Spring @RequestMapping注解示例

在 spring mvc hello world 应用程序中,我们看到了具有端到端功能(不包括任何数据库访问)的非常基本的员工管理应用程序。 在学习spring mvc 模块的下一步中,我将提供@RequestMapping注解的一些示例,以说明如何使用@RequestMapping以不同的方式将 URL映射到控制器方法。我再次使用与 Spring MVC Hello World 应用程序相同的代码库,并使用@RequestMapping注解仅更改控制器类。

1)仅方法级别的@RequestMapping注解

在@RequestMapping注解的这种用法中,必须提供完整的路径作为value属性。例如,请看下面具有基本 CRUD 操作的控制器代码。

@Controller
public class EmployeeController 
{
	@RequestMapping("/employee-management/employees")
	public String getAllEmployees(Model model)
	{
		//application code
		return "employeesList";
	}

	@RequestMapping("/employee-management/employees/add")
	public String addEmployee(EmployeeVO employee)
	{
		//application code
		return "employeesDetail";
	}

	@RequestMapping("/employee-management/employees/update")
	public String updateEmployee(EmployeeVO employee)
	{
		//application code
		return "employeesDetail";
	}

	@RequestMapping(value={"/employee-management/employees/remove","/employee-management/employees/delete"})
	public String removeEmployee(@RequestParam("id") String employeeId)
	{
		//application code
		return "employeesList";
	}
}

如果可以将多个网址映射到单个方法,则可以将具有所有不同网址的字符串参数数组传递给value属性,例如,我们在上面的示例中针对removeEmployee()方法执行了此操作。如果您调用 URL <BASE_URL>/employee-management/employees/remove<BASE_URL>/employee-management/employees/delete

2)类级别以及方法级别的@RequestMapping注解

在上面的示例中要注意的一件事是,/ employee-management / employees是映射到所有方法的每个 URL 的一部分。 如果我们以某种共同的步伐放它,并且每种方法应该仅具有所需的标识符,那将是很好的。

这可以通过将@RequestMapping注解放在类级别和方法级别上来完成。 看下面的例子。

@Controller
@RequestMapping("/employee-management/employees/*")
public class EmployeeController 
{
	@RequestMapping
	public String getAllEmployees(Model model)
	{
		//application code
		return "employeesList";
	}

	@RequestMapping("/add")
	public String addEmployee(EmployeeVO employee)
	{
		//application code
		return "employeesDetail";
	}

	@RequestMapping("/update")
	public String updateEmployee(EmployeeVO employee)
	{
		//application code
		return "employeesDetail";
	}

	@RequestMapping(value={"/remove","/delete"})
	public String removeEmployee(@RequestParam("id") String employeeId)
	{
		//application code
		return "employeesList";
	}
}

现在,我们也在类级别应用了注解。请注意,此更改不会更改映射的行为。它们与以前完全相同。

要注意的另一件事是,第一种方法getAllEmployees()缺少 URL 值。 由于类级别使用/employee-management/employees/ URL 通配符,因此,如果没有其他与任何请求匹配的处理器,则将该处理器方法作为catch块执行。因此,任何 URL 请求(例如/employee-management/employees/list/employee-management/employees/abcd/employee-management/employees/)触发此方法。

3)仅使用 HTTP 请求类型的@RequestMapping注解

也有可能在类级别上只有一个@RequestMapping注解,而在方法级别上您没有指定 URL 值。 只需指定 HTTP 请求类型,即可将每种不同的 http 类型映射到不同的方法。 这种设计在 RESTFul Web 服务 中非常流行。

@Controller
@RequestMapping("/employee-management/employees")
public class EmployeeController 
{
	@RequestMapping (method =  RequestMethod.GET)
	public String getAllEmployees(Model model)
	{
		//application code
		return "employeesList";
	}

	@RequestMapping (method =  RequestMethod.POST)
	public String addEmployee(EmployeeVO employee)
	{
		//application code
		return "employeesDetail";
	}

	@RequestMapping (method =  RequestMethod.PUT)
	public String updateEmployee(EmployeeVO employee)
	{
		//application code
		return "employeesDetail";
	}

	@RequestMapping (method =  RequestMethod.DELETE)
	public String removeEmployee(@RequestParam("id") String employeeId)
	{
		//application code
		return "employeesList";
	}
}

请注意,在此示例代码中,将使用相同的 URL 访问所有方法,但使用不同的 http 请求类型。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值