MySQL, Oracle, Linux, 软件架构及大数据技术知识分享平台

网站首页 > 精选文章 / 正文

《若依ruoyi》第十九章:SpringBoot基础之控制层Controller详解

2025-01-26 22:37 huorong 精选文章 3 ℃ 0 评论

1、请求URL详解

我们在实际的开发当中,一个控制器中不一定只有一个方法,而这些方法都是用来处理请求的,那么怎样才能将请求与处理方法一一对应呢,当然是通过 RequestMapping 注解来处理这些映射请求,也就是通过它来指定控制器可以处理哪些URL请求。

@RequestMapping

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

1.@RequestMapping可以标注的位置

1.1 标注在方法上

用于方法上,表示在类的父路径下追加方法上注解中的地址将会访问到

该方法

@Controller
public class RequestMappingController {
  @RequestMapping("/testRequest")
	public String testRequest(){
  	return "success";
  }
}

此时请求映射所映射的请求的请求路径为:
http://http://localhost:8080/springmvc_study02/testRequest

注意:springmvc_study02是项目名称

1.2 标注在类和方法上

用于类上,表示类中的所有响应请求的方法都是以该地址作为父路径。

@Controller
@RequestMapping(“/hello”)
public class RequestMappingController {
  @RequestMapping("/testRequest")
  public String testRequest(){
  	return "success";
  }
}

此时请求映射所映射的请求的请求路径为:
http://localhost:8080/springmvc_study02/hello/testRequest

注意:当你在类上添加RequestMapping注解后,如果要请求映射,就意味着请求要先映射到标注类的位置,然后再映射到该类的方法上。如果不加就会出现如下错误

2. @RequestMapping的属性

我们可以先查看一下源码:按住Ctrl键,鼠标点击RequestMapping注解就可以看到下面的界面

在源码中我们可以看到@RequestMapping的所有属性,那么接下来就一起看一看这些属性

2.1 @RequestMapping的value属性*

@RequestMapping 的 value 属性必须设值;

@RequestMapping 的 value 属性是通过当前请求的请求地址来匹配请求;

从上面的源码中可以看到value属性是一个字符串类型的数组,因此说明可以将多个请求映射到一个方法上,只需要给 value 来指定一个包含多个路径的数组。

设置value属性的值:

@Controller
public class RequestMappingController {
  @RequestMapping(value = {"/testRequest","/test"})
  public String testRequest(){
  	return "success";
  }
}

在浏览器中输入下面路径进行测试:

注意:从上面两张图我们能够看到,这时的请求映射所映射的请求的请求路径为选择value数组中的任意一个都可以。

2.2 @RequestMapping的method属性*

@RequestMapping的method属性是通过当前请求的请求方式来匹配请求;

浏览器向服务器发送请求,请求方式有很多GET、HEAD、POST、PUT、PATCH、DELETE、OPTIONS、TRACE。可以使用 method 属性来约束请求方式。

设置请求方式为get:

@Controller
public class RequestMappingController {
@RequestMapping(value = "/testRequest",method = RequestMethod.GET)
  public String testRequest(){
 	 return "success";
  }
}

以post方式请求:

请求结果:

注意:我们在@RequestMapping注解里加一个方法限定:method = RequestMethod.GET,则请求必须是get的,否则就会发生以上的错误。

映射方法中明确要求请求方式为get,所以post方式不被允许,只有修改为get,才能够请求成功,如果要想两种方式都支持,只需在@RequestMapping注解的method属性中添加另一种方式即可,中间用英文逗号隔开。

扩展:

@GetMapping:处理get方式请求的映射

@PostMapping:处理post方式请求的映射

@PutMapping:处理put方式请求的映射

@DeleteMapping:处理delete方式请求的映射

@GetMapping就相当于@RequestMapping(method=RequestMethod.GET),它会将get映射到特定的方法上。

使用方式:@GetMapping(value = "/testRequest")

2.3 @RequestMapping的params属性

@RequestMapping的params属性是通过当前请求的请求参数来匹配请求;

@RequestMapping的params属性是一个字符串类型的数组,可以通过下面四种表达是来设置匹配关系

“param”:要求请求映射的请求必须为包含 param的请求参数

“!param”:要求请求映射的请求是不能包含param的请求参数

