web后端开发--请求响应

目录

前言

请求

简单参数

原始方法

Spring方式

Post请求乱码处理

实体参数

简单实体参数

复杂实体参数

​编辑

数组集合参数

数组参数

​编辑

集合参数

日期参数

​编辑

Json参数

​编辑

传递json数据

json数组

json对象(POJO)

json集合(POJO)

注意

路径参数

请求映射路径

@RequestMapping

请求参数

响应

@ResponseBody

统一响应结果


前言

请求:获取请求数据

响应:设置响应数据

BS架构 Browser/Server,浏览器/服务器架构模式,客户端只需要浏览器,应用程序的逻辑和数据都存储在服务端(维护方便,体验一般

CS架构 Client/Server,客户端/服务器架构模式(开发维护麻烦,体验不错

请求

简单参数

原始方法

通过HttpServletRequest手动获取

import jakarta.servlet.http.HttpServletRequest;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;@RestController
public class RequestController {@RequestMapping("/SimpleParam")public String SimpleParam(HttpServletRequest request){  //返回的字符串类型是StringString name=request.getParameter("name");String age=request.getParameter("age");  //通过这个方法得到字符串类型的int age1=Integer.parseInt(age);  //将年龄进行类型转换System.out.println(name+":"+age1);  //设置返回格式return "OK";}
}

Spring方式

简单参数:参数名与形参变量名相同,定义形参即接收参数

@RestController
public class RequestController {@RequestMapping("/SimpleParam")public String SimpleParam(String name,Integer age){System.out.println(name+":"+age);return "OK";}
}

注意这里的postman的网址均为http://localhost:8080/SimpleParam?name=tom&age=10

以上两种均为get请求,当为post请求时只需要在postman中网址输入http://localhost:8080/SimpleParam

Post请求乱码处理

如果post里面有汉字传进去,后台会出现乱码所以在配置那里设置过滤器

为web容器添加过滤器并指定字符集,Spring-web包中提供了专用的字符过滤器

public class ServletContainersInitConfig extends AbstractAnnotationConfigDispatcherServletInitializer {protected Class<?>[] getRootConfigClasses() {return new Class[0];}
​protected Class<?>[] getServletConfigClasses() {return new Class[]{SpringMvcConfig.class};}
​protected String[] getServletMappings() {return new String[]{"/"};}//乱码处理@Overrideprotected Filter[] getServletFilters() {CharacterEncodingFilter filter = new CharacterEncodingFilter();filter.setEncoding("UTF-8");return new Filter[]{filter};//如果有多个过滤器,在这里用,隔开}
}

注意这个处理的是post的,如果get传入中文依旧会出现乱码

如果方法形参名称与请求参数名称不匹配,可以使用@RequestParam完成映射

@RestController
public class RequestController {@RequestMapping("/SimpleParam")public String SimpleParam(@RequestParam(name="name") String username, Integer age){  //引号中写的是请求参数名System.out.println(username+":"+age);return "OK";}
}

@PequestParam中的required属性默认为true,代表该请求参数必须传递,如果不传递,将会报错,如果该参数是可选的(也就是可以传递可以不传递),可以将required属性设置为false(这样你传或者不传都不会报错)

实体参数

简单实体参数

请求参数名与形参属性名相同,定义Pojo接收即可

@RestController
public class SimplePojo {@RequestMapping("/SimpleParam1")public String SimplePojo(user user) {System.out.println(user);return "yes";}
}
public class user {private String name;private Integer age;
//加getter和setter方法toString
} 

这里的url是http://localhost:8080/SimpleParam1?name=cat&age=29

复杂实体参数

请求参数名与形参属性名相同,按照对象层次结构关系即可接收嵌套pojo属性参数

public class user {private String name;private Integer age;
private Address address;
//加getter和setter和toString
}
public class Address {private String province;private String city;
//加getter和setter还有toString
}
@RestController
public class SimplePojo {@RequestMapping("/ComplexParam1")public String ComplexParam(user user) {System.out.println(user);return "yes";}
}

数组集合参数

数组参数

请求参数名与形参数组名称相同且请求为多个,定义数组类型形参即可接收参数

@RestController
public class SimplePojo {@RequestMapping("/arrayParam")public String ArrayParam(String[] hobby) {//在这里建立一个数组,然后后面的名称和传入参数相同System.out.println(Arrays.toString(hobby));return "yes";}
}

集合参数

请求参数名与形参集合名称相同且请求参数为多个@RequestParam绑定参数关系

@RestController
public class SimplePojo {@RequestMapping("/listParam")public String ArrayParam(@RequestParam List<String> hobby) {System.out.println(hobby);return "yes";}
}

日期参数

使用@DateTimeFormat注解完成日期参数格式转换

@RestController
public class SimplePojo {@RequestMapping("/dateParam")public String dateParam(@DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")LocalDateTime updateTime) {System.out.println(updateTime);return "yes";}
}

//日期参数    
//使用@DateTimeFormat注解设置日期类型数据格式,默认格式yyyy/MM/dd   @RequestMapping("/dataParam")    
@ResponseBody    
public String dataParam(Date date,@DateTimeFormat(pattern="yyyy-MM-dd") Date date1, @DateTimeFormat(pattern="yyyy/MM/dd HH:mm:ss") Date date2){        
System.out.println("参数传递 date ==> "+date);        
System.out.println("参数传递 date1(yyyy-MM-dd) ==> "+date1);        
System.out.println("参数传递 date2(yyyy/MM/dd HH:mm:ss) ==> "+date2);        
return "{'module':'data param'}";    }
}
//@DateTimeFormat是形参注解,用在SpringMVC控制器方法形参前面,用于设定日期时间型数据格式//属性:pattern:日期时间格式字符串

Get测试:

http://localhost:8080/springmvc_04_request_param/dataParam?date=2088/08/08&date1=2088-08-18&date2=2088/08/28 8:08:08

Json参数

json参数键名与形参对象属性名相同,定义Pojo类型形参即可接收参数,需要使用@RequestBody标识

@RestController
public class SimplePojo {@RequestMapping("/jsonParam")public String jsonParam(@RequestBody user user) {System.out.println(user);return "yes";}
}
//user这和前面的复杂实体参数一样

通过@requestbody将json封装到user这个实体类之中

传递json数据

先导入坐标

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

开启自动转换Json数据的支持

@Configuration
@ComponentScan("com.itheima.controller")
//开启json数据类型自动转换
@EnableWebMvc
public class SpringMvcConfig {
}
json数组
   
//集合参数:json格式//1.开启json数据格式的自动转换,在配置类中开启@EnableWebMvc//2.使用@RequestBody注解将外部传递的json数组数据映射到形参的集合对象中作为数据
//它用来将请求体所包含的数据传递给请求参数,此注解一个处理器方法只能使用一次@RequestMapping("/listParamForJson")@ResponseBodypublic String listParamForJson(@RequestBody List<String> likes){System.out.println("list common(json)参数传递 list ==> "+likes);return "{'module':'list common for json param'}";}
json对象(POJO)
//POJO参数:json格式
//1.开启json数据格式的自动转换,在配置类中开启@EnableWebMvc
//2.使用@RequestBody注解将外部传递的json数据映射到形参的实体类对象中,要求属性名称一一对应
@RequestMapping("/pojoParamForJson")
@ResponseBody
public String pojoParamForJson(@RequestBody User user){System.out.println("pojo(json)参数传递 user ==> "+user);return "{'module':'pojo for json param'}";
}

Get请求的时候:

{"name":"xixi","age":21,"address":{"provice":"taiyuan","city":"taiyuan"}
}
json集合(POJO)
//集合参数:json格式
//1.开启json数据格式的自动转换,在配置类中开启@EnableWebMvc
//2.使用@RequestBody注解将外部传递的json数组数据映射到形参的保存实体类对象的集合对象中,要求属性名称一一对应
@RequestMapping("/listPojoParamForJson")
@ResponseBody
public String listPojoParamForJson(@RequestBody List<User> list){System.out.println("list pojo(json)参数传递 list ==> "+list);return "{'module':'list pojo for json param'}";
}

Get请求的时候:

[{"name":"xixi","age":12},
{"name":"haha","age":21}
]
注意

路径参数

通过请求url直接传递参数,使用{...}来标识该路径参数,需要使用@PathVariable获取路径参数

一个路径参数

@RestController
public class SimplePojo {@RequestMapping("/path/{id}")public String pathParam(@PathVariable Integer id) {System.out.println(id);return "yes";}
}

postman测试的url为http://localhost:8080/path/1

多个路径参数

@RestController
public class SimplePojo {@RequestMapping("/path/{id}/{name}")public String pathParam(@PathVariable Integer id ,@PathVariable String name) {System.out.println(id+":"+name);return "yes";}
}

 postman测试的url为http://localhost:8080/path/1/cat

请求映射路径

问题的提出:在开发中请求的路径应该是不同的,但是如果有相同的路径就会报错,不知道到底应该调用哪一个----------通常通过设置模块名作为请求路径的前缀

@RequestMapping

他是方法注解和类注解

放在SpringMVC控制器方法定义上方

用于设置控制器方法请求路径,如果设置在类上设置当前控制器方法,请求访问路径前缀

@Controller
//设置模块名作为请求路径的前缀
@RequestMapping("/user")
public class UserController {//请求路径映射@RequestMapping("/save")@ResponseBodypublic String save(){System.out.println("user save ...");return "{'module':'user save'}";}//请求路径映射@RequestMapping("/delete")@ResponseBodypublic String delete(){System.out.println("user delete ...");return "{'module':'user delete'}";}
​
}

属性:value(默认):请求访问路径。或者访问路径前缀

请求参数

@RequestParam是形参注解,位于SpringMVC控制器方法形参定义前面,用于绑定请求参数与处理器方法形参之间的关系

参数:required:是否为必传参数 DefaultValue:参数默认值

响应

@ResponseBody

是方法注解和类注解

位于controller方法上/类上

作用是将方法返回值直接响应,如果返回值类型是 实体对象/集合,竟会转换为JSON格式响应

@RestController=@Controller+@ResponseBody

@RestController
public class ResponseController {@RequestMapping("/hello")public String hello(){System.out.println("hello world");return "hello world~";}@RequestMapping("/getAddr")public Address getAddr(){Address addr=new Address();addr.setProvince("山西");addr.setCity("太原");return addr;}@RequestMapping("/listAddr")public List<Address> ListAddr(){List<Address> list=new ArrayList<>();Address addr=new Address();addr.setProvince("山西");addr.setCity("太原");Address addr2=new Address();addr2.setProvince("山");addr2.setCity("太");list.add(addr);list.add(addr2);return list;}
}

测试是在postman输入http://localhost:8080/listAddr即可,其他类似

每一个对外暴露的方法都称为一个功能接口(比如上面就有三个接口),路径就是他们的访问路径

面临的问题是他们的响应结果不同,最后解析结果较为麻烦,所以需要统一响应结果

统一响应结果

public class Result {private Integer code;private String msg;private Object data;
public Result(){}
public Result(Integer code,String msg,Object data){this.code=code;this.msg=msg;this.data=data;}public Integer getCode() {return code;}public void setCode(Integer code) {this.code = code;}public String getMsg() {return msg;}public void setMsg(String msg) {this.msg = msg;}public Object getData() {return data;}public void setData(Object data) {this.data = data;}public static Result success(Object data){return new Result(1,"success",data);}public static Result success(){return new Result(1,"success",null);}public static Result error(String msg){return new Result(0,msg,null);}@Overridepublic String toString() {return "Result{" +"code=" + code +", msg='" + msg + '\'' +", data=" + data +'}';}
}
@RestController
public class ResponseController {@RequestMapping("/hello")public Result hello(){System.out.println("hello world");//return new Result(1,"success","hello world");return Result.success("hello world~");//需要给前端传送数据}@RequestMapping("/getAddr")public Result getAddr(){Address addr=new Address();addr.setProvince("山西");addr.setCity("太原");return Result.success(addr);}@RequestMapping("/listAddr")public Result ListAddr(){List<Address> list=new ArrayList<>();Address addr=new Address();addr.setProvince("山西");addr.setCity("太原");Address addr2=new Address();addr2.setProvince("山");addr2.setCity("太");list.add(addr);list.add(addr2);return Result.success(list);}
}

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

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

相关文章

【Flask从入门到精通:第一课:flask的基本介绍、flask快速搭建项目并运行】

从0开始入手到上手一个新的框架&#xff0c;应该怎么展开&#xff1f;flask这种轻量级的框架与django这种的重量级框架的区别&#xff1f;针对web开发过程中&#xff0c;常见的数据库ORM的操作。跟着学习flask的过程中&#xff0c;自己去学习和了解一个新的框架&#xff08;San…

CSS【详解】长度单位 ( px,%,em,rem,vw,vh,vmin,vmax,ex,ch )

px 像素 pixel 的缩写&#xff0c;即电子屏幕上的1个点&#xff0c;以分辨率为 1024 * 768 的屏幕为例&#xff0c;即水平方向上有 1024 个点&#xff0c;垂直方向上有 768 个点&#xff0c;则 width:1024px 即表示元素的宽度撑满整个屏幕。 随屏幕分辨率不同&#xff0c;1px …

小程序问题

1.获取节点 wx.createSelectorQuery() wx.createSelectorQuery().in(this) //组件中加in(this)&#xff0c;不然获取不到 2.使用实例 wx.createSelectorQuery().in(this).select(#share).fields({node: true,size: true}).exec(async (res) > {const canvas res[0].node;…

如何将Docker镜像源更改为阿里云的镜像加速地址

在使用Docker时&#xff0c;尤其是在国内环境下&#xff0c;由于网络原因&#xff0c;从Docker Hub拉取镜像可能会遇到速度较慢的问题。为了提高拉取速度&#xff0c;我们可以将Docker的镜像源更改为阿里云等国内镜像源。下面详细介绍如何获取并配置阿里云的Docker镜像加速地址…

C++三大特征:多态

1.virtual关键字 1.1何为虚函数 virtual用于在base类中声明一个虚函数&#xff0c;[虚函数]的主要作用是[允许]在派生类&#xff08;也称为子类)中对该函数进行[重写](override) 1.2何为重写 重写就是在drived类中写一个函数(返回类型,名称,参数列表)与base类相同的函数,dr…

C++基础(二)

目录 1.类和对象 1.1类的定义 1.2访问限定符 1.3类域 2.实例化 2.1实例化概念 2.2对象大小 3.this指针 4.类的默认成员函数 4.1构造函数 4.2析构函数 4.5运算符重载 1.类和对象 1.1类的定义 类的定义格式 class为定义类的关键字&#xff0c;Stack为类的名字&…

从零开始实现大语言模型(四):简单自注意力机制

1. 前言 理解大语言模型结构的关键在于理解自注意力机制(self-attention)。自注意力机制可以判断输入文本序列中各个token与序列中所有token之间的相关性&#xff0c;并生成包含这种相关性信息的context向量。 本文介绍一种不包含训练参数的简化版自注意力机制——简单自注意…

uni-app/vue项目如何封装全局消息提示组件

效果图&#xff1a; 第一步&#xff1a;封装组件和方法&#xff0c;采用插件式注册&#xff01; 在项目目录下新建components文件夹&#xff0c;里面放两个文件&#xff0c;分别是index.vue和index.js. index.vue&#xff1a; <template><div class"toast&quo…

【Linux杂货铺】2.进程优先级

1.进程优先级基本概念 进程优先级是操作系统中用于确定进程调度顺序的一个指标。每个进程都会被分配一个优先级&#xff0c;优先级较高的进程会在调度时优先被执行。进程优先级的设定通常根据进程的重要性、紧急程度、资源需求等因素来确定。操作系统会根据进程的优先级来决定进…

nuPlan 是一个针对自动驾驶车辆的闭环机器学习(ML-based)规划基准测试

nuPlan: A closed-loop ML-based planning benchmark for autonomous vehicles nuPlan 是一个针对自动驾驶车辆的闭环机器学习&#xff08;ML-based&#xff09;规划基准测试 Abstract In this work, we propose the world’s first closed-loop ML-based planning benchmar…

【JavaScript】解决 JavaScript 语言报错:Uncaught ReferenceError: XYZ is not defined

文章目录 一、背景介绍常见场景 二、报错信息解析三、常见原因分析1. 变量未声明2. 拼写错误3. 块级作用域4. 使用未定义的函数或对象5. 代码执行顺序 四、解决方案与预防措施1. 确保变量已声明2. 检查拼写错误3. 注意块级作用域4. 定义和调用函数5. 正确的代码执行顺序 五、示…

tkinter-TinUI-xml实战(11)多功能TinUIxml编辑器

引言 在TinUIXml简易编辑器中&#xff0c;我们通过TinUI搭建了一个简易的针对TinUIXml布局的编辑器&#xff0c;基本掌握了TinUIXml布局和TinUIXml的导入与导出。现在&#xff0c;就在此基础上&#xff0c;对编辑器进行升级。 本次升级的功能&#xff1a; 更合理的xml编辑与…

Java设计模式---(创建型模式)工厂、单例、建造者、原型

目录 前言一、工厂模式&#xff08;Factory&#xff09;1.1 工厂方法模式&#xff08;Factory Method&#xff09;1.1.1 普通工厂方法模式1.1.2 多个工厂方法模式1.1.3 静态工厂方法模式 1.2 抽象工厂模式&#xff08;Abstract Factory&#xff09; 二、单例模式&#xff08;Si…

浅析Kafka-Stream消息流式处理流程及原理

以下结合案例&#xff1a;统计消息中单词出现次数&#xff0c;来测试并说明kafka消息流式处理的执行流程 Maven依赖 <dependencies><dependency><groupId>org.apache.kafka</groupId><artifactId>kafka-streams</artifactId><exclusio…

【密码学】大整数分解问题和离散对数问题

公钥密码体制的主要思想是通过一种非对称性&#xff0c;即正向计算简单&#xff0c;逆向计算复杂的加密算法设计&#xff0c;来解决安全通信。本文介绍两种在密码学领域内最为人所熟知、应用最为广泛的数学难题——大整数分解问题与离散对数问题 一、大整数分解问题 &#xf…

thinkphp 生成邀请推广二维码,保存到服务器并接口返回给前端

根据每个人生成自己的二维码图片,接口返回二维码图片地址 生成在服务器的二维码图片 控制器 public function createUserQRcode(){$uid = input(uid);if

传言称 iPhone 16 Pro 将支持 40W 快速充电和 20W MagSafe

目前&#xff0c;iPhone 15 和 iPhone 15 Pro 机型使用合适的 USB-C 电源适配器可实现高达 27W 的峰值充电速度&#xff0c;而 Apple 和授权第三方的官方 MagSafe 充电器可以高达 15W 的功率为 iPhone 15 机型进行无线充电。所有四款 iPhone 15 机型均可使用 20W 或更高功率的电…

FPGA学习笔记(一) FPGA最小系统

文章目录 前言一、FPGA最小系统总结 前言 今天学习下FPGA的最小系统一、FPGA最小系统 FPGA最小系统与STM32最小系统类似&#xff0c;由供电电源&#xff0c;时钟电路晶振&#xff0c;复位和调试接口JTAG以及FLASH配置芯片组成&#xff0c;其与STM32最大的不同之处就是必须要有…

Appium自动化测试系列: 2. 使用Appium启动APP(真机)

历史文章&#xff1a;Appium自动化测试系列: 1. Mac安装配置Appium_mac安装appium-CSDN博客 一、准备工作 1. 安卓测试机打开调试模式&#xff0c;然后使用可以传输数据的数据线连接上你的电脑。注意&#xff1a;你的数据线一定要支持传输数据&#xff0c;有的数据线只支持充…

《数据结构:C语言实现顺序表》

文章目录 一、顺序表1、静态顺序表2、动态顺序表 二、动态顺序表实现1、创建自定义类型2、完成顺序表的创建&#xff0c;测试功能需求3、完成顺序表的初始化和销毁功能4、顺序表插入数据和打印数据5、删除数据 三、顺序表完成最终的代码test.c文件中的代码&#xff1a;用来测试…