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

news2025/2/24 23:04:06

文章目录

  • 1 写作动机
  • 2 准备工作
  • 3 前端请求
    • 3.1 get请求
      • 3.1.1 仿照网站栏撰写
      • 3.1.2 按照Parms格式传参
    • 3.2 Post请求
      • 3.2.1 按照Data格式传参
      • 3.2.2 按照Params格式传参
    • 3.3 一个特殊的点
  • 4 后端接收请求
    • 4.1 提要
    • 4.2 代码
      • 4.2.1 架子
      • 4.2.2 模块一:获取参数
      • 4.2.3 模块二:处理参数
      • 4.2.4 模块三:反馈参数
    • 4.3 思考

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' });

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

3.1.2 按照Parms格式传参

格式如下

export const reqGetStudentByLikename = (username) => requests({
   url: `/likeServlet`, params: {
      username:username
   }, method: 'get'
});

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

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

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

export const reqGetStudentByLikename = (username) => requests({
   url: `/likeServlet`, params: {
      username:username,
   	  password:password,
       //........
   }, method: 'get'
});

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 });

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

npm install qs --save-dev

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

import qs from 'qs'

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

let data = qs.stringify({
        username: "游坦之",
        password: "20221114"
})

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

可以追溯到上面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 });

在使用接口的地方,直接使用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);
    }
}

4.2.2 模块一:获取参数

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

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();

4.2.4 模块三:反馈参数

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

 if (user) {
   sqlSession.commit();
   String json = JSON.toJSONString(user);
   System.out.println(json);
   out.write(json)
 }else{}

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

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(“”)也应该是通过这种形式实现的。

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/405665.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【微信小程序】选择器组件picker

文章目录【微信小程序】选择器组件pickerpicker组件的定义picker组件的类型picker属性共同的属性时间选择器time参考【微信小程序】选择器组件picker picker组件的定义 picker组件是一种从底部向上弹起的滚动选择器。 picker组件的类型 在官方文档中,有提供五种…

【uni-app系列】uni-app之nvue使用

目录一、介绍二、新建 nvue 页面三、开发四、nvue 开发与 vue 开发的常见区别一、介绍 uni-app App 端内置了一个基于 weex 改进的原生渲染引擎,提供了原生渲染能力。 在 App 端,如果使用 vue 页面,则使用 webview 渲染;如果使用…

无界(wujie)微前端实现及三种通信方式介绍

一、对比 之前介绍过前段时间比较流行的微前端框架qiankun,虽然实现了微前端的理念,但是也暴露出很多缺点,比如官网上讲到的四点: 基于路由匹配,无法同时激活多个子应用,也不支持子应用保活改造成本较大&…

echarts:饼图标签formatter的使用/饼图自定义标签

需求描述 需要实现一个“五彩斑斓”的饼图:每块饼上的标签颜色与这块饼的颜色一致。 实现思路 要改变饼图标签的颜色,需要参考echarts饼图label配置项,以及这个很棒的官方示例:饼图引导线调整。从这个示例中可以了解到自定义标…

【Vue路由守卫】

Vue路由守卫Vue路由守卫全局路由守卫全局前置守卫全局后置守卫实例代码:独享守卫组件内守卫总结Vue路由守卫 路由守卫,简单理解来说就是,当用户要进行一些操作时,我需要用户的一些信息或数据或行为,我判断过后&#x…

【1024用代码改变世界】useMemo 和 useCallback|React.memo使用场景

欢迎来到我的博客 📔博主是一名大学在读本科生,主要学习方向是前端。 🍭目前已经更新了【Vue】、【React–从基础到实战】、【TypeScript】等等系列专栏 🛠目前正在学习的是🔥React/小程序React/小程序React/小程序&am…

【HTML+CSS】实现网页的导航栏和下拉菜单

熟练的使用导航栏,对于任何网站都非常重要,我们可以使用CSS转换为好看的导航栏而不是枯燥的HTML菜单。同时,我们使用 CSS 可以创建一个鼠标移动上去后显示下拉菜单的效果。 水平导航栏: 垂直导航栏: 文章目录 一.CSS导航栏1. HTML设置菜单项2. 垂直导航栏3. 水平导航栏3…

卸载,重新安装node

因为我的node版本比较低,需要换成高一点的版本,所以需要先卸载 卸载node 直接点卸载就可以了 重新安装 node下载网站:下载 | Node.js 中文网http://nodejs.cn/download/ 1 选择符合自己电脑的node(下载的的长期支持版本-这个比较稳定) 2 选择自己要安装的路径(最好自己选一…

