Get和Post请求和对应的参数获取

1.get和post的请求方式

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>vue的异步请求</title><script src="js/vue.js"></script><!--vue单独抽取的插件--><script src="js/axios-0.18.0.js"></script>
</head>
<body>
<div id="div"><input type="button" value="发送get请求方式1" @click="doGet1()"><input type="button" value="发送get请求方式2" @click="doGet2()"><input type="button" value="发送post请求方式1" @click="doPost1()"><input type="button" value="发送post请求方式2" @click="doPost2()">
</div>
<script>new Vue({el: "#div",data: {user: {username: "rose",password: 123}},methods: {// <input type="button" value="发送get请求方式1" @click="doGet1()">doGet1() {axios.get("ajaxServlet?username=jack&password=123456").then((resp) => {//resp响应对象,通过resp响应对象可以获取响应结果console.log(resp);//{data: "ok ,response successful...", status: 200, statusText: "", headers: {…}, config: {…}, …}//通过对象的属性data获取值(响应结果)console.log(resp.data);}).catch((error) => {//信息红色字体展示console.error(error);})},// <input type="button" value="发送get请求方式2" @click="doGet2()">doGet2() {//传参较多时使用对象封装,方便书写和阅读axios.get("ajaxServlet", {params: this.user}).then((resp) => {console.log(resp);//获取响应回来的数据console.log(resp.data);}).catch((error) => {//信息红色字体展示console.error(error);})},// <input type="button" value="发送post请求方式1" @click="doPost1()">doPost1() {axios.post("ajaxServlet", "username=jack&password=123456").then((resp) => {console.log(resp);//获取响应回来的数据console.log(resp.data);}).catch((error) => {//信息红色字体展示console.error(error);})},// <input type="button" value="发送post请求方式2" @click="doPost2()">doPost2() {//传参较多时使用对象封装,方便书写和阅读,传入的参数是json格式,对应的servlet需要用对应的方法axios.post("ajaxServlet", this.user).then((resp) => {console.log(resp);//获取响应回来的数据console.log(resp.data);}).catch((error) => {//信息红色字体展示console.error(error);})}}});
</script>
</body>
</html>

2.处理doGet1和doGet2以及doPost1

  • 方式1[req请求对象根据传递的key获取值]
    • request.getParameter(“key”)方式
 //1 获取请求参数String username = request.getParameter("username");String password = request.getParameter("password");//2 打印请求参数System.out.println("username = " + username);System.out.println("password = " + password);//3 响应结果response.getWriter().write("ok ,response successful...");打印结果:
------------------------------------------------------------------------------------
doGet1请求:
username = jack
password = 123456
界面Response:ok ,response successful...doGet2请求:
username = rose
password = 123
界面Response:ok ,response successful...doPost1请求:
username = jack
password = 123456
界面Response:ok ,response successful...
  • 方式2[使用BeanUtils封装多个参数]
    /**
    • 封装请求参数到javabean中,请求参数的格式为name=value&name=value
    • @param request 表单中的数据
    • @param clazz 封装到哪个javabean
    • @return 封装好的javabean对象
    • 使用的是泛型。泛型必须先声明再使用。声明必须在返回值之前
    • T指的就是泛型,它可以是任意字符,只是作为一个占位符。
    • 声明时用什么字符,使用时就得用什么
      */
//1.创建封装实例化对象User user = new User();try {//采用工具类封装方法BeanUtils.populate(user,request.getParameterMap());//打印请求参数System.out.println("username = " + user.getUsername());System.out.println("password = " + user.getPassword());} catch (Exception e) {e.printStackTrace();}//3 响应结果response.getWriter().write("ok ,response successful...");打印结果:
------------------------------------------------------------------------------------
doGet1请求:
username = jack
password = 123456
界面Response:ok ,response successful...doGet2请求:
username = rose
password = 123
界面Response:ok ,response successful...doPost1请求:
username = jack
password = 123456
界面Response:ok ,response successful...

注:BeanUtils.populate无法封装请求中带有数组的参数

BeanUtils工具类的依赖及**[jar包下载]**

<!--beanutils--><dependency><groupId>commons-beanutils</groupId><artifactId>commons-beanutils</artifactId><version>1.9.4</version></dependency>

3.处理doPost2

方式:使用 JSON转换工具[jackson]

        //1 获取请求参数ObjectMapper objectMapper=new ObjectMapper();//可以封装客户端发送过来的json数据[将json封装成对象]User user=objectMapper.readValue(request.getReader(),User.class);//2 打印请求参数System.out.println(user);//3 响应json[将对象转换为json]objectMapper.writeValue(response.getWriter(),user);打印结果:
------------------------------------------------------------------------------------
doPost2请求:
User{username='rose', password='123'}
界面Response:{"username":"rose","password":"123"}

注:jackson只能解析post请求参数类型为对象
jackson相关依赖或**jar包下载:**

<!--jackson--><dependency><groupId>com.fasterxml.jackson.core</groupId><artifactId>jackson-databind</artifactId><version>2.9.8</version></dependency>

4.请求示例

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>表单绑定</title></head>
<body><div id="div"><!--需求2:展示填写或者选中的内容--><div>输入的姓名是:{{user.username}}</div><div>输入的年龄是:{{user.age}}</div><div>选择的性别是:{{user.gender}}</div><div>选择的爱好是:{{user.hobbies}}</div><hr/><form><!--需求1:将表单和vue进行双向数据绑定-->姓名:<input type="text" name="username" v-model="user.username"><br>年龄:<input type="number" name="age" v-model="user.age"><br>性别:<input type="radio" name="gender" v-model="user.gender" value="man"><input type="radio" name="gender" v-model="user.gender" value="woman"><br>爱好:<input type="checkbox" name="hobbies" v-model="user.hobbies" value="1"><input type="checkbox" name="hobbies" v-model="user.hobbies" value="2"><input type="checkbox" name="hobbies" v-model="user.hobbies" value="3">rap<input type="checkbox" name="hobbies" v-model="user.hobbies" value="4">篮球<br><!--需求3:点击按钮,通过ajax把表单数据发送给服务器--><!--<input type="button" value="提交信息" v-on:click="sendData()">--><input type="button" value="提交信息" @click="sendData()"></form></div>
</body>
<script src="js/vue.js"></script>
<script src="js/axios-0.18.0.js"></script>
<script>new Vue({el:"#div", //表示vue接管的区域,在这一片区域内才可以使用vue的语法处理数据data:{  //定义变量等数据,这些变量的值将来会在展示到页面上user:{username:"张益达",age:20,gender:"man",hobbies:[]}},methods:{  //定义vue中的方法,将来使用vue的事件绑定需要使用这里面定义的方法。sendData(){/*要访问的路径:http://localhost:8080/vue_830/userServlet当前页面的路径:http://localhost:8080/vue_830/v_model.html*///发送异步GET请求,传递参数//axios.get("./userServlet",{params:this.user}).then(resp=>{})  //对/*axios.get("userServlet",{params:this.user}).then(resp=>{console.log(resp);  //响应对象:包括响应结果和响应码等数据console.log(resp.data);})*/axios.post("userServlet",this.user).then(resp=>{console.log(resp);  //响应对象:包括响应结果和响应码等数据console.log(resp.data);})}}});
</script>
</html>

响应方式 不能采用BeanUtils,因为参数中有数组;顾所以采用JSON,所以请求方式采用post

Servlet代码:

@WebServlet("/userServlet")
public class UserServlet extends HttpServlet {@Overrideprotected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {ObjectMapper objectMapper=new ObjectMapper();request.setCharacterEncoding("utf-8");response.setContentType("application/json;charset=utf-8");//get请求接收请求参数//1 接收请求参数并封装/* User user=new User();Map<String, String[]> parameterMap = request.getParameterMap();try {BeanUtils.populate(user,parameterMap);  //无法封装数组} catch (Exception e) {e.printStackTrace();}*///1 post请求接收请求参数User user = objectMapper.readValue(request.getReader(), User.class);//2 打印结果System.out.println(user);//3 响应jsonobjectMapper.writeValue(response.getWriter(),user);}@Overrideprotected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {doGet(request, response);}
}打印结果:
------------------------------------------------------------------------------
User{username='张益达', age=20, gender='man', hobbies=[1, 2]}
界面Response:{"username":"张益达","age":20,"gender":"man","hobbies":["1","2"]}

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

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

相关文章

阿里巴巴对Java编程【安全规约】的规约

转载自 阿里巴巴对Java编程【安全规约】的规约 安全规约 1. 【强制】隶属于用户个人的页面或者功能必须进行权限控制校验。 说明&#xff1a;防止没有做水平权限校验就可随意访问、修改、删除别人的数据&#xff0c;比如查看他人的私信内容、修改他人的订单。 2. 【强制】用户敏…

JSON转换工具---jackson

1.json传递中和javaBean对象的关系 打印出来的字符串&#xff0c;对象和键值集合用{}, 数组和用[] 2.json的转换 总测试类:以下转换都为单元测试方法 public class ObjectMapperTest {private ObjectMapper mapper new ObjectMapper(); }<1>json和对象的转换 /*1.Use…

df、du和fdisk命令的区别

【1】df 列出文件系统的整体磁盘使用量由于 df 主要读取的数据几乎都是针对一整个文件系统&#xff0c;因此读取的范围主要是在 Superblock 内的信息&#xff0c; 所以这个命令显示结果的速度非常的快速&#xff01;&#xff08;1&#xff09;&#xff08;2&#xff09;补充&am…

阿里巴巴对Java编程【Mysql】的规约

转载自 阿里巴巴对Java编程【Mysql】的规约 建表规约 1. 【强制】表达是与否概念的字段&#xff0c;必须使用 is _ xxx 的方式命名&#xff0c;数据类型是 unsigned tinyint&#xff08; 1 表示是&#xff0c;0 表示否 &#xff09; 。 说明&#xff1a;任何字段如果为非负数&a…

applicationContext配置mybatis

1.引入外部的properties属性文件 <?xml version"1.0" encoding"UTF-8"?> <beans xmlns"http://www.springframework.org/schema/beans"xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xmlns:context"http://w…

linux-basic(8)linux磁盘与文件系统管理

【8.1】认识EXT2文件系统【补充】硬盘与存储设备 https://blog.csdn.net/pacosonswjtu/article/details/79811762&#xff08;1&#xff09;实际的数据都是写在具有磁性物质的磁碟盘上头&#xff0c;而读写主要是透过在机械手臂上的读取头(head)来达成。 实际运作时&#xff0c…

阿里巴巴对Java编程【应用结构】的规约

转载自 阿里巴巴对Java编程【应用结构】的规约 应用分层 1. 【推荐】图中默认上层依赖于下层&#xff0c;箭头关系表示可直接依赖&#xff0c;如&#xff1a;开放接口层可以依赖于Web 层&#xff0c;也可以直接依赖于 Service 层&#xff0c;依此类推&#xff1a;  开放接口…

spring注解注入IOC

1.创建Bean对象的注解 <1>配置自定义Bean对象注解 Component、Controller、Service、repository 用法&#xff1a;写在类上&#xff0c; 例如&#xff1a;Service 或者 Service(“userService”) 作用&#xff1a;将该类交给Spring创建对象保存到Spring容器中&#xff…

jstack命令:教你如何排查多线程问题

转载自 jstack命令&#xff1a;教你如何排查多线程问题这是之前的一个死锁案例&#xff1a;一个多线程死锁案例&#xff0c;如何避免及解决死锁问题&#xff1f;如程序中发生这样的死锁问题该如何排查呢&#xff1f;我们可以使用java自带的jstack命令进行排查。1、先在服务器运…

linux-basic(9)文件与文件系统的压缩与打包

【9.1】压缩文件的用途与技术【9.2】linux系统常见的压缩命令1&#xff09;压缩文件的扩展名大多是 tar, tar.gz, tgz, gz, Z, bz2 等&#xff1b;如下图所示&#xff1a;&#xff08;1&#xff09;Linux上常见的压缩命令就是 gzip 与 bzip2 &#xff0c;至於 compress 已经不再…

纯注解开发配置spring

1.纯注解开发【定义配置类的注解】 Confituration 表示该类是一个配置类 ComponentScan(“com.itheima”) 配置包扫描 PropertySource(“classpath:jdbc.properties”) 加载属性文件 Import(JdbcConfig.class) 加载其他配置类 2.spring整合mybatis【纯注解&#xff0c;3个…

阿里巴巴对Java编程【命名风格】的规约

转载自 阿里巴巴对Java编程【命名风格】的规约 命名风格 1. 【强制】代码中的命名均不能以下划线或美元符号开始&#xff0c;也不能以下划线或美元符号结束。 反例&#xff1a; _name / __name / $Object / name_ / name$ / Object$ 2. 【强制】代码中的命名严禁使用拼音与英文…

linux-basic(10)vim程序编辑器

【10.1】vi 与 vim【10.2】vi的使用1&#xff09;3种模式&#xff1a;模式1&#xff1a;一般模式&#xff0c; vim打开就是这种模式&#xff0c;编辑模式下 按 esc 回到一般模式&#xff1b;模式2&#xff1a;编辑模式&#xff0c;要等到你按下『i, I, o, O, a, A, r, R』等任何…

阿里巴巴对Java编程【代码格式】的规约

转载自 阿里巴巴对Java编程【代码格式】的规约 代码格式 1. 【强制】大括号的使用约定。如果是大括号内为空&#xff0c;则简洁地写成{}即可&#xff0c;不需要换行 &#xff1b; 如果是非空代码块则&#xff1a; 1 &#xff09; 左大括号前不换行。 2 &#xff09; 左大括号后…

自定义通配器导入bean对象

1.CustomerImportSelector工具类&#xff1a; /*** description : 自动导入器* author : wanYunBo* date : 2021-09-02 20:46**/ package com.itheima.config.selector;import org.springframework.context.annotation.ClassPathScanningCandidateComponentProvider; import o…

linux-basic(11)认识和学习bash

【11.1】认识bash这个shell1&#xff09;介绍&#xff1a;其实壳程序的功能只是提供用户操作系统的一个接口&#xff0c;因此这个壳程序需要可以呼叫其他软件才好。命令&#xff0c;包括 man, chmod, chown, vi, fdisk, mkfs 等等命令&#xff0c;这些命令都是独立的应用程序&a…

阿里巴巴对Java编程【常量定义】的规约

转载自 阿里巴巴对Java编程【常量定义】的规约 常量定义 1. 【强制】不允许任何魔法值 &#xff08; 即未经定义的常量 &#xff09; 直接出现在代码中。 反例&#xff1a; String key " Id # taobao _" tradeId; cache . put(key , value); 2. 【强制】 long 或…

动态代理-AOP

1 什么是AOP&#xff1f; Aspect Oriented Programming的缩写&#xff0c;面向切面编程&#xff0c;切面指定就是动态代理的方法&#xff0c;作用是在不改变业务层方法源代码的基础上对方法进行增强&#xff0c;底层使用的是动态代理技术&#xff0c;面向切面编程也可以理解成…

linux-basic(12)正则表达式与文件格式化处理

【12.1.1】什么是正则表达式&#xff1f; 1&#xff09;简单说&#xff1a;正则表示法就是处理字串的方法&#xff0c;他是以行为单位来进行字串的处理行为&#xff0c; 正则表达式透过一些特殊符号的辅助&#xff0c;可以让使用者轻易的达到查找、删除、替换某特定字串的处理程…

阿里巴巴对Java编程【OOP规约】的规约

转载自 阿里巴巴对Java编程【OOP规约】的规约 OOP规约 1. 【强制】避免通过一个类的对象引用访问此类的静态变量或静态方法&#xff0c;无谓增加编译器解析成本&#xff0c;直接用类名来访问即可。 2. 【强制】所有的覆写方法&#xff0c;必须加 Override 注解。 说明&#xff…