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)
上一篇 2025年8月29日 上午10:43
下一篇 2025年8月29日 上午11:15


相关推荐

  • 鲁大师 android模拟器,手机模拟大师怎么安装?鲁大师安卓模拟器安装教程

    鲁大师 android模拟器,手机模拟大师怎么安装?鲁大师安卓模拟器安装教程许多网友向小编反映不知道怎么下载手机模拟大师?下载完成后不知道怎么安装?今天极速小编为大家提供一个安装教程,希望对大家有帮助!首先我们下载手机模拟大师(下载地址:http://www.jisuxz.com/down/49186.html),下载完成后点击打开文件夹找到下载的压缩文件,解压后打开安装文件“LDSGameMasterMini_officialwebsite.exe”,出现安装界面:这时…

    2022年6月1日
    63
  • 大数据采集技术概述「建议收藏」

    大数据采集技术概述「建议收藏」大数据采集是指从传感器和智能设备、企业在线系统、企业离线系统、社交网络和互联网平台等获取数据的过程。数据包括RFID数据、传感器数据、用户行为数据、社交网络交互数据及移动互联网数据等各种类型的结构化、半结构化及非结构化的海量数据。不但数据源的种类多,数据的类型繁杂,数据量大,并且产生的速度快,传统的数据采集方法完全无法胜任。所以,大数据采集技术面临着许多技术挑战,一方面需要保证数据…

    2022年6月24日
    48
  • java发送邮件带url、html

    java发送邮件带url、htmljava发送邮件,内容包含URL、HTML,并且对URL中文编码,URL的有效性校验。

    2022年5月14日
    39
  • 由于Redis后门漏洞导致服务器被注入挖矿脚本解决过程

    由于Redis后门漏洞导致服务器被注入挖矿脚本解决过程由于Redis后门漏洞导致服务器被注入挖矿脚本解决过程事件描述某一天的早晨,我还是像往常一样搭着公交车开启打工仔的一天,一早8.30就到办公室了,坐着玩手机等上班,就这这时突然我组长飞快的回来办公室,回来就说快看看阿里云后台服务,服务是不是挂掉了,我当时就纳闷了一大早的流量不大怎么就宕机了呢,不一会我组长收到了阿里云短信通知监测到恶意脚本,接下来就是脚本的查找前期处理首先是通过阿里云的控制台发现,查看到恶意的进程PID,通过ps-ef|greap5724的确看到了当前进程,前期处理我只

    2022年7月14日
    20
  • python中如何打开csv文件_python如何读取csv文件

    python中如何打开csv文件_python如何读取csv文件python如何读取csv文件,我们这里需要用到python自带的csv模块,有了这个模块读取数据就变得非常容易了。工具/原料python3方法/步骤1这里以sublimetext3编辑器作为示范,新建一个文档。2我们可以先确认CSV文档是否可以正确打开。并且放在同一个文件夹里面。3importcsv这是第一步要做的,就是调用csv模块。4importcsvfile=open(‘data…

    2022年7月21日
    31
  • idea快捷键大全最新文档(ctrl快捷键大全截图)

    Ctrl快捷键 介绍 Ctrl+F 在当前文件进行文本查找(必备) Ctrl+R 在当前文件进行文本替换(必备) Ctrl+Z 撤销(必备) Ctrl+Y 删除光标所在行或删除选中的行(必备) Ctrl+X 剪切光标所在行或剪切选择内容 Ctrl+C 复制光标所在行或复制选择内容 …

    2022年4月10日
    83

发表回复

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

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