“param=value”:要求请求映射的请求必须包含 param 的请求参数,且 param 参数的值必须为 value

“param!=value”: 要求请求映射的请求是必须包含 param 的请求参数,其值不能为 value。

设置params的属性值为username:

@RequestMapping(value = "/test",params = "username")
public String test(){
	return "success";
}

请求结果:

注意:我们设置了params属性,就意味着该请求映射的请求必须包含username才能够请求成功。

当我们传入参数用
http://localhost:8080/springmvc_study02/test?username路径来访问,我们来看看结果:

当给params属性设置多个属性值时,必须同时满足才能够请求成功,否则会出现下面的错误

2.4 @RequestMapping的headers属性

@RequestMapping的headers属性是通过当前请求的请求头信息来匹配请求;

@RequestMapping的headers属性是一个字符串类型的数组,可以通过下面四种表达是来设置匹配关系

“header”:要求请求映射的请求必须为包含 header的请求头信息

“!header”:要求请求映射的请求必须为不包含 header的请求头信息

“header=value”:要求请求映射的请求必须为包含 header的请求头信息,并且header的值必须为value

“header!=value”:要求请求映射的请求必须为包含 header的请求头信息,并且header的值必须不是value

设置请求头信息:

@RequestMapping(value = "/test",headers = "Host = localhost:8081")
public String test(){
	return "success";
}

2、若依GenController类说明

该类在Ruoyi-generator模块里面

路径:package
com.ruoyi.generator.controller;

  • @RestController注解,相当于@ResponseBody@Controller
  • Spring 4.0引入了@RestController,这是一个控制器的专用版本,它是一个方便的注释。

通过使用@RestController批注对控制器类进行注释,您不再需要将@ResponseBody添加到所有请求映射方法中。@ResponseBody注释默认处于活动状态。

说明它同时拥有这2注解的功能,@Controller注解表示后,该类将会被spring管理,@ResponseBody注解标识后,响应数据可以是文本或者JSON数据类型。所以这里我们return map的时候,可以直接输出JSON数据。当然@RestController注解属于springmvc的,并不属于springboot的。

@RestController
@RequestMapping("/tool/gen")
/**
 * 查询代码生成列表
 */
@PreAuthorize("@ss.hasPermi('tool:gen:list')")
@GetMapping("/list")
public TableDataInfo genList(GenTable genTable)
{
    startPage();
    List list = genTableService.selectGenTableList(genTable);
    return getDataTable(list);
}

通过上面两个代码片段,GenController被spring接管,作为接口,返回json数据格式,其中

RequestMapping表示请求的url地址是/tool/gen,通过这个地址就可以定位GenController类进行处理,

GenController类下面的函数@GetMapping("/list"),调用这个函数需要在get的请求下调用。

那么我们可以理解,我们目标是通过url地址来调用指定的genList方法,那么我们就要先使用get的方法,先找到GenController(找到该类的url:/tool/gen),在找到GenController下面的genList函数(找到该函数的url是:list),那么我们拼接起来的最终url地址是/tool/gen/list

@Autowired
private IGenTableService genTableService;
@Autowired
private IGenTableColumnService genTableColumnService;

@Autowired可以标注在属性上、方法上和构造器上,来完成自动装配。默认是根据属性类型,spring自动将匹配到的属性值进行注入,然后就可以使用这个属性(对
Springboot02WebApplicationTests类来说)autoWiredBean对象的方法。

  • 使用方法

它可以标注在属性上、方法上和构造器上,那有什么区别吗?简单来说因为类成员的初始化顺序不同,静态成员 ——> 变量初始化为默认值——>构造器——>为变量赋值。如果标注在属性上,则在构造器中就不能使用这个属性(对象)的属性和方法。

入上述代码片段,将genTableService(实现数据库表的增删改查询),genTableColumnService自动装配。

3、未来计划

1、ruoyi非分离版本拆解

2、ruoyi-vue-pro:讲解工作流

3、ruoyi-vue-pro:支付模块,电商模块

4、基于ruoyi-vue-pro项目开发

5、JEECG低代码开发平台

请关注我,本星球会持续推出更多的开源项目代码解析,如有更好的意见请留言回复或者私信。

Tags:th:action

控制面板
您好,欢迎到访网站!
  查看权限
网站分类
最新留言