axios发送cookie_js跨域设置cookie

axios发送cookie_js跨域设置cookie背景在开发vue的项目时,使用axios来与后端交互,经常会遇到几个问题请求跨域请求中带cookies请求跨域解决方案解决请求跨域有以下两种方案同源访问后端允许跨域请求这里主要针对非同源情况做介绍,解决请求跨域需要后端配合处理,下面直接看代码,这里的demo中,前端运行在localhost:1234,后端运行在localhost:3000,不满足同源协议axios发起请求impo…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

背景

在开发 vue 的项目时,使用 axios 来与后端交互,经常会遇到几个问题

请求跨域

请求中带 cookies

请求跨域解决方案

解决请求跨域有以下两种方案

同源访问

后端允许跨域请求

这里主要针对非同源情况做介绍,解决请求跨域需要后端配合处理,下面直接看代码,这里的 demo 中,前端运行在 localhost:1234,后端运行在 localhost:3000,不满足同源协议

axios发起请求

import axios from ‘axios’

(async function () {

try {

let {data} = await axios.get(‘//localhost:3000’)

console.log(data)

} catch (e) {

console.warn(e)

}

})()

在后端不做处理时,页面会报错

161cd33af3a0

QQ20180530-233625@2x.png

后端只需要按照提示设置响应头就可以了

res.header(“Access-Control-Allow-Origin”, “*”)

这时候前端已经可以做跨域请求了,不过一般这种情况尽量仅在测试环境使用,项目上线后通常就会同源访问了,如果仍为非同源,只需将 * 号修改为对应域名即可

请求中带 cookies

日常开发中,有些接口可能需要前端请求的时候携带 cookies 来做身份判断等操作,而 axios 请求默认是不带 cookies 的,这时需要前端与后端同时做一些调整

前端调整

// 对所有 axios 请求做处理

axios.defaults.withCredentials = true;

// 对单独的 axios 请求做处理

let {data} = await axios.get(‘//localhost:3000’, {

withCredentials: true

})

此时前端请求已经可以正常携带 cookies 了,而且可以正常发出请求甚至得到数据,而请求仍然抛出了一个 error,导致即使可以从 network 中看到数据,仍然没法进行进一步的使用

161cd33af3a0

QQ20180530-234749@2x.png

此时需要后端做一些调整,具体操作参照报错信息即可,根据当前 demo 的情况,后端可对响应头做如下调整

// res.header(“Access-Control-Allow-Origin”, “*”)

res.header(“Access-Control-Allow-Origin”, “http://localhost:1234”)

res.header(“Access-Control-Allow-Credentials”, true)

此时前端即可做跨域访问的同时,携带 cookies 了,如不涉及跨域情况,则去掉对于 origin 的设置即可

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/197726.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Linux dpkg 命令

    Linux dpkg 命令Linuxdpkg命令note:软件测试实习笔记1dpkgdpkg-idpkg-rdpkg-Pdpkg-ldpkgdpkg是linux系统下用来安装、创建和管理软件包的工具。其安装的软件包一般是下载到本地的软件包,拓展名是deb。格式:dpkg参数package.deb(初学者容易忘记打空格,在命令和参数以及参数和软件包中间要打空格,否则linux会无法

    2022年5月21日
    52
  • Tomcat报错—Invalid keystore format ,tomcat启动报错[通俗易懂]

    今天在修改了一些代码,然后重新放到服务器上,启动服务器的时候报这个错误!我就很纳闷,修改的文件里面根本就没有涉及到tomcat配置文件的内容怎么会出现这样子内容呢?想了很久也网上百度了很多,很多博客提供的解答都没有解决我的问题,然后我们主管过来看了一会,给出了指导性的建议,去看tomcat下的conf/server.xml 文件。然后逐步排查。

    2022年2月24日
    83
  • 安装Sql Server 2008R2报错0x84B10001[通俗易懂]

    安装Sql Server 2008R2报错0x84B10001[通俗易懂]解决方案:1、使用NotepadXML编辑C:\Windows\Microsoft.NET\Framework\v2.0.50727\CONFIG\machine.config2、删除system.serviceModel这个区(Section)。3、保存修改。如果出现提示:对路径“C:\Windows\Microsoft.NET\Framework\v2.0.50727…

    2025年10月24日
    4
  • 使用多重循环打印平行四边形「建议收藏」

    packagecom.qfedu.test1;/*** 使用多重循环打印平行四边形* 当我们打印三角形的时候:* 1.观察第一行符号的个数,第一行符号的个数决定了循环计数器的初始值* 2.观察形状符号的个数是越来越多的话就++越来越少就–* 3.当计数器变化为++的时候判断条件一定要小于或者小于等于某个值相当于设定一个上限* 4.当计数器变化为–的时候判断条件一定要大于或者大于等于某个值相当于设定一个下限*/publicclassT

    2022年4月7日
    76
  • windows 设置定时锁屏

    windows 设置定时锁屏设置间隔指定时间电脑自动锁屏CreateTime–2017年7月3日10:16:14Author:Marydon参考地址:电脑爱好者杂志举例:实现每间隔45分钟,电脑自动锁屏实现思路:  第一步:编写锁屏命令;  第二步:制定计划。实践:  1.编写锁屏命令    新建一个txt文件,重命名为:lockScreen(名字随意)–>打开该文件添…

    2022年7月21日
    57
  • linux shell指令大全整理

    linux shell指令大全整理整理了linuxshell中经常用到的指令和语法

    2022年10月18日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号