Springmvc @RequestMapping测试各种访问方式

配置视图解析器



package com.kute.controller;

import java.util.List;

import org.springframework.stereotype.Controller;
import org.springframework.ui.ModelMap;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.ResponseBody;

import com.order.domain.AllOrderInfoBean;
import com.order.util.JsonUtils;
import com.tgb.entity.User;

@Controller
@RequestMapping("/test")
//这里也可以写成@RequestMapping("/test.do")也可以不写,因为在web.xml中配置了*.do
public class TestController {
	
	@RequestMapping(params="method=addUser")
	public String addUser(User user){
		System.out.println("dddddddddd");
		return "success";
	}
	
	@RequestMapping(value="/test0")//默认为get方式
	public String test0(){
		System.out.println("访问路径:test/test0.do");
		return "success";
	}

	@RequestMapping(value="/test1",method=RequestMethod.POST)
	public String test1(String sex){
		System.out.println(sex);
		System.out.println("访问路径为:test/test1.do,而且是get方式______"+sex);
		return "success";
	}
	
	@RequestMapping(value="/test2",method=RequestMethod.GET,params="param=test2")
	public String test2(){
		System.out.println("访问路径为:test/test1.do?param=test2,而且是get方式");
		return "success";
	}
	
	//REST风格的参数
	@RequestMapping(value="/test3/{name}")
	public String test3(@PathVariable String name){//形参和接收参数的名称一致
		System.out.println(name);
		System.out.println("访问路径为:test/test3/zhangsan.do");
		System.out.println("看这里的访问路径,直接就将‘zhangsan’这个参数值就传递给了@RequestMapping(value=\"/test3/{name}\")中的name参数名,可随意命名参数名称,");
		return "success";
	}
	
	@RequestMapping(value="/test5/{name}")
	public String test5(@PathVariable("name")String rename){//形参和接收参数的名称不一致
		System.out.println(rename);
		System.out.println("访问路径为:test/test5/zhangsan.do");
		System.out.println("看这里的访问路径,直接就将‘zhangsan’这个参数值就传递给了@RequestMapping(value=\"/test5/{name}\")中的name参数名,可随意命名参数名称," +
				"然后后面的@PathVariable(\"name\")中的name名称要和上面的那个name保持一致,然后把此name绑定到形参rename");
		return "success";
	}
	
	@RequestMapping(value="/test4/{sex}/{sno}")
	//这里我写成@RequestMapping(value="test4/{sex}/{sno}")也是可以滴
	public String test4(@PathVariable("sex")String sex,@PathVariable("sno")String sno){
		System.out.println(sex);
		System.err.println(sno);
		System.out.println("访问路径:test/test4/male/10506.do");
		return "success";
	}
	
	//支持正则
	@RequestMapping(value="/test6/{textualPart:[a-z-]+}.{numericPart:[\\d]+}")
	public String test6(@PathVariable String textualPart,@PathVariable String numericPart){
		System.out.println(textualPart);//输出sometxt
		System.out.println(numericPart);//输出123
		System.out.println("访问路径:test/test6/sometxt.123.do");
		return "success";
	}
	
	//访问WEB-INF下的views文件中的不同目录的页面,这里访问的是user目录下的,不知道其他有什么好的办法没
	@RequestMapping(value="/test7")
	public String test7(){
		System.out.println("访问路径:test/test7.do");
		return "user/success";
	}
	
	//重定向到另一个controller
	@RequestMapping(value="/test8")
	public String test8(){
		System.out.println("访问路径:test/test8.do");
		return "redirect:/OrderInfo/queryOrderInfo.do";
	}
	
	//随时添加所需参数
	@RequestMapping(value="/test9")
	public String test9(HttpServletResponse response){
		System.out.println("访问路径:test/test9.do,这里我需要一个response,所以直接在形参上写上即可");
		return "user/success";
	}
	
	//ajax:添加@ResponseBody注解
	@RequestMapping(method = RequestMethod.GET, value = "/test10")
	public @ResponseBody
	String getEndTimeFBeginTime(@PathVariable("roomId") String roomId,
			@PathVariable("dtime") String dtime,
			@PathVariable("beginTime") String beginTime, ModelMap model) {
		List<AllOrderInfoBean> endList = userService.getEndTimeFBeginTime(
				roomId, dtime, beginTime);
		model.put("endList", endList);//这里的model相当于session
		return JsonUtils.toJson(endList);//ajax返回的数据
	}
	
}


最后复制下原理:原文:http://blog.csdn.net/xtu_xiaoxin/article/details/8796499

Spring MVC工作流程图

图一


图二 


