Spring MVC注解式开发使用详解

时间:2021-05-20

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对请求进行限制, 例如

复制代码 代码如下:@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: 请求中没有携带参数时, 指定当前参数默认值.
  • 复制代码 代码如下: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转发
  • 逻辑视图名

    处理器返回的字符串可以指定逻辑视图名, 通过视图解析器解析将其转为物理视图地址.

    最终真实的访问路径=“前缀”+逻辑视图名+“后缀”

    如果不指定前后缀, 也可以直接返回物理视图名, 如

    return "/WEB-INF/admin/welcome.jsp"

    Redirect重定向

    return "redirect:/admin/next.action";

    相当于response.sendRedirect(),转发后浏览器的地址栏变为转发后的地址.

    由于新发起一个request,原来的参数在转发时就不能传递到下一个url,

    如果要传参数可以在url后边拼接参数&a=1&b=2

    Forward转发

    return "forward:/admin/forward.action";

    相当于request.getRequestDispatcher().forward(request,response), 转发后浏览器地址栏还是原来的地址。

    转发并没有执行新的request和response,而是和转发前的请求共用一个request和response.

    参数可以直接复用转发前的.

    以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

    声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

    相关文章