• 一文弄懂Vue与Servlet的交互:让你的大学课设变得容易起来


    1 写作动机

    目前较为流行的套装是SpringBoot+Vue。SpringBoot操作简单,仅会使用的话上手非常容易。那么小游你为何逆流而上,要写一个Vue+Servlet的交互呢?

    要知道,CSDN最大的受众是学生,而且多数是大学生。就目前的形势而言,大学里的技术偏基础,有些甚至已经过时,如JSP。而有些老师又特别的“顽固”,规定学生的课设必须采用某某技术,那么小游的这篇文章就是为了方便这些人群,让他们在一定的后端限制上,也可以使用较流行的Vue来开发前端网站。

    2 准备工作

    对于Servlet不太纯熟的朋友,安利一下小游的JavaWeb专栏— JavaWeb专栏,虽然不是很好,但也足矣完成基础的工作。如果想直接使用的话,建议看一下里面的两篇实战。

    Vue的准备工作,这涉及到挺多知识的了。略微列举一下:router(跳转)、aixos(发送请求+接受请求)。使用Elementui的话,还需引入Elementui,甚至有些特殊的操作,需要用到Vuex。

    安利一下小游的这篇文章 从零搭建一个Vue项目,想要了解axios基础的。本文对接口进行统一管理,建议看一下小游的 Axios详解

    3 前端请求

    3.1 get请求

    关于axios的get请求,我记录了两种方法。

    3.1.1 仿照网站栏撰写

    image-20221104171148462

    ?后面是参数名=参数的内容,如果需要写多个,则用&分隔开来

    比如我想访问loginServlet,同时携带用户名和密码

    export const reqGetStudentByUsername = (username,password) => requests({ url: `/loginServlet?username=${username}&password=${password}`, method: 'get' });
    
    • 1

    此处的username、password即为后端 request.getParameter(参数);的参数值。

    3.1.2 按照Parms格式传参

    格式如下

    export const reqGetStudentByLikename = (username) => requests({
       url: `/likeServlet`, params: {
          username:username
       }, method: 'get'
    });
    
    • 1
    • 2
    • 3
    • 4
    • 5

    对于params,官方给出了这样两句话

    • params 是与请求一起发送的 URL 参数
    • 必须是一个简单对象或 URLSearchParams 对象

    使用多个参数时,只需要在params这个参数里面继续写即可

    export const reqGetStudentByLikename = (username) => requests({
       url: `/likeServlet`, params: {
          username:username,
       	  password:password,
           //........
       }, method: 'get'
    });
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    3.2 Post请求

    3.2.1 按照Data格式传参

    对于Data的解释,官方给了如下几点:

    • data 是作为请求体被发送的数据

    • 仅适用 ‘PUT’, ‘POST’, 'DELETE 和 ‘PATCH’ 请求方法

    • 在没有设置 transformRequest 时,则必须是以下类型之一: string, plain object, ArrayBuffer,ArrayBufferView,URLSearchParams

    • 浏览器专属: FormData, File, Blob

    • Node 专属: Stream, Buffer

    在统一管理的页面需要写成如下格式:

    export const reqPreserveColor = (data) => requests({ url: "/preserveColor", method: 'post', data: data });
    
    • 1

    在使用的页面里面,需要进行如下操作:

    npm install qs --save-dev
    
    • 1

    随后,在调用reqPreserveColor的文件中引入qs

    import qs from 'qs'
    
    • 1

    在传参之前需要进行一步操作,

    let data = qs.stringify({
            username: "游坦之",
            password: "20221114"
    })
    
    • 1
    • 2
    • 3
    • 4

    为什么要进行这样的一步操作呢?

    可以追溯到上面Axios官方给出的解释,要求所传的Data必须是 string, plain object, ArrayBuffer,ArrayBufferView,URLSearchParams其中的一种,Vue中的Object应该不是其中之一,所以需要转化一下。

    如果不转换直接传一个对象,那么netWork就不会显示这个请求,而且后端的Servlet也不会获取到相应的参数。

    image-20221104184457559

    3.2.2 按照Params格式传参

    Params要求的是一个对象,而不需要使用Qs转化,否者会爆如下的错误。所以使用Post请求,一定要区分好Params和Data两种方式。否则就容易出错

    image-20221104170441341

    在管理接口的文件处,格式写成如下

    export const reqPreserveColor = (params) => requests({ url: "/preserveColor", method: 'post', params: params });
    
    • 1

    在使用接口的地方,直接使用Vue的Object即可。

    image-20221104190039659

    然后便可正常发送成功!

    image-20221104185949331

    3.3 一个特殊的点

    method千万不要写成methods,这个错困惑了我很长的时间

    4 后端接收请求

    4.1 提要

    后端基本上都是固定的格式,大体分三步:接收参数、处理参数、反馈参数。

    当然要产生不同的效果,就需要使用不同的Sql语句,切记,使用update和insert的时候,一定切记要提交一下,否则不会保存在数据库里面的。自己手动添加,数据库也会提醒你要commit的。

    最后反馈的时候,还要转化成JSON格式,这样前端的页面,才能拿到正确的数值。

    4.2 代码

    4.2.1 架子

    @WebServlet("/preserveColor")
    public class preserveColor extends HttpServlet {
        @Override
        protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
            req.setCharacterEncoding("UTF-8");
            resp.setContentType("text/html;charset=utf-8");
            PrintWriter out = resp.getWriter();
            /* 1、模块一:获取参数 */
            /* 2、模块二:执行业务逻辑*/
            /* 3、模块三:反馈给前端 */
            out.flush();
            out.close();
        }
        @Override
        protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
            this.doGet(req, resp);
        }
    }
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19

    4.2.2 模块一:获取参数

    String username = req.getParameter("user_no");
    String color = req.getParameter("color");
    
    • 1
    • 2

    4.2.3 模块二:处理参数

    包括连接数据库以及操作数据库(这里省略了数据库sql语句的撰写,也就是insertUserInfo这个方法,需要写在UserMapper.interface这个类里面)

     String resource = "mybatis-config.xml";
     InputStream inputStream = null;
     inputStream = Resources.getResourceAsStream(resource);
     SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
     SqlSession sqlSession = sqlSessionFactory.openSession();
     UserMapper mapper = sqlSession.getMapper(UserMapper.class);
     boolean user = mapper.insertUserInfo(username,color);
     resp.setContentType("text/html;charset=UTF-8");
     PrintWriter writer = resp.getWriter();
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    4.2.4 模块三:反馈参数

    如果执行的是update或者insert,一定要记得 sqlSession.commit();提交

     if (user) {
       sqlSession.commit();
       String json = JSON.toJSONString(user);
       System.out.println(json);
       out.write(json)
     }else{}
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    可以看到是可以正常获取到数据的。

    image-20221104194227884

    4.3 思考

    前两天和一个同学聊天聊到:前端每发一个请求都需要为之撰写Servlet匹配吗?

    他讲到:通过获取Servlet的访问路径,对路径进行拆分,可以实现一个Servlet完成多个不同的请求。如/brand/*下的路径都来访问aServlet,再根据后缀路径找到不同的方法,如/brand/getOperaID,根据getOperaID,去找查询戏剧Id的方法,/brand/updateMusicID,根据updateMusicID去找修改音乐ID的方法。

    我恍然大悟,原来SpringBoot每个方法前面的@GetMapping(“”)也应该是通过这种形式实现的。

    访问路径,对路径进行拆分,可以实现一个Servlet完成多个不同的请求。如/brand/*下的路径都来访问aServlet,再根据后缀路径找到不同的方法,如/brand/getOperaID,根据getOperaID,去找查询戏剧Id的方法,/brand/updateMusicID,根据updateMusicID去找修改音乐ID的方法。

    我恍然大悟,原来SpringBoot每个方法前面的@GetMapping(“”)也应该是通过这种形式实现的。

    可见学习一定不要闭门造车,多和志同道合的人交流会有意想不到的收货,这一点是我所欠缺的。勉之!

  • 相关阅读:
    Java基础题(巩固语法)
    腾讯云服务器秒杀什么时候开始?腾讯云服务器秒杀时间
    虚拟机weblogic服务搭建及访问(物理机 )
    PAT 乙级 1052 卖个萌 python
    实验四 软中断信号及处理
    【可扩展性】谷歌可扩展和弹性应用的模式
    “基础不牢地动山摇“ ==> 重温 《内部类》
    Android Studio实现简易计算器(带横竖屏,深色浅色模式,更该按钮颜色,selector,style的使用)
    搜索指标优化
    华为云HECS云服务器docker环境下安装nacos
  • 原文地址:https://blog.csdn.net/m0_59792745/article/details/127695179