【Spring MVC】Spring MVC的功能使用和相关注解介绍

Spring MVC主要有三个功能:

  1. 连接
  2. 获取参数
  3. 输出数据

对于 Spring MVC 来说,掌握了以上 3 个功能就相当于掌握了Spring MVC。

1.连接

连接的功能:将⽤户(浏览器)和 Java 程序连接起来,也就是访问⼀个地址能够调⽤到我们的Spring 程序。

1.1 实现 Spring MVC的连接

先创建一个SpringMVC项目,过程和SpringBoot项目创建相同。

可以参考这篇文章SpringBoot的创建和运行

接下来,创建⼀个 UserController 类,实现⽤户到 Spring 程序的互联互通,具体实现代码如下:

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
@Controller // 让 spring 框架启动时,加载
@ResponseBody // 返回⾮⻚⾯数据
@RequestMapping("/user") // 路由器规则注册
public class UserController {
 // 路由器规则注册
 	@RequestMapping("/hi")
 	public String sayHi(){
 		return "<h1>Hi,Spring MVC.</h1>";
 	}
}

这样实现之后,当访问地址:http://localhost:8080/user/hi 时就能打印“hello,spring mvc”的信息了。

1.2 注解介绍

@RequestMapping

@RequestMapping是⽤来注册接⼝的路由映射的。

路由映射:所谓的路由映射指的是,当⽤户访问⼀个 url 时,将⽤户的请求对应到程序中某个类 的某个⽅法的过程就叫路由映射

  • @RequestMapping 即可修饰类,也可以修饰⽅法,当修饰类和⽅法时,访问的地址是类 + ⽅法。
  • @RequestMapping 既是post请求又是get请求。
@Controller
@RequestMapping("/web")
public class WebController {

    //响应视图
    @RequestMapping("/index")
    public String index(){
        return "/index.html";
    }
    //响应正文
    @ResponseBody
    @RequestMapping("/indexData")
    //只支持get请求
    //@RequestMapping(value = "/indexData",method = RequestMethod.GET)
    public String indexData(){
        return "hello,MVC";
    }
}

@GetMapping

实现get请求。

get请求的三种写法:

// 写法1
@RequestMapping("/index")
// 写法2
@RequestMapping(value = "/index",method = RequestMethod.GET)
// 写法3
@GetMapping("/index")

@PostMapping

实现post请求。

post请求的两种写法:

// 写法1
@RequestMapping(value = "/index",method = RequestMethod.POST)
// 写法2
@PostMapping("/index")

2.获取参数

2.1 传递单个参数

在 Spring MVC 中可以直接⽤⽅法中的参数来实现传参,⽐如以下代码:

@RestController
@RequestMapping("/param")
public class ParamController {

    //servlet传参
    @RequestMapping("/get1")
    public String get1(HttpServletRequest request){
        String name=request.getParameter("name");
        return "name:"+name;
    }
    //MVC传参
    @RequestMapping("/get2")
    public String get2(String name){
        return "name:"+name;
    }
    //多个参数传参
    @RequestMapping("/get3")
    public String get3(String name,Integer age){
        return "name:"+name+"|age:"+age;
    }
}

2.2 传递对象

定义一个Student类:

@Data
public class Student {
    private Integer id;
    private String name;
    private Integer age;
}

传递对象代码实现:

    @RequestMapping("/get6")
    public String get6(Student student){
        return student.toString();
    }

2.3 后端参数重命名

某些特殊的情况下,前端传递的参数 key 和我们后端接收的 key 可以不⼀致,⽐如前端传递了⼀个
n 给后端,⽽后端⼜是由name 字段来接收的,这样就会出现参数接收不到的情况,如果出现
这种情况,我们就可以使⽤ @RequestParam 来重命名前后端的参数值。

代码实现:

    @RequestMapping("/get7")
    public String get7(@RequestParam(name="n",required = false) String name){
        return "name:"+name;
    }

参数必传:将required设置成false,来避免不传递时报错

2.4 接收JSON对象

@RequestBody

上传一个json格式的数据:

在这里插入图片描述

后端接收代码实现:

    @RequestMapping("/get8")
    public String get8(@RequestBody Student student){
        log.info(student.toString());
        return student.toString();
    }

@RequestBody表示接收的是一个json字符串,String会帮我们把这个字符串转为对象。

2.5 获取URL中参数

@PathVariable

给定一个URL:
在这里插入图片描述
实现代码:

    @RequestMapping("/get9/{shopid}")
    public String get9(@PathVariable Integer shopid){
        return "shopid:"+shopid;
    }

2.6 上传文件

@RequestPart

实现代码:

    @RequestMapping("/get10")
    public String get10(@RequestPart("file") MultipartFile file) throws IOException {
        log.info(file.getOriginalFilename());
        file.transferTo(new File("D:\\Desktop\\Bit\\temp"+file.getOriginalFilename()));
        return "success";
    }

2.7 获取Cookie/Session/header

@CookieValue

获取Session实现代码:

    @RequestMapping("/get11")
    public String get11(@CookieValue(required = false) String bite){
        return "bite:"+bite;
    }

@SessionAttribute

设置Session实现代码:

    @RequestMapping("/get12")
    public String get12(@SessionAttribute(required = false) String username){
        return "username:"+username;
    }

设置之后,cookie中会多一个sessionId。

@RequestHeader

获取Header内容实现代码:

    @RequestMapping("/get13")
    public String get13(@RequestHeader("User-Agent") String useragent){
        return "useragent:"+useragent;
    }

2.8 返回JSON对象

实现代码:

    @RequestMapping("/get14")
    public Map<String,String> get14(){
        Map<String,String>map=new HashMap<>();
        map.put("k1","v1");
        map.put("k2","v2");
        map.put("k3","v3");
        map.put("k4","v4");
        return map;
    }

3.输出数据

3.1 返回静态页面

实现代码:

    //响应视图
    @RequestMapping("/index")
    public String index(){
        return "/index.html";
    }

3.2 返回text正文

@ResponseBody

实现代码:

	//响应正文
    @ResponseBody

> 这里是引用

    @RequestMapping("/indexData")
    public String indexData(){
        return "hello,MVC";
    }
}

4.请求转发和请求重定向

return 不但可以返回⼀个视图,还可以实现跳转,跳转的⽅式有两种:

  • forward:请求转发;
  • redirect:请求重定向。

举例说明: forward(请求转发)和 redirect(请求重定向)的区别

你告诉你妈妈,你想吃辣条,如果你妈妈,说好,我帮你去买,这就是 forward 请求转发;如果你妈妈让你⾃⼰去买,那么就是
请求 redirect 重定向

4.1 请求转发forward

代码实现:

    /**
     * 请求转发
     * @return
     */
    @RequestMapping("/forward")
    public String forward(){
        return "forward:/index.html";
    }

4.2 请求重定向redirect

代码实现:

    /**
     * 请求重定向
     * @return
     */
    @RequestMapping("/redirect")
    public String redirect(){
        return "redirect:/index.html";
    }
  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 7
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值