前端练手3D爱心

文章目录盒子模型常用属性(认识)效果一 爱心半边效果二 爱心整合生成效果三 实现立方体爱心最终效果 3D爱心盒子模型常用属性(认识) overflow: hidden;定义盒子不随浮动 margin-left: 50px:使盒子距离外边距左(右上下)50px margin…

前端面试宝典~Symbol、相同的Set、Getter、控制动画、js中哪些操作会造成内存泄漏?等......

前端JavaScript面试题🍓🍓Symbol🍓🍓相同的Set🍓🍓Getter🍓🍓控制动画🍓🍓js中哪些操作会造成内存泄漏?html页面的骨架,相当于人的骨头&#xff…

vscode下载和安装教程和配置中文插件(超详细)

前言必读 读者手册(必读)_云边的快乐猫的博客-CSDN博客 前言: vscode主要是用于前端的编程工具,其他编程的语言也可以在vscode里面编程运行。 优点:简洁、占用内存小、界面美观 一、下载步骤 1.到官网根据自己的操…

vue里面使用pdfjs-dist+fabric实现pdf电子签章!!!

2022.9.6 一、需求 最近领导提了一个新需求:仿照e签宝,实现pdf电子签章! 最终实现效果图 这是做出来的效果图,当然还有很多待修改 二、思路 然后我就去看了下人家e签宝的操作界面,左侧是印章,右侧是…

Vue 原理整理

目录 1. 组件化基础>(MVVM模型) 2. Vue的响应式原理 3.为什么在 Vue3.0 采用了 Proxy,抛弃了 Object.defineProperty? 4.computed 的实现原理 5. computed 和 watch 有什么区别及运用场景? 6. Vue 中的 key 到底有什么用&#xff…

VUE中watch的详细使用教程

1、watch是什么? watch:是vue中常用的侦听器(监听器),用来监听数据的变化 2、watch的使用方式如下 watch: { 这里写你在data中定义的变量名或别处方法名: { handler(数据改变后新的值, 数据改变之前旧的值) { 这里写你拿到变化值后…

uniApp实现热更新

热更新 热更新是开发中常见且常用的一种软件版本控制的方式,在uniapp进行使用热更新将软件实现更新操作 思路: 服务器中存储着最新版本号,前端进行查询可以在首次进入应用时进行请求版本号进行一个匹对如果版本号一致则不提示,反之则提示进行…

Layui的layer.confirm弹框用法,很详细

Layui的弹框用法一、官网示例二、自定义一些样式1、自定义标题2、给提示框内容加上图标3、定义按钮的位置4、自定义关闭按钮5、自定义遮罩6、自定义点击弹框外遮罩关闭弹框7、定义唯一弹框8、自定义弹框出场动画9、关闭弹框动画10、设置弹框可以最大或者最小化11、设置弹框固定…

前端react axios 发送post请求fastapi响应报错422 (Unprocessable Entity)

post请求fastapi响应报错:422 (Unprocessable Entity) 最近在学习和使用fastapi的时候遇到了一个问题,就是发送了post请求后服务器端回应:422 (Unprocessable Entity), 具体含义: HTTP 422 状态码表示服务器理解请求实体的内容类型,并且请求实体的语法是正确的&am…

CSS盒子居中的6种方法!

大家好, 我是菜鸟,今天给大家带来几种css盒子居中的方法! 1.flex布局设置居中 常见的一种方式就是使用flex布局设置居中。 利用弹性布局(flex),实现水平居中,其中justify-content 用于设置弹性盒子元素在主轴(横轴)方向上的对…

如何成功安装webpack

按照B站里的视频总是报错,于是去CSDN里尝试了多种方法,也不知道是哪种方法有效了,叠加了多种方法,都记下来。 做换行变色的例子时不会变色。因为jQuery包属于es6语法,并不是所有浏览器都能支持es6语法。因此&#xff0…

resetFields重置初始值不生效的原因

问题 最近在做项目的时候, dialog组件回调close里面 一般我都会加个resetFields 重置初始值和校验 其他地方都没问题, 在table组件里面出问题了, 后来经过监听vue tools, 查看到resetFields后, formData没变, 最后也找到原因了. 解决 1、用 dialog【新增】、【修改】数据 2、…