当前位置: 首页 > news >正文

Spring MVC2

在Spring MVC1中,我们知道了MVC的定义,同时也知道了@RequestMapping和@RestController这个注解的作用。

本篇文章,我们将学习使用Spring MVC获取请求参数和返回不同的响应等等

请求

传递单个参数

如图所示,创建RequestController类:

 在类中实现传递单个参数:

@RestController
public class RequestController {@RequestMapping("/r1")public String r1(String name){return "获取参数"+name;}
}

我们可以使用Postman对代码进行测试 :

传int和Integer对比(传错误类型和不传参数):

传递Integer:

  @RequestMapping("/r2")public String r2(Integer num){return "获取参数"+num;}

传递int:

   @RequestMapping("/r3")public String r3(int num){return "获取参数"+num;}

可以看到在不传参时int直接报了个500(500属于客户端的问题,是要我们后端开发人员负责的),因此在实际开发中建议多使用包装类型

传递多个参数

@RequestMapping("/r4")public String r4(String name,Integer age){return "获取参数:"+name+" age:"+age;}

Postman测试: 

传递对象 

当我们需要传递两个以上的参数时,就可以使用对象来进行传递,使代码更加简洁。

先在目录下创建一个学生类:

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

我们可以使用Lombok的@Data注解来减少Getter和Setter方法的书写:

首先,我们需要在pom.xml中添加Lombok的依赖,这里建议使用插件进行添加: 在pom.xml文件中右键-生成:

选中我们刚才安装的插件:

 

继续按图示点击,然后OK即可: 回到刚才的Student代码处,添加上@Data注解。

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

这是Lombok中所包含的一些其他注解: @Data=@Getter+@Setter+@ToString+@EqualsAndHashCode+@RequiredArgsConstructor+@NoArgsContryctor

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

测试: 

后端参数映射(后端参数重命名)

后端参数映射需要使用@RequestParam这个注解:

    @RequestMapping("/r6")public String r6(@RequestParam("name")String userName){return "获取参数"+userName;}

测试: 

传递数组

    @RequestMapping("/r7")public String r7(int[] arr){return Arrays.toString(arr);}

测试:

方式1: 
方式2: 

传递集合

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

 测试:

方式1:
方式2:

传递Json对象

传递Json对象需要使用@RequestBody这个注解

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

测试: 

Json字符串转对象和对象转字符串

代码:

public class TestJson {public static void main(String[] args) throws JsonProcessingException {ObjectMapper mapper = new ObjectMapper();//json字符串转对象String jsonstr = "{\"name\":\"张三\",\"age\":15,\"id\":5}";Student student = mapper.readValue(jsonstr,Student.class);System.out.println(student);//json对象转字符串String s = mapper.writeValueAsString(student);System.out.println(s);}
}

 运行结果:

传递URL中的对象

注意这里的参数一个都不能少,Spring是无法识别出缺失的参数的。 

    @RequestMapping("r9/{name}/{age}")public String r9(@PathVariable("name")String userName,@PathVariable Integer age){return "获取参数:"+userName+" age:"+age;}

测试: 

 传递文件

这里的注解@RequestPart可加也可不加。

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

测试: 

获取Cookie

Spring中内置了HttpSeverletRequest和HttpSeverletResponse两个对象(这两个对象包含了Http请求/响应中的所有属性)。因为Cookie一般是在请求中的,所以我们可以通过HttpSeverletRequest来获取到Cookie。

方式1: 
    @RequestMapping("/getC1")public String getCookie1(HttpServletRequest request){Cookie[] cookies = request.getCookies();if(cookies != null){Arrays.stream(cookies).forEach((ck)->{System.out.println(ck.getName()+":"+ck.getValue());});}return "获取cookie成功";}

点击这里创建一个Cookie: 输入127.0.0.1后Add Domain即可:

点击这里创建Cookie:

测试:

方式2:
 @RequestMapping("/getC2")public String getCookie2(@CookieValue("xmy") String xmy){return xmy;}

测试:

设置Session

方式1:
    @RequestMapping("/setSess")public String setSess(HttpServletRequest request){HttpSession session = request.getSession();session.setAttribute("name","zhangsan");return "设置session成功";}
方式2:
  @RequestMapping("/setSess1")public String setSess1(HttpSession session) {session.setAttribute("name","zhangsan");return "设置session成功";}

获取Session 

方式1:
    @RequestMapping("/getSess1")public String getSess1(HttpServletRequest request){HttpSession session = request.getSession();String name = (String) session.getAttribute("name");return name;}

测试:

 方式2:
   @RequestMapping("/getSess2")public String getSess2(HttpSession session){String name = (String) session.getAttribute("name");return name;}

测试:

