目录
一、Postman 工具使用
1.1 Postman安装
1.2 Postman的使用
1.2.1 创建WorkSpace工作空间
1.2.2 创建请求
二、参数传递
2.1 添加 Slf4j 依赖
2.2 普通传参
知识点1:@RequestMapping
知识点2:@RequestParam
2.3 路径传参
知识点3:@PathVariable
2.4 Json数据传参
知识点4:@RequestBody
三、响应
3.1 响应Json数据
3.2 跳转页面响应数据
3.3 ModelAndView 响应
四、页面跳转
4.1 转发(地址栏不变)
4.2 重定向(地址栏改变)
4.3 跳其它的controller
在这之前先了解一下Postman工具,Postman是一款流行的API开发和测试工具,它提供了一个用户友好的界面,用于发送HTTP请求并查看响应。它可以帮助开发人员在开发和测试API时更加高效和方便。
我们在编写web程序的时候需要频繁的进行数据测试,发送的是GET请求可以直接使用浏览器,如果要求发送的是post请求,我们就得准备页面在页面上准备form表单,测试起来比较麻烦。所以我们就需要借助一些第三方工具,如Postman、Eolink...
Postman官方下载地址 https://www.postman.com/downloads/
双击自动安装,首次进入需要我们注册登入也可以选择跳过,如需要测试还得要登入一手。可以点可以按照提示进行注册,如下界面是我登入后的主界面。
创建新的工作空间并设置工作空间的名字:
选择刚创建的工作空间并添加一个请求:
注意: 第一次请求需要创建一个新的目录,后面就不需要创建新目录,直接保存到已经创建好的目录即可。
上一篇我们已经完成了入门案例相关的知识学习,我们知道SpringMVC是web层的框架,主要的作用是接收请求、接收数据、响应结果,所以这一章节是学习SpringMVC的重点内容。
2.9.1 3.2.0 1.7.13 org.slf4j slf4j-api${slf4j.version} org.slf4j jcl-over-slf4j${slf4j.version} runtime org.apache.logging.log4j log4j-api${log4j2.version} org.apache.logging.log4j log4j-core${log4j2.version} org.apache.logging.log4j log4j-slf4j-impl${log4j2.version} org.apache.logging.log4j log4j-web${log4j2.version} runtime com.lmax disruptor${log4j2.disruptor.version}
在上篇文章的pom.xml配置文件中换掉log4j的依赖,在实际开发中通常会使用日志文件将数据信息进行保存。而 Slf4j(Simple Logging Facade for Java)是一个简单的Java日志门面框架,它提供了一种通用的日志接口,使开发人员能够在应用程序中使用不同的日志实现,而无需修改代码。Slf4j的目标是为Java应用程序提供一种简单、灵活和可扩展的日志解决方案。
编写paramController类
package com.ycxw.web; import lombok.extern.slf4j.Slf4j; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; /** * @author 云村小威 * @site blog.csdn.net/Justw320 * @create 2023-09-05 16:34 */ @Slf4j @Controller @RequestMapping("/param") public class ParamController { @RequestMapping("/hello1") public String toHello1(Integer bid,String bname){ log.info("基础类型+String传参:bid:{},bname:{}",bid,bname); return "index"; } }
@RequestMapping注解是一个用来处理请求地址映射的注解,可用于映射一个请求或一个方法,可以用在类或方法上。
- @Slf4j注解表示该类使用Slf4j日志框架进行日志记录。
- @Controller注解表示这是一个控制器类,用于处理HTTP请求。该类的请求映射路径为"/param"。
- 在该类中,定义了一个名为ParamController的控制器类。它包含了一个名为toHello1的方法,该方法使用@RequestMapping注解来指定处理的URL路径为"/hello1"。该方法接受两个参数,一个是基本类型的整数bid,另一个是字符串类型的bname。
- 在方法体内,使用log.info方法记录了一条日志信息。这条日志信息包含了两个参数bid和bname的值,使用{}占位符来表示参数的位置。
- 最后,该方法返回了一个字符串"index",表示要渲染的视图名称。
打印结果:
注意:如果形参与地址参数名不一致会导致接收数据失败:
解决方案: 使用@RequestParam注解
@RequestParam主要用于将请求参数区域的数据映射到控制层方法的参数上
参数 | 说明 |
---|---|
value | 请求中传入参数的名称,如果不设置后台接口的value值,则会默认为该变量名。 |
required | 该参数是否为必传项。默认是true,表示请求中一定要传入对应的参数,否则会报404错误,如果设置为false时,当请求中没有此参数,将会默认为null,而对于基本数据类型的变量,则必须有值,这时会抛出空指针异常。如果允许空值,则接口中变量需要使用包装类来声明。 |
defaultValue | 参数的默认值,如果请求中没有同名的参数时,该变量默认为此值。注意默认值可以使用SpEL表达式,如"#{systemProperties[‘java.vm.version’]}" |
@RequestMapping("/hello2") public String toHello2(@RequestParam(required = false) Integer bid, @RequestParam(value = "bhahaha") String bname) { log.info("基础类型+String传参:bid:{},bname:{}", bid, bname); return "index"; }
这时利用@RequestParam注解设置前台传参名字,就可以用bhahaha传值成功。
如果我要通过id进行删除某一项可以用PathVariable注释,示例:
@RequestMapping("/hello3/{bid}") public String toHello3(@PathVariable("bid") Integer bid) { log.info("使用@PathVariable注解传递参数:{}", bid); return "index"; }
运行结果:
在实际开发中运用最多的就是通过Json数据进行传输,在本篇就没有演示对象、数组、以及集合传输,其传输方式与上普通传参略微有异。
SpringMVC默认使用的是jackson来处理json的转换,所以需要在pom.xml添加jackson依赖
2.9.3 com.fasterxml.jackson.core jackson-databind${jackson.version} com.fasterxml.jackson.core jackson-core${jackson.version} com.fasterxml.jackson.core jackson-annotations${jackson.version}
@RequestBody 注解用于将HTTP请求的请求体内容绑定到方法的参数上。它告诉Spring MVC框架将请求体的内容转换为指定的参数类型,并将其传递给方法进行处理。
使用@RequestBody注解的参数可以是任何Java对象类型,包括自定义的POJO(Plain Old Java Object)类。Spring MVC会自动根据请求体的内容类型,使用适当的转换器将请求体的内容转换为指定的参数类型。
请求和数据的发送:
{ "bid": 1, "bname": "斗破苍穹", "price": 9.9 }
后端接收数据:
@RequestMapping("/hello5") @ResponseBody public String toHello5(@RequestBody Book book) { System.out.println(book); return "index"; }
请求和数据的发送:
[{ "bid": 1, "bname": "斗破苍穹", "price": 9.9 }, { "bid": 2, "bname": "斗破苍穹", "price": 10.9 } ]
后端接收数据:
@RequestMapping("/hello6") @ResponseBody public String toHello6(@RequestBody Listbooks) { System.out.println(books); return "index"; }
@RequestBody与@RequestParam区别
区别:
应用:
1. 创建控制器:ReturnController类
package com.ycxw.web; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; /** * @author 云村小威 * @site blog.csdn.net/Justw320 * @create 2023-09-06 22:18 */ @Controller @RequestMapping("/rs") public class ReturnController { }
2. 编写响应数据
@ResponseBody //响应Json数据 @RequestMapping("/return1") public Mapreturn1(HttpServletResponse response){ Map maps = new HashMap<>(); maps.put("code",200); maps.put("msg","响应成功"); return maps; }
3. 测试:
1. 编写响应的jsp
<%@ page contentType="text/html;charset=UTF-8" language="java" %>Title 昵称:${name} 又爱又恨:${hobby}
2. 编写响应的数据
@RequestMapping("/return2") public String return2(Model model, HttpServletRequest request){ //填充模型数据 model.addAttribute("name","云村小威"); request.setAttribute("hobby","编程"); //逻辑视图名 return "index"; }
3. 测试:
@RequestMapping("/return3") public ModelAndView return3(){ ModelAndView mv = new ModelAndView(); //填充模型数据 mv.addObject("name","云村小威"); mv.addObject("hobby","编程"); //逻辑视图名 mv.setViewName("index"); return mv; }
测试:
转发(forward:path)和重定向(redirect:path)这两种跳转方式将会绕开视图解析器的前缀和后缀;还有就是如果是在同一controller中则不用使用"/"从根目录开始,而如果是在不同的controller则一定要从根目录开始。
@RequestMapping("/helloPage1") public String toHelloPage1(){ System.out.println("helloPage1..."); return "forward:return1"; }
它相当于“request.getRequestDispatcher("url").forward(request,response)”。使用转发,既可以转发到jsp, 也可以转发到其他的控制器方法。
@RequestMapping("/helloPage2") public String toHelloPage2(){ System.out.println("helloPage2..."); return "redirect:return1"; }
它相当于“response.sendRedirect(url)”, 也可以转发到其他的控制器方法。
/*转发*/ @RequestMapping("/helloPage3") public String toHelloPage3(){ System.out.println("helloPage3..."); return "forward:/param/hello1"; } /*重定向*/ @RequestMapping("/helloPage4") public String toHelloPage4(){ System.out.println("helloPage4..."); return "redirect:/param/hello1"; }
测试重定向:redirect:/param/hello1
如果是在同一controller中则不用使用 "/" 从根目录开始,而如果是在不同的controller则一定要从根目录开始。