zoukankan      html  css  js  c++  java
  • 转载:ionic+nodejs开发遇到的跨域和post请求数据问题

    转载自:http://www.cnblogs.com/ytu2010dt/p/5471366.html

    最近学习ionic+nodejs开发混合app中遇到了一些问题,在此总结一下。

    项目地址 https://github.com/ytudt/nodejsApp

    代码和问题都会在之后的学习中持续更新

    1.跨域问题:

         之前一直想用ionic+angular打包app时代码在客户端,因为客户端js有ajax请求,这样去请求服务器数据时是不是跨域?

         在实际调试中后台nodejs起一个服务器 192.168.0.19:3000,然后前端我用sublime的server起一个服务器这样的确是跨域,所以在开始前台请求数据我一直用jsonp的方式。

    而在真机上跑也可以跑通,后来因为要发比较大的数据到后台,所以jsonp就不可以了。

        最近光搜资料得出的结论是当把app打包后在手机端实际上是file协议访问,顾没有跨域问题。然后开始试验,电脑端测试时安装了谷歌的一个插件Allow-Control-Allow-Origin(注意:需在Access-Control-Expose-Headers加上Allow-Control-Allow-Origin: *(表示允许所有ip访问))此插件实际用了cors的方式允许跨域取得数据。

        最终在电脑端和真机测试都能顺利拿到数据。

    2.angular发送post请求,开始这么写的

    $http.post(url, message).success(function(data) {
            console.log(data);
            });

    此时发现后台拿不到数据,然后各种查资料以及查看谷歌浏览器控制台信息,得出结论angular post请求默认数据格式为 application/json  而同样的后台程序我用jquery发送post请求后台可以拿到数据。以下为angular和jquery发送请求的信息。

                                                                         jquery 的请求头

                    angular post请求头

    此后根据angular官网的写法,重新改了代码

    复制代码
     var url = GlobalVariable.SERVER_PATH + "/doWrite";
            var req = {
              method: 'POST',
              url: url,
              headers: {
                'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8',
                'Accept': '*/*'
              },
              data:message  //message 必须是a=b&c=d的格式
            };
            $http(req).success(function(data){
              console.log(data);
               obj_goodsListData = data;
              deferred.resolve(obj_goodsListData);
            }).error(function(){});
    复制代码

    此时重新查看angular请求头如下。后台可拿到angular发送post的数据。

  • 相关阅读:
    驰骋工作流引擎-系统变量的引用
    驰骋工作流引擎-表单样本展示
    驰骋工作流引擎CCFLOW下载代码
    初识CSS
    初识HTML标签
    初识JDBC
    通过锁对象解决哲学家就餐问题
    MySQL基本用法
    LRU算法实现,HashMap与LinkedHashMap源码的部分总结
    Java简易实现记事本的打开与保存
  • 原文地址:https://www.cnblogs.com/niejunchan/p/5725320.html
Copyright © 2011-2022 走看看