zoukankan      html  css  js  c++  java
  • Ajax跨域请求设置带Cookie

    1. 无关Cookie跨域Ajax请求
    客户端
    以 Jquery 的 ajax 为例:
    $.ajax({ url : 'http://remote.domain.com/corsrequest', data : data, dataType: 'json', type : 'POST', crossDomain: true, contentType: "application/json", // POST时必须 ...
    主要注意的是参数 crossDomain: true。发送Ajax时,Request header 中会包含跨域的额外信息,但不会含cookie。
    服务器端
    跨域的允许主要由服务器端控制。服务器端通过在响应的 header 中设置 Access-Control-Allow-Origin 及相关一系列参数,提供跨域访问的允许策略。相关参数的设置介绍,可参见 [Access_control_CORS]
    以Java为例:
    /** * Spring Controller中的方法: */ @RequestMapping(value = "/corsrequest") @ResponseBody public Map<String, Object> mainHeaderInfo(HttpServletResponse response) { response.setHeader("Access-Control-Allow-Origin", "*"); ... }
    • 通过在响应 header 中设置 ‘*’ 来允许来自所有域的跨域请求访问。
    response.setHeader("Access-Control-Allow-Origin", "*");
    • 只允许来自特定域 http://my.domain.cn:8080 的跨域访问
    response.setHeader("Access-Control-Allow-Origin", "http://my.domain.cn:8080");
    • 较灵活的设置方式,允许所有包含 mydomain.com 的域名访问.
    if(request.getHeader("Origin").contains("mydomain.com")) { response.setHeader("Access-Control-Allow-Origin", request.getHeader("Origin")); }
    2. 带Cookie的跨域Ajax请求
    客户端
    $.ajax({ url : 'http://remote.domain.com/corsrequest', data : data, dataType: 'json', type : 'POST', xhrFields: { withCredentials: true }, crossDomain: true, contentType: "application/json", ...
    通过设置 withCredentials: true ,发送Ajax时,Request header中便会带上 Cookie 信息。
    服务器端
    相应的,对于客户端的参数,服务器端也需要进行设置:
    /** * Spring Controller中的方法: */ @RequestMapping(value = "/corsrequest") @ResponseBody public Map<String, Object> getUserBaseInfo(HttpServletResponse response) { if(request.getHeader("Origin").contains("woego.cn")) { response.setHeader("Access-Control-Allow-Origin", request.getHeader("Origin")); } response.setHeader("Access-Control-Allow-Credentials", "true"); ... }
    对应客户端的 xhrFields.withCredentials: true 参数,服务器端通过在响应 header 中设置 Access-Control-Allow-Credentials = true 来运行客户端携带证书式访问。通过对 Credentials 参数的设置,就可以保持跨域 Ajax 时的 Cookie。这里需要注意的是:
    服务器端 Access-Control-Allow-Credentials = true时,参数Access-Control-Allow-Origin 的值不能为'*' 。
  • 相关阅读:
    js中的构造函数
    js中的匿名函数
    【bzoj4771】七彩树 树链的并+STL-set+DFS序+可持久化线段树
    【bzoj3881】[Coci2015]Divljak AC自动机+树链的并+DFS序+树状数组
    【loj6029】「雅礼集训 2017 Day1」市场 线段树+均摊分析
    【loj114】k大异或和 线性基+特判
    【bzoj5118】Fib数列2 费马小定理+矩阵乘法
    【bzoj5084】hashit 广义后缀自动机+树链的并+STL-set
    【bzoj5210】最大连通子块和 树链剖分+线段树+可删除堆维护树形动态dp
    【bzoj4712】洪水 树链剖分+线段树维护树形动态dp
  • 原文地址:https://www.cnblogs.com/a-moemiss/p/12844592.html
Copyright © 2011-2022 走看看