zoukankan      html  css  js  c++  java
  • 关于跨域和如何解决跨域问题的小结

    之前使用到JSONP的时候接触了一下跨域请求的问题,记录总结一下,以便以后参照。提到跨域,什么是跨域?只要协议、域名、端口有任何一个不同,都被当作是不同的域。

    特别注意两点:

    第一:如果是协议和端口造成的跨域问题“前台”是无能为力的。

    第二:在跨域问题上,域仅仅是通过“URL的首部”来识别而不会去尝试判断相同的ip地址对应着两个域或两个域是否在同一个ip上。

    • 前台关于处理跨域的方法

      (一)document.domain+iframe的设置

        (二)动态创建script

      (三)利用iframe和location.hash

        (四)window.name实现的跨域数据传输

        (五)使用HTML5 postMessage

        (六)利用flash

        (七)jsonp

        (八)jQuery插件-jquery-jsonp

    angularjs关于解决跨域的问题

    一、$http.jsonp【实现跨域】

    1. 指定callback和回调函数名,函数名为JSON_CALLBACK时,会调用success回调函数,JSON_CALLBACK必须全为大写。
    2. 指定其它回调函数,但必须是定义在window下的全局函数。url中必须加上callback。

    二、$http.get【实现跨域】

    1. 在服务器端设置允许在其他域名下访问

    response.setHeader("Access-Control-Allow-Origin", "*"); //允许所有域名访问
    response.setHeader("Access-Control-Allow-Origin", "http://www.123.com"); //允许www.123.com访问

    2. AngularJS端使用$http.get()

    三、$http.post【实现跨域】

    1. 在服务器端设置允许在其他域名下访问,及响应类型、响应头设置

    response.setHeader("Access-Control-Allow-Origin", "*");
    response.setHeader("Access-Control-Allow-Methods","POST");
    response.setHeader("Access-Control-Allow-Headers","x-requested-with,content-type");

    2. AngularJS端使用$http.post(),同时设置请求头信息

    $http.post('http://localhost/ajax/getAllIndustryCategoty.pt',{languageColumn:'name_eu'},{'Content-Type':'application/x-www-form-urlencoded'}).success(function(data){
    		$scope.industries = data;
    	});
  • 相关阅读:
    搭建环境遇到的几个问题
    webservice
    Eclipse 反编译 阅读class 文件
    设置navigationBar上面的item
    自定义的UITabbar上面的按钮的x坐标的计算方法
    UIToolbar自定义背景及按钮设置
    UITabBar实现自定义背景及UITabBarItem自定义图片和字体
    IOS APP圆形图片的实现
    如果AlertView输入框为空,则禁止点击确定按钮
    两种局部刷新UITableView的方法的使用条件
  • 原文地址:https://www.cnblogs.com/xiaoxiaochengxuyuan/p/5629842.html
Copyright © 2011-2022 走看看