【SpringMVC】参数传递与用户请求和响应(上)

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: 【SpringMVC】参数传递与用户请求和响应(上)

一、Postman 工具使用

       在这之前先了解一下Postman工具,Postman是一款流行的API开发和测试工具,它提供了一个用户友好的界面,用于发送HTTP请求并查看响应。它可以帮助开发人员在开发和测试API时更加高效和方便。

       我们在编写web程序的时候需要频繁的进行数据测试,发送的是GET请求可以直接使用浏览器,如果要求发送的是post请求,我们就得准备页面在页面上准备form表单,测试起来比较麻烦。所以我们就需要借助一些第三方工具,如Postman、Eolink...

1.1 Postman安装

Postman官方下载地址 https://www.postman.com/downloads/

       双击自动安装,首次进入需要我们注册登入也可以选择跳过,如需要测试还得要登入一手。可以点可以按照提示进行注册,如下界面是我登入后的主界面。

1.2 Postman的使用

1.2.1 创建WorkSpace工作空间

创建新的工作空间并设置工作空间的名字:

1.2.2 创建请求

选择刚创建的工作空间并添加一个请求:

注意: 第一次请求需要创建一个新的目录,后面就不需要创建新目录,直接保存到已经创建好的目录即可。

二、参数传递

       上一篇我们已经完成了入门案例相关的知识学习,我们知道SpringMVC是web层的框架,主要的作用是接收请求、接收数据、响应结果,所以这一章节是学习SpringMVC的重点内容。

2.1 添加 Slf4j 依赖

<log4j2.version>2.9.1</log4j2.version>
<log4j2.disruptor.version>3.2.0</log4j2.disruptor.version>
<slf4j.version>1.7.13</slf4j.version>
<!--4.log日志相关依赖-->
<!-- log4j2日志相关依赖 -->
<!-- log配置:Log4j2 + Slf4j -->
<!-- slf4j核心包-->
<dependency>
  <groupId>org.slf4j</groupId>
  <artifactId>slf4j-api</artifactId>
  <version>${slf4j.version}</version>
</dependency>
<dependency>
  <groupId>org.slf4j</groupId>
  <artifactId>jcl-over-slf4j</artifactId>
  <version>${slf4j.version}</version>
  <scope>runtime</scope>
</dependency>
<!--核心log4j2jar包-->
<dependency>
  <groupId>org.apache.logging.log4j</groupId>
  <artifactId>log4j-api</artifactId>
  <version>${log4j2.version}</version>
</dependency>
<dependency>
  <groupId>org.apache.logging.log4j</groupId>
  <artifactId>log4j-core</artifactId>
  <version>${log4j2.version}</version>
</dependency>
<!--用于与slf4j保持桥接-->
<dependency>
  <groupId>org.apache.logging.log4j</groupId>
  <artifactId>log4j-slf4j-impl</artifactId>
  <version>${log4j2.version}</version>
</dependency>
<!--web工程需要包含log4j-web,非web工程不需要-->
<dependency>
  <groupId>org.apache.logging.log4j</groupId>
  <artifactId>log4j-web</artifactId>
  <version>${log4j2.version}</version>
  <scope>runtime</scope>
</dependency>
<!--需要使用log4j2的AsyncLogger需要包含disruptor-->
<dependency>
  <groupId>com.lmax</groupId>
  <artifactId>disruptor</artifactId>
  <version>${log4j2.disruptor.version}</version>
</dependency>

       在上篇文章的pom.xml配置文件中换掉log4j的依赖,在实际开发中通常会使用日志文件将数据信息进行保存。而 Slf4j(Simple Logging Facade for Java)是一个简单的Java日志门面框架,它提供了一种通用的日志接口,使开发人员能够在应用程序中使用不同的日志实现,而无需修改代码。Slf4j的目标是为Java应用程序提供一种简单、灵活和可扩展的日志解决方案。

2.2 普通传参

编写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";
    }
}

