axios03-解决请求头兼容导致跨域报错问题

2024-09-02 15:48

本文主要是介绍axios03-解决请求头兼容导致跨域报错问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

不同版本接口区别老版本接口(form形式)新版本接口(json形式)
请求头application/x-www-form-urlencodedapplication/json;charset=UTF-8
参数格式序列化字符串: key1=value1&key2=value2json格式字符串 :{key1:value1}
接口请求头和参数错误提示(1)服务器返回:参数错误
(2)状态码400
(1)服务器返回:参数错误
(2)状态码400
(3)跨域报错
  • 1.老版本的后台接口post请求头是:application/x-www-form-urlencoded

    • axios不支持

    • 解决方案

      • 1.设置axios请求头为application/x-www-form-urlencoded

        • headers: {'Content-type': 'application/x-www-form-urlencoded'}
          
      • 2.将参数拼接为:key1=value1&key2=value2

        • 使用qs第三方包来拼接:Qs.stringify({username: 'zxk'})
          • qs网站:https://www.npmjs.com/package/qs
  • 2.新版本的后台接口post请求头是:application/json;charset=UTF-8

    • axios默认支持,不需要任何处理
/*1.学习目标介绍 : axios解决post请求兼容性问题2.学习路线 :(1)post请求头类型a.在很久很久以前,ajax技术没有发明以前,浏览器发送请求使用的是form表单来发送,form表单默认的请求头是:application/x-www-form-urlencodedb.后来ajax技术发明之后,由于之前的服务器处理post请求都是按照表单的默认请求头方式来处理所以,ajax发送post请求,一般也设置请求头为:application/x-www-form-urlencodedc. axios技术发明之后,此时json数据格式传输已经越来越流行,所以在axios中post请求默认的请求头是:'Content-Type: application/json;charset=UTF-8'd. 不同的请求头,服务器在处理的时候方式不一样。所以前后端必须要统一总结:a. 老接口的post请求头是:application/x-www-form-urlencoded这种方式参数会以:  'key1=value1&key2=value2'形式传输后台处理方式:字符串切割获取参数b. 新接口的post请求头是: application/json;charset=UTF-8这种方式参数会以json格式传输: '{"key":"value"}'这种方式处理:JSON.parse()解析(2)axios解决post请求兼容性a. 如果你的后台是新接口,则不需要任何处理。(axios默认json格式)b. 如果你的后台是老接口(1)需要设置axios的请求头为:application/x-www-form-urlencoded(2)需要将参数转为拼接方式:key1=value1&key2=value2(3)使用axios后如何判断后台是老接口还是新接口?a. 有的服务器会返回一段文本提示你:参数格式错误b. 有的服务器直接返回400错误码,也是提示你参数格式错误  c. 有的服务器会直接报错跨域   */
<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><meta http-equiv="X-UA-Compatible" content="ie=edge"><title>Document</title>
</head><body><button id="btn1">点我发送post请求(老接口)</button><button id="btn2">点我发送post请求(新接口)</button><!-- 导入axios --><script src="./axios.js"></script><script src="./qs.js"></script><form action="" enctype="application/x-www-form-urlencoded"></form><script>/*1.学习目标介绍 : axios解决post请求兼容性问题2.学习路线 :(1)post请求头类型a.在很久很久以前,ajax技术没有发明以前,浏览器发送请求使用的是form表单来发送,form表单默认的请求头是:application/x-www-form-urlencodedb.后来ajax技术发明之后,由于之前的服务器处理post请求都是按照表单的默认请求头方式来处理所以,ajax发送post请求,一般也设置请求头为:application/x-www-form-urlencodedc. axios技术发明之后,此时json数据格式传输已经越来越流行,所以在axios中post请求默认的请求头是:'Content-Type: application/json;charset=UTF-8'd. 不同的请求头,服务器在处理的时候方式不一样。所以前后端必须要统一总结:a. 老接口的post请求头是:application/x-www-form-urlencoded这种方式参数会以:  'key1=value1&key2=value2'形式传输后台处理方式:字符串切割获取参数b. 新接口的post请求头是: application/json;charset=UTF-8这种方式参数会以json格式传输: '{"key":"value"}'这种方式处理:JSON.parse()解析(2)axios解决post请求兼容性a. 如果你的后台是新接口,则不需要任何处理。(axios默认json格式)b. 如果你的后台是老接口(1)需要设置axios的请求头为:application/x-www-form-urlencoded(2)需要将参数转为拼接方式:key1=value1&key2=value2(3)使用axios后如何判断后台是老接口还是新接口?a. 有的服务器会返回一段文本提示你:参数格式错误b. 有的服务器直接返回400错误码,也是提示你参数格式错误  c. 有的服务器会直接报错跨域   *///post请求:老接口/* 1.设置请求头:headers: {'Content-type': 'application/x-www-form-urlencoded'}2.将参数转为字符串拼接方式一般使用第三库qs来转换*/btn1.onclick = function () {//(1)使用第三方库  qs来转换参数格式(推荐)let str1 = Qs.stringify({username: 'zxk'});console.log(str1);//(2)使用js原生对象URLSearchParams来处理 (好处:不需要导入Qs库)// var param = new URLSearchParams();// param.append('username','zxk');axios({url: 'https://autumnfish.cn/api/user/check',method: 'post',data: str1,headers: {'Content-type': 'application/x-www-form-urlencoded'}}).then(res => {console.log(res);})};//post请求:新接口//不需要任何处理btn2.onclick = function () {axios({url: 'http://ttapi.research.itcast.cn/mp/v1_0/authorizations',method: 'post',data: {mobile: '18801185985',code: '246810'},}).then(res => {console.log(res);})};</script>
</body></html>

