Spring MVC中的一些常用注解

发布时间:2024年01月15日

目录

@RequestMapping

实现路由映射

限制请求方式

@PathVariable

从url中获取变量的值

更改绑定参数的名字

@RequestParam

可以传递集合?

更改绑定参数的名字

可修改是否为必传参数

@RequestBody

获取请求正文的内容?

可修改是否为必传参数

@RequestPart

可以支持上传文件

更改绑定参数的名字

可修改是否为必传参数

@Controller

@CookieValue

获取指定的Cookie值

@SessionAttribute

获取指定的Session值

@RequestHeader

获取请求头中的值

@Controller

返回html页面

@ResponseBody

设置返回类型为数据


@RequestMapping

这个注解既是类注解也是方法注解?

实现路由映射

这个注解主要来实现URL路由映射,也就是浏览器连接程序的作用。

url的组成:http://IP:端口号/类注解/方法注解

@RestController
public class LoginController {
    @RequestMapping("/fun1")
    public String fun1() {
        return "hahaha";
    }
}

@RequestMapping("/test")
@RestController
public class LoginController {
    @RequestMapping("/fun1")// "/"可写可不写
    public String fun1() {
        return "hahaha";
    }
}

限制请求方式

@RequestMapping("/test")
@RestController
public class LoginController {
    @RequestMapping(value = "/fun1", method = RequestMethod.GET)// 只接收GET请求
    public String fun1() {
        return "hahaha";
    }
}

?

@PathVariable

从url中获取变量的值

@RequestMapping("/fun2/{name}")
public String fun2(@PathVariable String name) {
    return "name:"+name;
}

更改绑定参数的名字

此时形参username的名字就可以随意更改了。

@RequestParam

可以传递集合?

如果不加?@RequestParam注释Spring会默认将前端传的集合转换成数组。

@RequestMapping("/fun3")
public List<String> fun3(@RequestParam List<String> list) {
    return list;
}

@RequestMapping("/fun3")
public List<String> fun3(List<String> list) {
    return list;
}

更改绑定参数的名字

@RequestMapping("/fun3")
public List<String> fun3(@RequestParam("list") List<String> a) {
    return a;
}

此时形参username的名字就可以随意更改了。

可修改是否为必传参数

被@RequestParam修饰的参数默认为必传参数。

@RequestMapping("/fun3")
public List<String> fun3(@RequestParam(value = "list", required = false) List<String> a) {
    return a;
}

此时如果不传参数就不会报错。

@RequestBody

获取请求正文的内容?

@RequestMapping("/fun4")
public String fun4(@RequestBody User user){
    return user.toString();
}

可修改是否为必传参数

被@RequestBody修饰的参数默认为必传参数。

将其设置为非必传参数:

@RequestMapping("/fun4")
public String fun4(@RequestBody(required = false) User user){
    return user.toString();
}

@RequestPart

可以支持上传文件

@RequestMapping("/fun5")
public String fun5(@RequestPart MultipartFile file){
    return file.getOriginalFilename();//返回文件名
}

更改绑定参数的名字

@RequestMapping("/fun5")
public String fun5(@RequestPart("file") MultipartFile a){
    return a.getOriginalFilename();
}

可修改是否为必传参数

被@RequestPart修饰的参数默认为必传参数。

@RequestMapping("/fun5")
//设置参数为非必传
public String fun5(@RequestPart(value = "file", required = false) MultipartFile a){
    return a.getOriginalFilename();
}

@Controller

@CookieValue

获取指定的Cookie值

注:@CookieValue该注释只能获取一个Cookie值。

@RequestMapping("/fun6")
//获取Cookie中键为name的值
public String fun6(@CookieValue("name") String value) {
    return "name:"+value;
}

首先在浏览器中创建一个?Cookie

@SessionAttribute

获取指定的Session值

注:只能获取单个Session

//因为Session是服务器端的概念,所以获取之前应该先设置
@RequestMapping("/fun7")
public void fun7(HttpSession session) {
    //设置Session值
    session.setAttribute("name", "zhangsan");
}
//获取Session值
@RequestMapping("/fun8")
public String fun8(@SessionAttribute("name") String name) {
    return "name:"+name;
}

@RequestHeader

获取请求头中的值

下面这是一段请求头信息?

现在获取里面的Host的值

@RequestMapping("/fun9")
public String fun9(@RequestHeader("Host") String data) {
    return "Host:"+data;
}

@Controller

@Controller是一个类注解,它定义?个控制器,Spring框架启动时加载,把这个对象交给Spring管理。默认返回的是一个页面。

返回html页面

先创建一个HTML页面login.html

里面只有一行代码:

@Controller
@RequestMapping("/test1")
public class Test {
    @RequestMapping("/fun1")
    public String fun1() {
        return "/login.html";
    }
}

@ResponseBody

注:这个注解既可以修饰类,也可以修饰方法。

被修饰的类或方法都只能返回数据。?

设置返回类型为数据

@Controller
@RequestMapping("/test1")
public class Test {
    @ResponseBody
    @RequestMapping("/fun1")
    public String fun1() {
        return "/login.html";
    }
}

文章来源:https://blog.csdn.net/2302_76339343/article/details/135559496
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。