利用window.name跨域请求

稿件来源: 阳光企业网站管理系统   撰稿作者: 太阳光   发表日期: 2016-01-31   阅读次数: 201   查看权限: 游客查看

利用window.name跨域请求

var url = "http://www.xxx.com/post.php";//在这个文件里返回<script>window.name='{需要的json字符串}'<\/script>
postJSONP(url, {name:"xzys",pass:"123456"}, function(obj){
    console.log(obj);
});
function postJSONP(url, data, fn) {
    var _doc = document,form = _doc.createElement("form"),
        iframeState,key,input,iframe,iframeName = "ifr" + Math.random().toString(16).slice(-6);
    //创建表单数据
    if (!!data) {
        for(key in data) {
            input = _doc.createElement("input");
            input.type = "hidden";
            input.name = key;
            input.value = data[key];
            form.appendChild(input);
        }
    }
    form.action = url;
    form.target = iframeName;
    form.method = "post";
    _doc.body.appendChild(form);
    try {
        iframe = _doc.createElement('<iframe name="'+iframeName+'">');//兼容IE6、7
    } catch (e) {
        iframe = _doc.createElement('iframe');
        iframe.name = iframeName;
    }
    iframe.style.display = "none";
    iframe.attachEvent ? iframe.attachEvent("onload", fulfil) :(iframe.onload = fulfil);//事件处理
    _doc.body.appendChild(iframe);
    form.submit();//表单提交
    iframeState = 0;//框架状态记录
    function fulfil(){
        if(iframeState === 0){
            iframeState = 1;
            iframe.removeAttribute('name');//解决IE10+获取不到window.name的问题
            iframe.contentWindow.location.replace("about:blank");
        }else if(iframeState === 1){
            iframeState = null;
            var json,arr,str = iframe.contentWindow.name;
            console.info(str);
            try{
                json = window.JSON ? JSON.parse(str) : new Function("return " + str)();
            }catch(e){
                json = {error:1};
            }
            iframe.contentWindow.document.write('');
            iframe.contentWindow.close();
            _doc.body.removeChild(iframe);
            _doc.body.removeChild(form);
            //执行回调方法
            if(typeof fn === "function"){
                fn(json);
            }else if(arr = url.match(/[&?]callback=([^&#]+)/)){
                typeof window[arr[1]] === 'function' && fn(json);
            }
        }
    }
}

 

关键词: 跨域请求,window.name,跨域   编辑时间: 2016-01-31 11:24:16

  • 感到高兴

    0

    高兴
  • 感到支持

    0

    支持
  • 感到搞笑

    0

    搞笑
  • 感到不解

    0

    不解
  • 感到谎言

    0

    谎言
  • 感到枪稿

    0

    枪稿
  • 感到震惊

    0

    震惊
  • 感到无奈

    0

    无奈
  • 感到无聊

    0

    无聊
  • 感到反对

    0

    反对
  • 感到愤怒

    0

    愤怒
0%(0)
0%(0)
共有0 条评论 发言请遵守【相关规定

网友评论

会员头像
发 表同步腾讯微博    验证码:  点击更新请先登陆
  • 暂无评论
关闭模块文章图片 article Pictrue
  • 我的妈妈爸爸
  • 基于koa2+mysql+vue2.0+Element阳光内容管理系统
  • 代码覆盖率工具 Istanbul 入门教程
  • 全栈工程师的武器——MEAN
  • 9款超炫的 CSS3 复选框(Checkbox)
  • 微信开发在线翻译功能
  • CSS3那些不为人知的高级属性
  • 给easyui的datebox添加清空事件
  • flash写字效果
  • kendoUI系列教程之DropDownList下拉菜单
  • kendoUI系列教程之datetimepicker日期时间选择
  • kendoUI系列教程之datepicker日期选择
  • kendoUI系列教程之combobox下拉列表框
  • kendoUI系列教程之colorpicker
  • kendoUI系列教程之calendar日历表
  • kendoUI系列教程之autocomplete自动补齐