Spring工作流程描述
      1. 用户向服务器发送请求,请求被Spring 前端控制Servelt DispatcherServlet捕获;
      2.  DispatcherServlet对请求URL进行解析,得到请求资源标识符(URI)。然后根据该URI,调用HandlerMapping获得该Handler配置的所有相关的对象(包括Handler对象以及Handler对象对应的拦截器),最后以HandlerExecutionChain对象的形式返回;
      3.  DispatcherServlet 根据获得的Handler,选择一个合适的HandlerAdapter。(附注:如果成功获得HandlerAdapter后,此时将开始执行拦截器的preHandler(...)方法
       4.  提取Request中的模型数据,填充Handler入参,开始执行Handler(Controller)。 在填充Handler的入参过程中,根据你的配置,Spring将帮你做一些额外的工作:
      HttpMessageConveter: 将请求消息(如Json、xml等数据)转换成一个对象,将对象转换为指定的响应信息
      数据转换:对请求消息进行数据转换。如String转换成Integer、Double等
      数据根式化:对请求消息进行数据格式化。 如将字符串转换成格式化数字或格式化日期等
      数据验证: 验证数据的有效性(长度、格式等),验证结果存储到BindingResult或Error中
      5.  Handler 执行完成后,向DispatcherServlet 返回一个ModelAndView对象;
      6.  根据返回的ModelAndView,选择一个适合的ViewResolver(必须是已经注册到Spring容器中的 ViewResolver)返回给DispatcherServlet ;
      7.  ViewResolver 结合Model和View,来渲染视图
      8. 将渲染结果返回给客户端。

Spring工作流程描述
     为什么Spring只使用一个Servlet(DispatcherServlet)来处理所有请求?
     详细见J2EE设计模式-前端控制模式
    Spring为什么要结合使用HandlerMapping以及HandlerAdapter来处理Handler?
    符合面向对象中的单一职责原则,代码架构清晰,便于维护,最重要的是代码可复用性高。如HandlerAdapter可能会被用于处理多种Handler。

二、实验步骤 1、创建Maven项目并添加SpringMVC依赖 2、在web.xml中配置DispatcherServlet 3、创建Controller类并添加@RequestMapping注解 4、编写业务逻辑方法 5、使用@RequestParam,@RequestBody,@ResponseBody,@PathVariable注解获取请求参数或返回结果 6、启动Tomcat服务器并测试 三、实验代码 1、pom.xml文件中添加SpringMVC依赖 ```xml <dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> <version>5.2.9.RELEASE</version> </dependency> ``` 2、web.xml中配置DispatcherServlet ```xml <servlet> <servlet-name>springmvc</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <init-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:applicationContext.xml</param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>springmvc</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping> ``` 3、Controller类中添加@RequestMapping注解 ```java @Controller @RequestMapping("/user") public class UserController { @RequestMapping(value="/add", method=RequestMethod.POST) @ResponseBody public String addUser(@RequestBody User user){ System.out.println("添加用户:"+user.getName()); return "success"; } @RequestMapping(value="/{id}", method=RequestMethod.GET) @ResponseBody public User getUser(@PathVariable int id){ User user = new User(id, "张三", 20); return user; } @RequestMapping(value="/list", method=RequestMethod.GET) public ModelAndView getUserList(){ List<User> userList = new ArrayList<User>(); userList.add(new User(1, "张三", 20)); userList.add(new User(2, "李四", 22)); userList.add(new User(3, "王五", 24)); ModelAndView mav = new ModelAndView(); mav.addObject("userList", userList); mav.setViewName("userList"); return mav; } } ``` 4、编写业务逻辑方法 ```java public class User { private int id; private String name; private int age; //getter和setter方法省略 } ``` 5、使用@RequestParam,@RequestBody,@ResponseBody,@PathVariable注解获取请求参数或返回结果 ```java @Controller @RequestMapping("/user") public class UserController { @RequestMapping(value="/add", method=RequestMethod.POST) @ResponseBody public String addUser(@RequestBody User user){ System.out.println("添加用户:"+user.getName()); return "success"; } @RequestMapping(value="/{id}", method=RequestMethod.GET) @ResponseBody public User getUser(@PathVariable int id){ User user = new User(id, "张三", 20); return user; } @RequestMapping(value="/list", method=RequestMethod.GET) public ModelAndView getUserList(){ List<User> userList = new ArrayList<User>(); userList.add(new User(1, "张三", 20)); userList.add(new User(2, "李四", 22)); userList.add(new User(3, "王五", 24)); ModelAndView mav = new ModelAndView(); mav.addObject("userList", userList); mav.setViewName("userList"); return mav; } } ``` 6、启动Tomcat服务器并测试 访问http://localhost:8080/user/list,可以看到用户列表页面。 访问http://localhost:8080/user/1,可以看到id为1的用户信息。 使用Postman发送POST请求,提交用户信息到http://localhost:8080/user/add。 四、实验总结 通过本次实验,我们学习了SpringMVC的基本使用方法,包括了配置DispatcherServlet、编写Controller类、使用注解获取请求参数或返回结果等。掌握了这些基本知识后,可以更好地进行后续的开发工作。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值