❣️关注专栏:JavaEE
Spring MVC
- ⌛️ 1. Spring MVC 创建和连接
- ⌛️ 1.1 @RequestMapping
- ⌛️ 1.2 @GetMapping
- ⌛️ 1.3 @PostMapping
- ⌛️ 2. 获取参数
- ⌛️ 2.1 传递/获取单个参数
- ⌛️ 2.2 传递/获取多个参数
- ⌛️ 2.3 传递/获取对象
- ⌛️ 2.4 参数重命名
- ⌛️ 2.4.1 设置参数必传
- ⌛️ 2.5 获取 JSON 对象
- ⌛️ 2.6 从基础URL中获取参数
- ⌛️ 2.7 获取上传的文件
- ⌛️ 2.8 获取Cookie
- ⌛️ 2.9 存储和获取 session
- ⌛️ 2.10 获取 Header
SpringMVC有三个功能:
- 连接的功能:将⽤户(浏览器)和 Java 程序连接起来,也就是当用户访问⼀个地址能够调⽤到我们的Spring 程序。
- 获取参数的功能:⽤户访问的时候会传入⼀些参数,在程序中要想办法可以获取到参数。
- 输出数据的功能:执⾏了业务逻辑之后,要把程序执⾏的结果返回给⽤户。
接下来我们来探索这 3 个功能,掌握了之后就相当于掌握了SpringMVC!!!😀
⌛️ 1. Spring MVC 创建和连接
实现连接可以有 3 种注解:@RequestMapping 、@GetMapping 和 PostMapping
⌛️ 1.1 @RequestMapping
首先创建一个控制类,实现⽤户到 Spring 程序的互联互通。
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
@RestController // 相当于把 @Controller 和 @ResponseBody 结合起来。@Controller 是让 spring 框架启动时,加载。@ResponseBody 是返回⾮⻚⾯数据
@RequestMapping("/user")
public class UserController {
@RequestMapping("/say") // 这里可以是一级路由,也可以是 N 级路由
public String sayHi(){
return "springmvc sayhi";
}
}
完成之后,当访问地址: http://localhost:8080/user/say
时就能在浏览器中打印 “springmvc sayhi” 的信息了。
👏 @RequestMapping 是 Spring Web 应⽤程序中最常被⽤到的注解之⼀,它是⽤来注册接⼝的路由映射的。也就是当用户访问一个 URL 时,将用户的请求对应到某个类的方法上。
👏 @RequestMapping 可修饰类,也可以修饰⽅法。
当修饰类和⽅法时,访问的地址是:localhost:端口号/类/⽅法。比如: http://localhost:8080/user/say
如果直接修饰的是方法,则访问的地址是:localhost:端口号/⽅法,比如: http://localhost:8080/say
👏 @RequestMapping 支持 post 请求 也支持 get 请求。
我们可以在代码中手动指定为 post 请求:
// 当@RequestMapping() 中只有一个参数,不需要加 value,当有指定方法时要加上。
@RequestMapping(value = "/say", method = RequestMethod.POST)
public String sayHi() {
return "springmvc sayhi";
}
检测是否支持 post 的请求我们使用 postman,结果如下,可以知道该注解支持 post 请求。
⌛️ 1.2 @GetMapping
使用如下:
@GetMapping("/hi") // @GetMapping 只支持 get 请求,不支持 post 请求
public String hi() {
return "springmvc hi";
}
⌛️ 1.3 @PostMapping
使用如下:
@PostMapping("/sayhello") // 只支持 post 请求,不支持 get 请求
public String sayhello() {
return "springmvc hello";
}
⌛️ 2. 获取参数
⌛️ 2.1 传递/获取单个参数
在 Spring MVC 中可以直接⽤⽅法中的参数来实现传参,
// 这里列举了 3 种参数类型
@RequestMapping("/sayhi1")
public String sayHi(String name) { // 不传递 name 参数,那么此变量使用的是 String 的默认值 null
return "hi " + name;
}
@RequestMapping("/sayhi2")
public String sayhi2(Integer id) { // 不传递参数,使用 Integer(包装类) 的默认值 null
if(id == null) return "参数有误";
return "hi " + id;
}
@RequestMapping("/sayhi3")
public String sayhi3(int id) { // 不传递参数,报错 --> 所以参数传递不要使用基础数据类型,使用包装类
return "hi " + id;
}
访问第一个地址时,我传入参数 name=zhangsan,结果如下:
⌛️ 2.2 传递/获取多个参数
@RequestMapping("/sayhi11")
public String sayHi11(String name, String password) {
return "name:" + name + " | password:" + password;
}
比如我们传递参数 name=zhangsan,password=123,结果如下:
那么有人可能会把参数的顺序传错了,那会影响我们的结果吗?答案是不会的,因为当有多个参数时,前后端进⾏参数匹配时,是以参数的名称进⾏匹配的,因此参数的位置是不影响后端获取参数的结果。结果如下:
⌛️ 2.3 传递/获取对象
首先我们新建一个类 Userinfo:
package com.example.demo.entity;
import lombok.Data;
@Data
public class Userinfo { // 类下面有以下属性
private int id;
private String name;
private String password;
private int age;
}
接下来我们来获取对象:
@RequestMapping("/reg")
public Object reg(Userinfo userinfo) { // 框架会实现自动的参数映射
System.out.println(userinfo); // 拿到的对象只是普通格式的对象
return userinfo;
}
Spring MVC 可以⾃动实现参数对象的赋值,也就是框架会实现自动的参数映射。运行结果如下:
⌛️ 2.4 参数重命名
我们可以对后端的参数重命名,也叫作后端参数映射。因为工作中有时候前端和后端的参数命名要求不同,比如前端规定他们的命名为 username,而后端要求的为 name,那么此时我们就需要使用 @RequestParam 来重命名参数。
如果参数不重名的话,结果如下:
参数重命名就给前面加上注解:
@RequestMapping("/reg2")
// 使⽤ @RequestParam 来重命名前后端的参数值。eg:前端传入 username,后端命名为 name
public Object reg(@RequestParam(value = "username") String name, String password) {
return name + ":" + password;
}
结果如下:
⌛️ 2.4.1 设置参数必传
如果在上述例子中,我们不给 username 传入参数,那么访问时就会出错,所以当我们的实际业务中前端的参数是⼀个⾮必传的参数,我们可以通过设置 @RequestParam 中的 required=false 来避免不传递时报错,具体实现如下:
@RequestMapping("/reg2")
public Object reg(String name,@RequestParam(value = "username", required = false)
String password) {
return name + ":" + password;
}
⌛️ 2.5 获取 JSON 对象
@RequestMapping("/reg3")
// @RequestBody --> 接收 JSON 对象,要想拿到 json 格式的,必须加上 @RequestBody 注解
public Object reg3(@RequestBody Userinfo userinfo) {
System.out.println(userinfo); // 拿到的对象只是普通格式的对象
return userinfo;
}
⌛️ 2.6 从基础URL中获取参数
从基础的 URL中获取参数(?之前的参数,比如:http://localhost:8080/reg4/sy/123,获取的参数就是 sy 和123), 而不是从 URL的参数部分获取参数(是?之后的,比如http://localhost:8080/reg4?name=sy&password=123)。
@RequestMapping("/reg4/{name}/{password}")
public Object reg4(@PathVariable String name, @PathVariable("password") String password) {
return "name=" + name + " | password=" + password;
}
@RequestMapping("/reg44/{name}/{pwd}") // 参数名不同
public Object reg44(@PathVariable String name,
@PathVariable(required = false, name = "pwd") String password) {
return "name=" + name + " | password=" + password;
}
结果为:
一般当参数比较少的情况下使用这种传参。
⌛️ 2.7 获取上传的文件
后端代码:
@RequestMapping("/myupload")
public Object upload(@RequestPart("dog")MultipartFile file) {
String fileName = UUID.randomUUID() + // 文件名
file.getOriginalFilename().substring( // substring 处理的是文件后缀
file.getOriginalFilename().lastIndexOf(".")); // . 之前的为文件名
File saveFile = new File(
"D:\\Y\\106\\rrich\\java-ee\\JavaEE_further\\" + fileName); // 这里D:\\Y\\106\\rrich\\java-ee\\JavaEE_further\\是我的文件的保存路径
try{
file.transferTo(saveFile);
return true;
} catch (IOException e) {
e.printStackTrace();
}
return false;
}
前端:
在我的文件中查看,已经有了该图片:
⌛️ 2.8 获取Cookie
@RequestMapping("/getck")
public Object getCk(@CookieValue(value = "java", required = false) String java) {
return java;
}
⌛️ 2.9 存储和获取 session
存储 session 代码:
@RequestMapping("/setsess")
public void doPostConstruct(HttpServletRequest request) {
HttpSession session = request.getSession();
session.setAttribute(SESSION_KEY,"zhangsan");
}
只需要访问 http://localhost:8080/setsess 地址就可以成功存储 session。
获取 session 代码:
@RequestMapping("/getsess")
public Object getSession(@SessionAttribute(SESSION_KEY) String name) {
return "session -> " + name;
}
获取的结果如下:
⌛️ 2.10 获取 Header
@RequestMapping("/gethd")
// @RequestHeader() 里边的 header 是可以改变的
public Object getHeader(@RequestHeader("User-Agent")String ua) {
return "header -> " + ua;
}
结果为: