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

相关文章

RedisTemplate默认序列化方式显示中文乱码的解决

《RedisTemplate默认序列化方式显示中文乱码的解决》本文主要介绍了SpringDataRedis默认使用JdkSerializationRedisSerializer导致数据乱码,文中通过示... 目录1. 问题原因2. 解决方案3. 配置类示例4. 配置说明5. 使用示例6. 验证存储结果7.

Swagger在java中的运用及常见问题解决

《Swagger在java中的运用及常见问题解决》Swagger插件是一款深受Java开发者喜爱的工具,它在前后端分离的开发模式下发挥着重要作用,:本文主要介绍Swagger在java中的运用及常... 目录前言1. Swagger 的主要功能1.1 交互式 API 文档1.2 客户端 SDK 生成1.3

java连接opcua的常见问题及解决方法

《java连接opcua的常见问题及解决方法》本文将使用EclipseMilo作为示例库,演示如何在Java中使用匿名、用户名密码以及证书加密三种方式连接到OPCUA服务器,若需要使用其他SDK,原理... 目录一、前言二、准备工作三、匿名方式连接3.1 匿名方式简介3.2 示例代码四、用户名密码方式连接4

如何解决Druid线程池Cause:java.sql.SQLRecoverableException:IO错误:Socket read timed out的问题

《如何解决Druid线程池Cause:java.sql.SQLRecoverableException:IO错误:Socketreadtimedout的问题》:本文主要介绍解决Druid线程... 目录异常信息触发场景找到版本发布更新的说明从版本更新信息可以看到该默认逻辑已经去除总结异常信息触发场景复

IDEA中Maven Dependencies出现红色波浪线的原因及解决方法

《IDEA中MavenDependencies出现红色波浪线的原因及解决方法》在使用IntelliJIDEA开发Java项目时,尤其是基于Maven的项目,您可能会遇到MavenDependenci... 目录一、问题概述二、解决步骤2.1 检查 Maven 配置2.2 更新 Maven 项目2.3 清理本

CentOS 7 YUM源配置错误的解决方法

《CentOS7YUM源配置错误的解决方法》在使用虚拟机安装CentOS7系统时,我们可能会遇到YUM源配置错误的问题,导致无法正常下载软件包,为了解决这个问题,我们可以替换YUM源... 目录一、备份原有的 YUM 源配置文件二、选择并配置新的 YUM 源三、清理旧的缓存并重建新的缓存四、验证 YUM 源

VS配置好Qt环境之后但无法打开ui界面的问题解决

《VS配置好Qt环境之后但无法打开ui界面的问题解决》本文主要介绍了VS配置好Qt环境之后但无法打开ui界面的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 目UKeLvb录找到Qt安装目录中designer.UKeLvBexe的路径找到vs中的解决方案资源

解决mysql插入数据锁等待超时报错:Lock wait timeout exceeded;try restarting transaction

《解决mysql插入数据锁等待超时报错:Lockwaittimeoutexceeded;tryrestartingtransaction》:本文主要介绍解决mysql插入数据锁等待超时报... 目录报错信息解决办法1、数据库中执行如下sql2、再到 INNODB_TRX 事务表中查看总结报错信息Lock

MySQL启动报错:InnoDB表空间丢失问题及解决方法

《MySQL启动报错:InnoDB表空间丢失问题及解决方法》在启动MySQL时,遇到了InnoDB:Tablespace5975wasnotfound,该错误表明MySQL在启动过程中无法找到指定的s... 目录mysql 启动报错:InnoDB 表空间丢失问题及解决方法错误分析解决方案1. 启用 inno

Java使用MethodHandle来替代反射,提高性能问题

《Java使用MethodHandle来替代反射,提高性能问题》:本文主要介绍Java使用MethodHandle来替代反射,提高性能问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑... 目录一、认识MethodHandle1、简介2、使用方式3、与反射的区别二、示例1、基本使用2、(重要)