Vue.js配置全局参数并向后端SpringBoot接口发Get/Post请求

本文介绍了如何在Vue.js应用中配置全局参数,利用Vuex管理axios请求路径,并展示了向后端SpringBoot接口发送Get和Post请求的方法。文中提到Post请求时,若参数为非POJO的JSON,可通过引入FASTJSON并在全局配置中处理。同时,作者分享了个人从后端转向前端开发的学习历程。
先说配置,在axios发送请求的地方要加请求路径,但是如果分散在不同的地方很明显不好管理,我们要统一在一个路由文件管理。具体看这位大佬的文章写得非常好:VueX(Vue状态管理模式)

(1)npm i vuex -s
安装管理工具,让它来管理我们全部的请求路径。
(2)新建一个store文件夹,新增一个index.js文件作为我们的全部请求路径管理文件
在这里插入图片描述

这里我只是写了请求路径,当然也可以写其他的全局参数,比如域名,比如区分不同环境下的不同配置参数,又或者定义一些全局常量,一些枚举类型,统一的状态码…等等东西都可以放在这里。

(3)修改main.JS文件
在这里插入图片描述

(4)在要使用的地方,直接按照下图使用:
在这里插入图片描述

Get请求:

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

Post请求:

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

这里的Post请求接参我用了@RequestBody,参数类型是一个POJO,所以只要参数名一样,就自动映射进去了。
那么有的情况下我们Post的参数并不是POJO,只是单纯的JSON,怎么接受:

(1)引入FASTJSON依赖

// 获取参数方式7:post请求JSON数据格式,各参数名与POJO定义的字段完全不一样, 通过HttpServletRequest获取(需要引入fastJson依赖)
    @PostMapping("/httpServletRequest")
    public String httpServletRequest(HttpServletRequest param){
        JSONObject jsonParam = null;
        try {
            // 获取输入流
            BufferedReader streamReader = new BufferedReader(new InputStreamReader(param.getInputStream(), "UTF-8"));

            // 写入数据到Stringbuilder
            StringBuilder sb = new StringBuilder();
            String line = null;
            while ((line = streamReader.readLine()) != null) {
                sb.append(line);
            }
            jsonParam = JSONObject.parseObject(sb.toString());
            // 直接将json信息打印出来
            System.out.println("转换出来的JSON:"+jsonParam.toJSONString());
        } catch (Exception e) {
            e.printStackTrace();
        }
        return "转换出来的JSON:"+jsonParam.toJSONString();
    }

(2)在全局请求路径配置文件新增一条:
在这里插入图片描述
(3)
在这里插入图片描述
(4)
在这里插入图片描述

这样就OK啦,其实重点不在于前端如何传,而是在于后端如何用各种方式接。请看我另外一篇博客是做得比较齐全的总结:SpringBoot在Controller层接参常用方法总结
其实我是严重偏科后端的,最近才开始做一些前端内容,也会慢慢把自己踩坑过程记录下来,如果有帮助的话可以点个赞哈~
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值