Spring MVC注解式开发使用详解

 更新时间:2018年03月21日 10:28:58   作者:大道方圆  
本篇文章主要介绍了Spring MVC注解式开发使用详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

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有三个属性

  1. name / value: 指定请求参数的名称.
  2. required: 参数是否必须, 若为false, 则表示参数有没有均可.
  3. 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注解的处理器, 其方法返回值常用的有如下四种:

  1. ModelAndView
  2. Void
  3. Object, 自定义类型对象
  4. 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

返回字符串可能有以下三种场景:

  1. 逻辑视图名
  2. Redirect重定向
  3. 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.

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

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

相关文章

  • Netty分布式编码器写buffer队列逻辑剖析

    Netty分布式编码器写buffer队列逻辑剖析

    这篇文章主要介绍了Netty分布式编码器写buffer队列逻辑剖析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-03-03
  • 解析rainbond以应用为中心的架构设计原理

    解析rainbond以应用为中心的架构设计原理

    这篇文章主要为大家介绍了rainbond以应用为中心的架构设计实现及原理解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-02-02
  • Spring Security权限管理实现接口动态权限控制

    Spring Security权限管理实现接口动态权限控制

    这篇文章主要为大家介绍了Spring Security权限管理实现接口动态权限控制,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-06-06
  • java实现多线程交替打印

    java实现多线程交替打印

    这篇文章主要为大家详细介绍了java实现多线程交替打印,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-11-11
  • springboot 事件监听的实现方法

    springboot 事件监听的实现方法

    这篇文章主要介绍了springboot 事件监听的实现方法,并详细的介绍了四种监听方式,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-04-04
  • Java泛型类型通配符和C#对比分析

    Java泛型类型通配符和C#对比分析

    下面小编就为大家带来一篇Java泛型类型通配符和C#对比分析。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-10-10
  • RxJava的消息发送和线程切换实现原理

    RxJava的消息发送和线程切换实现原理

    这篇文章主要介绍了RxJava的消息发送和线程切换实现原理,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-11-11
  • Springboot引入拦截器并放行swagger代码实例

    Springboot引入拦截器并放行swagger代码实例

    这篇文章主要介绍了Springboot引入拦截器并放行swagger代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-11-11
  • 基于Listener监听器生命周期(详解)

    基于Listener监听器生命周期(详解)

    下面小编就为大家带来一篇基于Listener监听器生命周期(详解)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-10-10
  • 熟练掌握Java8新特性之Stream API的全面应用

    熟练掌握Java8新特性之Stream API的全面应用

    Stream是Java8的一大亮点,是对容器对象功能的增强,它专注于对容器对象进行各种非常便利、高效的 聚合操作(aggregate operation)或者大批量数据操作。Stream API借助于同样新出现的Lambda表达式,极大的提高编程效率和程序可读性,感兴趣的朋友快来看看吧
    2021-11-11

最新评论