SpringBoot之请求的详细解析

发布时间:2023年12月18日

1. 请求

在本章节呢,我们主要讲解,如何接收页面传递过来的请求数据。

1.1 Postman

之前我们课程中有提到当前最为主流的开发模式:前后端分离

在这种模式下,前端技术人员基于"接口文档",开发前端程序;后端技术人员也基于"接口文档",开发后端程序。

由于前后端分离,对我们后端技术人员来讲,在开发过程中,是没有前端页面的,那我们怎么测试自己所开发的程序呢?

方式1:像之前SpringBoot入门案例中一样,直接使用浏览器。在浏览器中输入地址,测试后端程序。

  • 弊端:在浏览器地址栏中输入地址这种方式都是GET请求,如何我们要用到POST请求怎么办呢?

    • 要解决POST请求,需要程序员自己编写前端代码(比较麻烦)

方式2:使用专业的接口测试工具(课程中我们使用Postman工具)

1.1.1 介绍

  • Postman是一款功能强大的网页调试与发送网页HTTP请求的Chrome插件。

    Postman原是Chrome浏览器的插件,可以模拟浏览器向后端服务器发起任何形式(如:get、post)的HTTP请求

    使用Postman还可以在发起请求时,携带一些请求参数、请求头等信息

  • 作用:常用于进行接口测试

  • 特征

    • 简单

    • 实用

    • 美观

    • 大方

1.1.2 安装

双击资料中提供的Postman-win64-8.3.1-Setup.exe即可自动安装。

安装完成之后,进入页面中会提示有新版本可以升级(无需升级)

界面介绍:

如果我们需要将测试的请求信息保存下来,就需要创建一个postman的账号,然后登录之后才可以。

登录完成之后,可以创建工作空间:

创建请求:

点击"Save",保存当前请求

1.2 简单参数

简单参数:在向服务器发起请求时,向服务器传递的是一些普通的请求数据。

那么在后端程序中,如何接收传递过来的普通参数数据呢?

我们在这里讲解两种方式:

  1. 原始方式

  2. SpringBoot方式

1.2.1 原始方式

在原始的Web程序当中,需要通过Servlet中提供的API:HttpServletRequest(请求对象),获取请求的相关信息。比如获取请求参数:

Tomcat接收到http请求时:把请求的相关信息封装到HttpServletRequest对象中

在Controller中,我们要想获取Request对象,可以直接在方法的形参中声明 HttpServletRequest 对象。然后就可以通过该对象来获取请求信息:

//根据指定的参数名获取请求参数的数据值
String ?request.getParameter("参数名")
@RestController
public class RequestController {
 ? ?//原始方式
 ? ?@RequestMapping("/simpleParam")
 ? ?public String simpleParam(HttpServletRequest request){
 ? ? ? ?// http://localhost:8080/simpleParam?name=Tom&age=10
 ? ? ? ?// 请求参数: name=Tom&age=10 ? (有2个请求参数)
 ? ? ? ?// 第1个请求参数: name=Tom ? 参数名:name,参数值:Tom
 ? ? ? ?// 第2个请求参数: age=10 ? ? 参数名:age , 参数值:10
?
 ? ? ? ?String name = request.getParameter("name");//name就是请求参数名
 ? ? ? ?String ageStr = request.getParameter("age");//age就是请求参数名
?
 ? ? ? ?int age = Integer.parseInt(ageStr);//需要手动进行类型转换
 ? ? ? ?System.out.println(name+"  :  "+age);
 ? ? ? ?return "OK";
 ?  }
}

以上这种方式,我们仅做了解。(在以后的开发中不会使用到)

1.2.2 SpringBoot方式

在Springboot的环境中,对原始的API进行了封装,接收参数的形式更加简单。 如果是简单参数,参数名与形参变量名相同,定义同名的形参即可接收参数。

@RestController
public class RequestController {
 ? ?// http://localhost:8080/simpleParam?name=Tom&age=10
 ? ?// 第1个请求参数: name=Tom ? 参数名:name,参数值:Tom
 ? ?// 第2个请求参数: age=10 ? ? 参数名:age , 参数值:10
 ? ?
 ? ?//springboot方式
 ? ?@RequestMapping("/simpleParam")
 ? ?public String simpleParam(String name , Integer age ){//形参名和请求参数名保持一致
 ? ? ? ?System.out.println(name+"  :  "+age);
 ? ? ? ?return "OK";
 ?  }
}

postman测试( GET 请求):

postman测试( POST请求 ):

结论:不论是GET请求还是POST请求,对于简单参数来讲,只要保证请求参数名和Controller方法中的形参名保持一致,就可以获取到请求参数中的数据值。

1.2.3 参数名不一致

如果方法形参名称与请求参数名称不一致,controller方法中的形参还能接收到请求参数值吗?

@RestController
public class RequestController {
 ? ?// http://localhost:8080/simpleParam?name=Tom&age=20
 ? ?// 请求参数名:name
?
 ? ?//springboot方式
 ? ?@RequestMapping("/simpleParam")
 ? ?public String simpleParam(String username , Integer age ){//请求参数名和形参名不相同
 ? ? ? ?System.out.println(username+"  :  "+age);
 ? ? ? ?return "OK";
 ?  }
}

答案:运行没有报错。 controller方法中的username值为:null,age值为20

  • 结论:对于简单参数来讲,请求参数名和controller方法中的形参名不一致时,无法接收到请求数据

那么如果我们开发中,遇到了这种请求参数名和controller方法中的形参名不相同,怎么办?

解决方案:可以使用Spring提供的@RequestParam注解完成映射

在方法形参前面加上 @RequestParam 然后通过value属性执行请求参数名,从而完成映射。代码如下:

@RestController
public class RequestController {
 ? ?// http://localhost:8080/simpleParam?name=Tom&age=20
 ? ?// 请求参数名:name
?
 ? ?//springboot方式
 ? ?@RequestMapping("/simpleParam")
 ? ?public String simpleParam(@RequestParam("name") String username , Integer age ){
 ? ? ? ?System.out.println(username+"  :  "+age);
 ? ? ? ?return "OK";
 ?  }
}

注意事项:

@RequestParam中的required属性默认为true(默认值也是true),代表该请求参数必须传递,如果不传递将报错

如果该参数是可选的,可以将required属性设置为false

@RequestMapping("/simpleParam")
public String simpleParam(@RequestParam(name = "name", required = false) String username, Integer age){
System.out.println(username+ ":" + age);
return "OK";
}
文章来源:https://blog.csdn.net/qq_69748833/article/details/134960676
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。