技术饭

ajax请求中的jsonp可以设置POST方式,但效率不高

copylian    0 评论    14711 浏览    2017.05.15

ajax请求中的jsonp可以设置POST方式,但效率不高,JSONP是一种非官方协议,可以解决AJAX跨域提交数据情况。安全部门的同事测试发现,都是GET的请求,相比较而言不如POST安全,还是尽量改了吧。但是,JSONP真的支持POST提交吗?近期在项目中遇到这样一问题,关于jsonp跨域问题,get传值是可以的,但post传值死活不行啊,于是网上看了一大堆关于这方面的资料,最终问题得以解决,今天抽空与大家分享下。

当然这是我本地配置的,需要改为自己对应的地址。

客户端代码:

<script type="text/javascript">

    $(function(){

        var url = 'http://www.t1.com/index.php';

        $.ajax({

                   type:      'post',

                   url:      url,

                   data:      {name:'wangyulu'},

                   dataType:    'jsonp',

                   success:function(result){

                                 console.log(result);

                    }

        });

  });

 </script>

服务端代码:

<?php

if($_POST){

        $arr = array('name'=>$_POST['name'], 'age'=>23);

        echo json_encode($arr);

}

浏览器运行如下图:

ajax请求中的jsonp可以设置POST方式,但效率不高

看下运行结果,即使设置传送方式为 post,Jquery也会自动转为 get,难道Jsonp真的不支持 post 方式提交吗,继续折腾...

折腾到现在最终在 stackoverflow 里找到一些关于这方面的资料,看来老外也遇到这样问题呀,地址贴给大家:http://stackoverflow.com/questions/3860111/how-to-make-a-jsonp-post-request-that-specifies-contenttype-with-jquery

关键点如下图:

ajax请求中的jsonp可以设置POST方式,但效率不高

看上图我们发现,箭头标记处有变化,先不管这么多了,折腾这么久了,先对应放到程序里再说嘛,万一可以呢

客户端更改:

      添加:crossDomain: true

      修改:dataType: "json"

服务端添加:

      header('Access-Control-Allow-Origin: *');

      header('Access-Control-Allow-Methods: POST');

      header('Access-Control-Max-Age: 1000');

运行结果如下图:

ajax请求中的jsonp可以设置POST方式,但效率不高

到这里我们发现问题终于解决了,但我们详细观察发现,请求时间那是个漫长啊,,,看来老外也没个效率高的解决方案,

最后,我想说的是,要想完美支持POST方式的JSONP真心不好办啊,咱就到这吧,折腾不少时间了。

以上内容可能会关联到其它技术点,有兴趣自己可去研究哈,这里主要解决 Jsonp ,写的不好,大家请勿吐槽,谢谢!

以上所述就是本文的全部内容了,希望大家能够喜欢。

只袄早~~~
感谢你的支持,我会继续努力!
扫码打赏,感谢您的支持!
ajax 请求 jsonp post 

文明上网理性发言!

  • 还没有评论,沙发等你来抢