这篇关于axios03-解决请求头兼容导致跨域报错问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1130388

相关文章

如何使用Java实现请求deepseek

《如何使用Java实现请求deepseek》这篇文章主要为大家详细介绍了如何使用Java实现请求deepseek功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1.deepseek的api创建2.Java实现请求deepseek2.1 pom文件2.2 json转化文件2.2

mybatis和mybatis-plus设置值为null不起作用问题及解决

《mybatis和mybatis-plus设置值为null不起作用问题及解决》Mybatis-Plus的FieldStrategy主要用于控制新增、更新和查询时对空值的处理策略,通过配置不同的策略类型... 目录MyBATis-plusFieldStrategy作用FieldStrategy类型每种策略的作

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

linux下多个硬盘划分到同一挂载点问题

《linux下多个硬盘划分到同一挂载点问题》在Linux系统中,将多个硬盘划分到同一挂载点需要通过逻辑卷管理(LVM)来实现,首先,需要将物理存储设备(如硬盘分区)创建为物理卷,然后,将这些物理卷组成... 目录linux下多个硬盘划分到同一挂载点需要明确的几个概念硬盘插上默认的是非lvm总结Linux下多

Python Jupyter Notebook导包报错问题及解决

《PythonJupyterNotebook导包报错问题及解决》在conda环境中安装包后,JupyterNotebook导入时出现ImportError,可能是由于包版本不对应或版本太高,解决方... 目录问题解决方法重新安装Jupyter NoteBook 更改Kernel总结问题在conda上安装了

pip install jupyterlab失败的原因问题及探索

《pipinstalljupyterlab失败的原因问题及探索》在学习Yolo模型时,尝试安装JupyterLab但遇到错误,错误提示缺少Rust和Cargo编译环境,因为pywinpty包需要它... 目录背景问题解决方案总结背景最近在学习Yolo模型,然后其中要下载jupyter(有点LSVmu像一个

Goland debug失效详细解决步骤(合集)

《Golanddebug失效详细解决步骤(合集)》今天用Goland开发时,打断点,以debug方式运行,发现程序并没有断住,程序跳过了断点,直接运行结束,网上搜寻了大量文章,最后得以解决,特此在这... 目录Bug:Goland debug失效详细解决步骤【合集】情况一:Go或Goland架构不对情况二:

解决jupyterLab打开后出现Config option `template_path`not recognized by `ExporterCollapsibleHeadings`问题

《解决jupyterLab打开后出现Configoption`template_path`notrecognizedby`ExporterCollapsibleHeadings`问题》在Ju... 目录jupyterLab打开后出现“templandroidate_path”相关问题这是 tensorflo

如何解决Pycharm编辑内容时有光标的问题

《如何解决Pycharm编辑内容时有光标的问题》文章介绍了如何在PyCharm中配置VimEmulator插件,包括检查插件是否已安装、下载插件以及安装IdeaVim插件的步骤... 目录Pycharm编辑内容时有光标1.如果Vim Emulator前面有对勾2.www.chinasem.cn如果tools工

Python安装时常见报错以及解决方案

《Python安装时常见报错以及解决方案》:本文主要介绍在安装Python、配置环境变量、使用pip以及运行Python脚本时常见的错误及其解决方案,文中介绍的非常详细,需要的朋友可以参考下... 目录一、安装 python 时常见报错及解决方案(一)安装包下载失败(二)权限不足二、配置环境变量时常见报错及