 方式3:
    @RequestMapping("/getSess3")public String getSess3(@SessionAttribute("name")String name){return name;}

获取Header中的元素

这里我们获取的是Header中的User-Agent元素。

方式1:
 @RequestMapping("/getHeader")public String getHeader(HttpServletRequest request){String header = request.getHeader("User-Agent");return header;}

测试:

 方式2:
    @RequestMapping("/getHeader2")public String getHeader2(@RequestHeader("User-Agent")String header){return header;}

测试:

响应

返回静态页面

先在static目录下创建一个HTML文件: 

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Title</title>
</head>
<body>
<h1>我是一个标题</h1>
</body>
</html>

这里我们需要把类上面的@RestController变成@Controller,@Controller是定义⼀个控制器, Spring 框架启动时加载, 把这个对象交给Spring管理(返回的是视图),而@RestController = @ResponseBody(返回数据)+@Controller,因此RestController返回的是数据。

@Controller
public class ResponseController {@RequestMapping("/index")public String index(){return "/index.html";}

测试:

注意:因为在这里使用的是@Controller,所以我们后面需要返回数据的内容都要加上@ResponseBody 。

返回数据

@RequestMapping("/index2")@ResponseBodypublic String index2(){return "返回数据";}

测试: 

返回HTML代码片段

    //返回html@RequestMapping("/index3")@ResponseBodypublic String index3(){return "<h1>hello springmvc<h1>";}

 测试:

返回Json 

    //返回json@RequestMapping("/index4")@ResponseBodypublic HashMap<String,String> index4(){HashMap<String,String> map = new HashMap<>();map.put("k1","v1");map.put("k2","v2");map.put("k3","v3");map.put("k4","v4");return map;}

 测试:

设置状态码

设置状态码需要使用HttpSeverletResponse对象 

    //设置状态码@ResponseBody@RequestMapping("/index5")public String setStatus(HttpServletResponse response){response.setStatus(418);return "设置状态码";}

测试:

设置返回类型

//设置返回类型@RequestMapping(value = "return",produces = "applicatin/json")@ResponseBodypublic String returnJson(){return "{\"success\":true}";}

 测试:

http://www.xdnf.cn/news/1127881.html

相关文章:

  • 尚庭公寓-----day1----@MapperScan爆红问题
  • 三十二、【核心功能改造】数据驱动:重构仪表盘与关键指标可视化
  • 【转】Rust: PhantomData,#may_dangle和Drop Check 真真假假
  • 【字节跳动】数据挖掘面试题0019:带货直播间推荐:现在有一个带货的直播间,怎么把它精准地推送给有需要的用户
  • 【C++】神奇的AVL树
  • WebView JSBridge 无响应问题排查实录 全流程定位桥接调用失效
  • 无人机故障响应模块运行与技术难点
  • Ubuntu24 辅助系统-屏幕键盘的back按键在网页文本框删除不正常的问题解决方法
  • RTL编程中常用的几种语言对比
  • 【C#地图显示教程:实现鼠标绘制图形操作】
  • 厂区车辆导航系统:基于 GPS+AI 动态路径规划的技术实现与实践
  • 春秋云镜 initial
  • 2025开放原子开源生态大会 | openKylin的技术跃迁和全球协作
  • 2025开放原子开源生态大会 | 开源欧拉的AI原生实践与全球协作
  • GaussDB 数据库架构师修炼(三) 集群管理概览
  • 李宏毅《生成式人工智能导论》 | 第11讲-第14讲:大型语言模型的可解释性、能力评估、安全性
  • React源码5 三大核心模块之一:render,renderRoot
  • docker-compose 配置启动2个MongoDB
  • 【Docker基础】Dockerfile构建与运行流程完全指南:从原理到实践优化
  • PostgreSQL 超详细安装与使用教程:从入门到实战
  • Axios 和Express 区别对比
  • 使用LNMP一键安装包安装PHP、Nginx、Redis、Swoole、OPcache
  • Linux系统调优和工具
  • 理解 HTTP POST 请求中的 json 和 data 参数
  • 【目标追踪】MUTR3D: A Multi-camera Tracking Framework via 3D-to-2D Queries
  • 快速了解 HTTPS
  • 【BUG处理】构建APK时遇到错误:‘flutter‘ 命令未被识别。这通常表示您的系统中未安装Flutter SDK或环境变量配置不正确。
  • 【亲测有效】ubuntu20.04服务器新建用户+vnc配置教程
  • 基于按键开源MultiButton框架深入理解代码框架(二)(指针的深入理解与应用)
  • 【橘子分布式】Thrift RPC(编程篇)