MVC 注解式开发即处理器基于注解的类开发, 对于每一个定义的处理器, 无需在 xml 中注册.
只需在代码中通过对类与方法的注解, 即可完成注册.
定义处理器
@Controller: 当前类为处理器
@RequestMapping: 当前方法为处理器方法, 方法名随意, 对于请求进行处理与响应.
- @Controller
- public class MyController {@RequestMapping(value = "/hello.do")
- public ModelAndView doControl(HttpServletRequest request,
- HttpServletResponse response) {
- ModelAndView mv = new ModelAndView();
- mv.addObject("message", "执行方法");
- mv.setViewName("welcome, neil!");
- return mv;
- }
- }
可以在 RequestMapping 对请求进行限制, 例如
1 @RequestMapping(value="/hello.do", params={"name=neil", "!age"}, method=RequestMethod.POST)
method=RequestMethod.POST 限定提交类型为 POST
params={"name=neil", "!age"} 限定请求中必须携带参数 name, 值为 neil, 不可以携带参数 age
接受请求参数
如果请求中参数名与处理器方法参数名一致, 那么可以直接获取.
- @RequestMapping(value="/hello.do")
- public ModelAndView doControll(String name, int age) {
- System.out.println("Name :" + name + ", Age:" + age);
- ModelAndView mv = new ModelAndView();
- return mv;
- }
如果参数名不一致, 则需要通过 @RequestParam 进行定位.
@RequestParam 有三个属性
name / value: 指定请求参数的名称.
required: 参数是否必须, 若为 false, 则表示参数有没有均可.
defaultValue: 请求中没有携带参数时, 指定当前参数默认值.
1 doControll(@RequestParam(name = "username") String name, @RequestParam(name = "userage") int age)
路径变量 @PathVariable
对处理器方法中的参数, 可以来自于请求携带的参数, 也可以来自于 URI 中的变量, 即路径变量.
与上述正常参数一样, 如果路径变量名与接收其值的参数名不一致, 则需要通过参数指出路径变量名称.
如下所示, 注意 username 与 name, age 与 age.
- @RequestMapping(value="/{username}/{age}/hello.do")
- public ModelAndView doControll(@PathVariable("username") String name, @RequestParam int age) {
- System.out.println("Name :" + name + ", Age:" + age);
- ModelAndView mv = new ModelAndView();
- return mv;
- }
处理器方法返回值
使用 @Controller 注解的处理器, 其方法返回值常用的有如下四种:
- ModelAndView
- Void
Object, 自定义类型对象
String
1, 返回 ModelAndView
处理器方法完成后, 需要跳转到其他资源, 且需要在跳转的资源之间传递数据, 则返回 ModelAndView 即可.
- public ModelAndView doControll(){
- ModelAndView modelAndView = new ModelAndView();
- // 传递的数据
- modelAndView.addObject("name", "neil");
- modelAndView.setViewName("/user.do");
- return modelAndView;
- }
2, 返回 Void
请求处理后, 无需跳转, 可以放处理器返回 void, 例如 Ajax 异步请求响应.
如果需要跳转, 也可以通过操作 ServletAPI 进行 sendRedirect 或者 forward.
3, 返回 Object
处理器可以返回 Object 对象, 此时不是作为逻辑视图出现的, 而是直接在页面展示数据用的.
返回 Object 对象, 需要使用 @ResponseBody 注解, 将转换后的 JSON 数据放入响应体重.
- @RequestMapping(value="/hello.do")
- @ResponseBody
- public ModelAndView doControll() {
- return new Student("neil", 998);
- }
前端获取到数据
- FR.ajax({
- url: "hello.do",
- complete: function(data) {
- alert(data.name + " " + data.age);
- }
- })
同样, 也可以返回集合 List, Map 等等.
- @RequestMapping(value="/hello.do")
- @ResponseBody
- public ModelAndView doControll() {
- List<Student> list = new ArrayList<Student>();
- list.add(new Student("a", 11));
- list.add(new Student("b", 22));
- list.add(new Student("c", 33));
- return list;
- }
- FR.ajax({
- url: "hello.do",
- complete: function(data) {
- $(data).each(function(index)) {
- alert(data[index].name + data[index].age);
- }
- }
- })
4, 返回 String
返回字符串可能有以下三种场景:
逻辑视图名
Redirect 重定向
Forward 转发
逻辑视图名
处理器返回的字符串可以指定逻辑视图名, 通过视图解析器解析将其转为物理视图地址.
最终真实的访问路径 = 前缀 + 逻辑视图名 + 后缀
如果不指定前后缀, 也可以直接返回物理视图名, 如
1 return "/web-INF/admin/welcome.jsp"
Redirect 重定向
1 return "redirect:/admin/next.action";
相当于 response.sendRedirect(), 转发后浏览器的地址栏变为转发后的地址.
由于新发起一个 request, 原来的参数在转发时就不能传递到下一个 url,
如果要传参数可以在 url 后边拼接参数 & a=1&b=2
Forward 转发
1 return "forward:/admin/forward.action";
相当于 request.getRequestDispatcher().forward(request,response), 转发后浏览器地址栏还是原来的地址
转发并没有执行新的 request 和 response, 而是和转发前的请求共用一个 request 和 response.
参数可以直接复用转发前的.
来源: https://www.cnblogs.com/xdecode/p/8614735.html