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对请求进行限制, 例如
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: 请求中没有携带参数时, 指定当前参数默认值.
路径变量@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.
参数可以直接复用转发前的.
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
推荐阅读
-
详解使用Spring AOP和自定义注解进行参数检查
-
Spring MVC项目中log4J和AOP使用详解
-
Spring boot中PropertySource注解的使用方法详解
-
详解Spring Data JPA使用@Query注解(Using @Query)
-
详解使用Spring AOP和自定义注解进行参数检查
-
详解Spring mvc ant path的使用方法
-
Spring+Spring MVC+Mybatis 框架整合开发(半注解半配置文件)
-
详解Spring Data JPA使用@Query注解(Using @Query)
-
Spring mvc 分步式session的实例详解
-
Spring MVC注解式开发使用详解