您当前的位置:首页 > 计算机 > 编程开发 > Html+Div+Css(前端)

前端开发跨域请求并携带 Cookie 和 Authentication 头

时间:12-14来源:作者:点击数:
城东书院 www.cdsy.xyz

由于历史原因,一个应用即使用了 传统的 Cookie 登录,有使用 jwt 方式登录验证,为了让着两种方式能够互通,就需要 ajax 请求里面能够携带认证信息。

跨域一般设置 Access-Control-Allow-Origin: * 就够了,细心的你可能会发现,在请求里面没有携带任何 Cookie,这可不行,没有 Cookie 怎么验证用户,通过查询资料得知:Access-Control-Allow-Origin 有多种设置方法:

  • 设置 * 是最简单粗暴的,但是服务器出于安全考虑,肯定不会这么干,而且,如果是 * 的话,游览器将不会发送 cookies,即使你的 XHR 设置了 withCredentials
  • 指定域,如 http://172.20.0.206,一般的系统中间都有一个 nginx,所以推荐这种
  • 动态设置为请求域,多人协作时,多个前端对接一个后台,这样很方便

没有办法,Access-Control-Allow-Origin 只能设置为应用的域名,多个环境就需要动态设置,请参考这篇文章:https://www.cdsy.xyz/computer/programme/PHP/241214/cd70070.html,另外在 前端 也需要设置:

jQuery

$.ajax({
  xhrFields: {
    withCredentials: true,
  },

axios

axios.defaults.withCredentials = true; // 让 ajax 携带 cookie

详细介绍:https://www.cdsy.xyz/computer/servers/ns/251110/cd74930.html

城东书院 www.cdsy.xyz
方便获取更多学习、工作、生活信息请关注本站微信公众号城东书院 微信服务号城东书院 微信订阅号
推荐内容
相关内容
栏目更新
栏目热门
本栏推荐