位置: IT常识 - 正文

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

编辑:rootadmin
一文弄懂Vue与Servlet的交互:让你的大学课设变得容易起来 文章目录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 写作动机

推荐整理分享一文弄懂Vue与Servlet的交互:让你的大学课设变得容易起来(vue区别),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vue区别,vue区别,vue和vuejs,vue和servlet,vue和ssm,vue和vuejs,vue和ssm,vue和ssm,内容如对您有帮助,希望把文章链接给更多的朋友!

目前较为流行的套装是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 仿照网站栏撰写

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

比如我想访问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'一文弄懂Vue与Servlet的交互:让你的大学课设变得容易起来(vue区别)

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

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

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

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

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

3.2.2 按照Params格式传参

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

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

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

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

然后便可正常发送成功!

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{}

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

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

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

本文链接地址:https://www.jiuchutong.com/zhishi/299330.html 转载请保留说明!

上一篇:英雄联盟轮播图手动轮播(英雄联盟轮转模式2020时间表)

下一篇:uniapp中uni.navigateTo传递变量

  • 原来QQ群可以这样玩?可以被动去吸粉?(qq群可以随便进吗)

    原来QQ群可以这样玩?可以被动去吸粉?(qq群可以随便进吗)

  • 荣耀x10如何隐藏应用(荣耀x10如何隐藏桌面图标)

    荣耀x10如何隐藏应用(荣耀x10如何隐藏桌面图标)

  • 小米mix2s前摄像头失效(小米mix2s前摄像头更换视频教程)

    小米mix2s前摄像头失效(小米mix2s前摄像头更换视频教程)

  • QQ怎么用电脑录像(qq怎么电脑录屏幕视频)

    QQ怎么用电脑录像(qq怎么电脑录屏幕视频)

  • 笔记本安装内存4g是什么意思(笔记本安装内存条需要注意什么问题)

    笔记本安装内存4g是什么意思(笔记本安装内存条需要注意什么问题)

  • 关机键变成siri怎么取消(关机键变成音量键)

    关机键变成siri怎么取消(关机键变成音量键)

  • 手机杂志锁怎么关闭(手机杂志锁屏是什么意思)

    手机杂志锁怎么关闭(手机杂志锁屏是什么意思)

  • 微信授权是什么意思(微信授权管理是啥意思)

    微信授权是什么意思(微信授权管理是啥意思)

  • ios14.1更新了什么(ios14更新了什么功能)

    ios14.1更新了什么(ios14更新了什么功能)

  • 屏幕有黄斑是什么原因(屏幕出黄斑)

    屏幕有黄斑是什么原因(屏幕出黄斑)

  • 照片最近删除在哪(照片最近删除在哪里开启)

    照片最近删除在哪(照片最近删除在哪里开启)

  • 路由器不通电怎么回事(路由器不通电怎么办)

    路由器不通电怎么回事(路由器不通电怎么办)

  • 商品id是什么意思啊(商品id是商品编码吗)

    商品id是什么意思啊(商品id是商品编码吗)

  • 打电话没有提示音就挂了(为什么手机关机了打电话没有提示)

    打电话没有提示音就挂了(为什么手机关机了打电话没有提示)

  • 电源适配器坏了的现象(如何判断电源适配器坏了)

    电源适配器坏了的现象(如何判断电源适配器坏了)

  • qq打卡什么时候开始的(qq打卡什么时候可以打卡)

    qq打卡什么时候开始的(qq打卡什么时候可以打卡)

  • 手机怎么连接电脑宽带(手机怎么连接电脑传输照片与文件)

    手机怎么连接电脑宽带(手机怎么连接电脑传输照片与文件)

  • 红米note7pro什么时候更新MIUI11(红米note7pro值得入手吗?)

    红米note7pro什么时候更新MIUI11(红米note7pro值得入手吗?)

  • 华为荣耀9x指纹识别在哪里(华为荣耀9x指纹设置不见了)

    华为荣耀9x指纹识别在哪里(华为荣耀9x指纹设置不见了)

  • word格式选项卡在哪里(word文件形式怎么弄)

    word格式选项卡在哪里(word文件形式怎么弄)

  • 苹果6s扩容有什么影响(苹果6s扩容有什么用)

    苹果6s扩容有什么影响(苹果6s扩容有什么用)

  • 云课堂签到有定位吗(云课堂学生怎么样正常签到)

    云课堂签到有定位吗(云课堂学生怎么样正常签到)

  • 想打匿名电话怎么打(打匿名电话怎样查不出号码)

    想打匿名电话怎么打(打匿名电话怎样查不出号码)

  • 息屏挂机是什么意思

    息屏挂机是什么意思

  • 苹果max怎么关机(苹果max关机在哪里)

    苹果max怎么关机(苹果max关机在哪里)

  • 怎么把时间和天气设置到桌面(怎么把时间和天气设置到主屏幕上)

    怎么把时间和天气设置到桌面(怎么把时间和天气设置到主屏幕上)

  • reader_sl.exe - reader_sl进程有什么用.

    reader_sl.exe - reader_sl进程有什么用.

  • 微软 Win11 安卓子系统成功安装上 Google Play 服务和商店(w11系统安卓)

    微软 Win11 安卓子系统成功安装上 Google Play 服务和商店(w11系统安卓)

  • hpzstatn.exe是什么进程 有什么作用 hpzstatn进程查询(hp是什么软件)

    hpzstatn.exe是什么进程 有什么作用 hpzstatn进程查询(hp是什么软件)

  • mtask.exe - mtask是什么进程 有什么用

    mtask.exe - mtask是什么进程 有什么用

  • 企业并购需要交什么税
  • 发票二维码只有一半可以收吗
  • 辅导期增值税一般纳税人申报材料
  • 耕地转让权是什么意思
  • 资产负债表中存货项目金额怎么算
  • 进项税额转出要补所得税吗
  • 咨询费成本怎么成本结转
  • 去年的原材料发票能入账吗
  • 银行承兑汇票到期日期怎么算
  • 软件开发的服务内容方式要求
  • 资本公积与实收资本和盈余公积有什么区别?
  • 个人交物业费开发票交税点吗
  • 固定资产折旧计入成本还是费用
  • 当月工资补扣个税吗
  • 电子发票已缴税怎么查
  • 增值税发票备注栏怎么填写
  • 非现金资产包括
  • 在建工程产生废料收入的账务处理?
  • 土地使用税和房产税
  • windows更新显示
  • 建筑公司小规模纳税人怎么做账报税
  • 增值税发票半年后能冲红
  • 对公账户转私人账户有限额吗
  • 弃置费用的会计核算
  • php读取目录
  • 长期借款利息的会计科目
  • Waterfalls at the source of the Mundo River, Sierra de Riopar, Albacete, Spain (© Westend61/Getty Images)
  • windows安装无法继续,若要安装请重新启动
  • 私营独资企业的税收规定
  • 利润表里的所得税费用怎么算出来的
  • 金融企业呆账核销管理办法
  • php语言采用什么方式执行
  • 免税是政府补助吗
  • 软考备考时间
  • vue前端项目实战
  • 发票取得取得售卡方公司开具的增值税专用发票
  • 帝国cms使用手册
  • 帝国cms8.0
  • 旅行社怎样进行营销
  • 增值税出口税
  • 留购价计入什么费
  • 什么是资产减值准备计提
  • 预收账款转收入可以调以前年度吗
  • 一般人财务报表季报还是月报
  • 出租的厂房折旧记哪里
  • sql2008r2如何使用
  • 税控盘的进项税在哪里申报
  • 土地使用权转让法律规定
  • 外商投资有限合伙企业
  • 增值税退税是否算主营业务收入
  • 加班打车费用计入什么科目
  • 实际收到货款分录
  • 其他应收款内部往来
  • 财务报表的一般构成要素
  • 上月有留底税额时本月缴纳税款时怎么做分录
  • 2020年专项扣除怎么填
  • 将外购商品用于赠送客户
  • 百旺金赋领回来的发票怎么读入
  • 机械租赁怎么开9个点
  • 在sql server数据库中
  • ubuntu mysql 5.6版本的删除/安装/编码配置文件配置
  • MySql 5.6.36 64位绿色版安装图文教程
  • window怎么操作
  • gdiwindow是什么
  • win7访问共享文件
  • win7系统修改
  • mac系统如何安装双系统
  • 深入linux内核架构与底层原理 pdf
  • javascript 数组
  • jquery prevall
  • css中hack
  • unity编译原理
  • shell中的括号
  • Android ListViewitem滑动出现删除按钮
  • unity人物换肤用什么方法
  • 安卓的生命周期方法
  • 按时交纳党费
  • 地税局热线电话是多少
  • 建筑业发票范围
  • 办税服务厅是税收工作的
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设