如何使用SpringMVC之常用注解

❣️关注专栏:JavaEE
在这里插入图片描述


SpringMVC有三个功能:

  1. 连接的功能:将⽤户(浏览器)和 Java 程序连接起来,也就是当用户访问⼀个地址能够调⽤到我们的Spring 程序。
  2. 获取参数的功能:⽤户访问的时候会传入⼀些参数,在程序中要想办法可以获取到参数。
  3. 输出数据的功能:执⾏了业务逻辑之后,要把程序执⾏的结果返回给⽤户。
    接下来我们来探索这 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;
    }

结果为:
在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值