知识点1:@RequestMapping

       @RequestMapping注解是一个用来处理请求地址映射的注解,可用于映射一个请求或一个方法,可以用在类或方法上。

  • @Slf4j注解表示该类使用Slf4j日志框架进行日志记录。
  • @Controller注解表示这是一个控制器类,用于处理HTTP请求。该类的请求映射路径为"/param"。
  • 在该类中,定义了一个名为ParamController的控制器类。它包含了一个名为toHello1的方法,该方法使用@RequestMapping注解来指定处理的URL路径为"/hello1"。该方法接受两个参数,一个是基本类型的整数bid,另一个是字符串类型的bname。
  • 在方法体内,使用log.info方法记录了一条日志信息。这条日志信息包含了两个参数bid和bname的值,使用{}占位符来表示参数的位置。
  • 最后,该方法返回了一个字符串"index",表示要渲染的视图名称。

 

  • 普通参数:url地址传参,地址参数名与形参变量名相同,定义形参即可接收参数。

打印结果:

注意:如果形参与地址参数名不一致会导致接收数据失败:

解决方案: 使用@RequestParam注解

 

知识点2:@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传值成功。

相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
相关文章
|
2月前
|
前端开发 Java 开发者
Spring MVC中的请求映射:@RequestMapping注解深度解析
在Spring MVC框架中,`@RequestMapping`注解是实现请求映射的关键,它将HTTP请求映射到相应的处理器方法上。本文将深入探讨`@RequestMapping`注解的工作原理、使用方法以及最佳实践,为开发者提供一份详尽的技术干货。
145 2
|
3月前
|
JSON 前端开发 Java
Spring MVC——获取参数和响应
本文介绍了如何在Spring框架中通过不同的注解和方法获取URL参数、上传文件、处理cookie和session、以及响应不同类型的数据。具体内容包括使用`@PathVariable`获取URL中的参数,使用`MultipartFile`上传文件,通过`HttpServletRequest`和`@CookieValue`获取cookie,通过`HttpSession`和`@SessionAttribute`获取session,以及如何返回静态页面、HTML代码片段、JSON数据,并设置HTTP状态码和响应头。
77 1
Spring MVC——获取参数和响应
|
3月前
|
设计模式 前端开发 Java
Spring MVC——项目创建和建立请求连接
MVC是一种软件架构设计模式,将应用分为模型、视图和控制器三部分。Spring MVC是基于MVC模式的Web框架,通过`@RequestMapping`等注解实现URL路由映射,支持GET和POST请求,并可传递参数。创建Spring MVC项目与Spring Boot类似,使用`@RestController`注解标记控制器类。
51 1
Spring MVC——项目创建和建立请求连接
|
3月前
|
前端开发 Java
学习SpringMVC,建立连接,请求,响应 SpringBoot初学,如何前后端交互(后端版)?最简单的能通过网址访问的后端服务器代码举例
文章介绍了如何使用SpringBoot创建简单的后端服务器来处理HTTP请求,包括建立连接、编写Controller处理请求,并返回响应给前端或网址。
64 0
学习SpringMVC,建立连接,请求,响应 SpringBoot初学,如何前后端交互(后端版)?最简单的能通过网址访问的后端服务器代码举例
|
4月前
|
XML 缓存 前端开发
springMVC02,restful风格,请求转发和重定向
文章介绍了RESTful风格的基本概念和特点,并展示了如何使用SpringMVC实现RESTful风格的请求处理。同时,文章还讨论了SpringMVC中的请求转发和重定向的实现方式,并通过具体代码示例进行了说明。
springMVC02,restful风格,请求转发和重定向
|
6月前
|
缓存 前端开发 Java
SpringMVC原理(1)-文件上传请求
【7月更文挑战第2天】SpringMVC文件上传请求原理:文件上传请求的执行流程、文件上传的自动配置原理 涉及组件:MultiPartFile、MultipartResolver、MultipartHttpServlet
|
7月前
|
JSON 前端开发 Java
【JavaEE进阶】 关于Spring MVC 响应
【JavaEE进阶】 关于Spring MVC 响应
70 3
|
7月前
|
JSON Java fastjson
SpringMVC(二)【请求与响应】(2)
SpringMVC(二)【请求与响应】
|
7月前
|
JSON 前端开发 数据格式
SpringMVC的数据响应-直接回写json字符串
SpringMVC的数据响应-直接回写json字符串
|
7月前
|
前端开发 Java Spring
SpringMVC的数据响应-19
SpringMVC的数据响应-19