Axios请求结合后台实例

本文深入探讨了在Vue项目中使用Axios进行GET和POST请求的细节,包括参数处理、请求头设置及后端对接注意事项。特别关注了get请求参数的URL拼接,post请求中qs.stringify的使用,以及Content-Type对后端接收的影响。

这几天一直在看axios在vue项目中的封装和模块话的东西,当时开了一个后台测试,然后发现在发送请求和后台接收参数的时候有些问题自己不是很清楚,然后使用postman做了一些测试。记录如下!

1、get请求

众所众知,使用get请求的话,参数只能拼接在url上面,使用postman的话发送get请求,请求体是禁止选的,如下

 所以使用axios发送get请求的话,可以直接拼接在url上面,也可以使用axios.get(url,{params:{name:123}})使用,使用后一种方法也是把{name:123}处理拼接在url上面

//前台
axios.get(url,{params:{name:"123"}})
//后台接收参数
@RestController
@RequestMapping(value = "/axios")
public class Test {
        @GetMapping(value="/test1")
        public List<Map<String,String>> result(@RequestParam Map m){
            System.out.println(m+"==========");  //{name=123, age=12}==========

注意点:get请求后台不能使用RequestBody接收 因为get请求数据不是放在请求体里面(报错:Required request body is missing:)

2、post请求

 首先介绍一个 常用的使用axios发送post请求的用法

import qs from "qs"
axios.post("/api/axios/test2",qs.stringify({name:123,age:12}))...
其中qs是axios自带的一个库 处理请求的参数qs.stringify()处理过得数据格式是name=123&age =12
此时request头的Content-Type是application/x-www-form-urlencoded;charset=UTF-8

--后台
@PostMapping(value="/test2")
    public List<Map<String,String>> postRequest(@RequestParam Map m){
        System.out.println(person+"===========");//{name=123, age=12}===========

  此时后台不能使用RequestBody注解接收(报错信息: "Content type 'application/x-www-form-urlencoded;charset=UTF-8' not supported",) 就是这个注解不支持这种请求mime类型;如果使用RequestParam注解接收数据的话 

import qs from "qs"
axios.post("/api/axios/test2",qs.stringify({name:[1,2,3],age:12}))...
其中qs是axios自带的一个库 处理请求的参数qs.stringify()处理过得数据格式是name=123&age =12
此时request头的Content-Type是application/x-www-form-urlencoded;charset=UTF-8

--后台
@PostMapping(value="/test2")
    public List<Map<String,String>> postRequest(@RequestParam Map m){
        System.out.println(person+"===========");//{name[0]=11, name[1]=22, name[2]=33,                             
                                                    age=11}===========

此时的传过来的数组被分解,很奇怪,目前还不知道什么原因

所以最好还是使用默认的Content-Type:application/json接收数据 使用RequestBody和RequestParam注解都可以接收数据 

前置知识: - Vue3.0 - Axios - 微服务 Axios是一个基于Promise的HTTP库,可以用于浏览器和Node.js。在Vue中,我们通常使用Axios来发送HTTP请求。 微服务是一种面向服务架构的软件设计风格。它把一个应用划分为一些小的、独立的、可替换的服务,每个服务运行在自己的进程中,服务之间通过轻量级通信机制互相协作。微服务架构可以提高应用的可伸缩性和可维护性。 下面是一个基于Vue3和Axios的微服务请求封装示例: 1. 安装Axios ``` npm install axios ``` 2. 创建axios实例 ```js import axios from 'axios' const service = axios.create({ baseURL: process.env.VUE_APP_BASE_API, // 微服务请求的基础路径 timeout: 5000 // 超时时间 }) // 请求拦截器 service.interceptors.request.use( config => { // 在请求发送之前做些什么 return config }, error => { // 对请求错误做些什么 console.log(error) // for debug return Promise.reject(error) } ) // 响应拦截器 service.interceptors.response.use( response => { // 对响应数据做些什么 const res = response.data if (res.code !== 20000) { // 如果响应状态码不是20000,则视为错误 return Promise.reject(new Error(res.message || 'Error')) } else { return res } }, error => { // 对响应错误做些什么 console.log('err' + error) // for debug return Promise.reject(error) } ) export default service ``` 3. 封装请求方法 ```js import request from '@/utils/request' export function getUserInfo() { return request({ url: '/user/info', method: 'get' }) } export function login(data) { return request({ url: '/user/login', method: 'post', data }) } export function logout() { return request({ url: '/user/logout', method: 'post' }) } ``` 在组件中使用: ```js import { getUserInfo } from '@/api/user' export default { name: 'HelloWorld', created() { getUserInfo().then(response => { console.log(response) }) } } ``` 这样就完成了基于Vue3和Axios的微服务请求封装。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值