|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
什么时候上述的三种开发工具能和三为一,什么时候java的竞争力才更强,才有机会拉拢更多的程序员投入到对java的开发上,因为到时的开发工具将会比.net网页编程的更简单。还有一点也很关键,什么时候java推出的jsf能成为真正意义上的标准。
Spring-MVC怎样利用拦阻器,官方文档只给出了非注解作风的例子。那末基于注解作风怎样利用拦阻器呢?
基于注解基础上有2个可以使用的界说类,分离是DefaultAnnotationHandlerMapping和AnnotationMethodHandlerAdapter:
<bean class="org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping"/>
<bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter"/>
1、DefaultAnnotationHandlerMapping
DefaultAnnotationHandlerMapping自己撑持自界说拦阻器,只需按以下举行设置:
1 <bean class="org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping">
2 <property name="interceptors">
3 <list>
4 <bean class="packageName.XXXInterceptor" />
5 </list>
6 </property>
7 </bean>
Interceptor的界说为:
1 public class XXXInterceptor extends HandlerInterceptorAdapter {
2 @Override
3 public boolean preHandle(HttpServletRequest req, HttpServletResponse resp, Object handler) {
4
5 String className = handler.getClass().getName();// packageName.ClassName
6 if (Error) {
7 return false;
8 }
9 return true;
10 }
11 }
2、AnnotationMethodHandlerAdapter
今朝,笔者没找到怎样给AnnotationMethodHandlerAdapter设置自界说Interceptor的办法,可是有个customArgumentResolver能够使用一下,来充任Interceptor。
1 <bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter">
2 <property name="customArgumentResolver">
3 <bean class="packageName.XXXResolver"/>
4 </property>
5 </bean>
Resolver的界说为:
1 public class XXXResolver implements WebArgumentResolver {
2
3 @Override
4 public Object resolveArgument(MethodParameter methodParameter, NativeWebRequest webRequest) throws Exception {
5
6 String className = methodParameter.getMethod().getDeclaringClass().getName();// packageName.ClassName
7
8 // 怎样获得Response和Request
9 HttpServletResponse resp = (HttpServletResponse) webRequest.getNativeResponse();
10 HttpServletRequest req = (HttpServletRequest) webRequest.getNativeRequest();
11
12 if (Error) {
13 if (!resp.isCommitted()) resp.sendError(ERROR_STATUS);
14 }
15 return UNRESOLVED;
16 }
17 }
18
细心的人会看出,第二种办法实在基本不是拦阻。实在第二种只是在映照Controller,挪用办法的时分,给每个办法的参数增添了一个切点。
上例在堕落的时分往HttpServletResponse写毛病形态,来关照web容器举行毛病重定向,到达了拦阻器的感化。
这么做有一个弱点,就是每一个参数都有本人的切点,好比办法有3个参数就会调3次resolveArgument。为了不堕落,必要判别一下resp.isCommitted。
customArgumentResolver的初志不是用来做Interceptor的,但有些情况却不能不利用它,好比部署在GAE上。
GAE是不撑持DefaultAnnotationHandlerMapping的,由于此类用到了org.springframework.beans.BeanUtils.findEditorByConvention,这个办法会挪用java.lang.ClassLoader.getSystemClassLoader,而这恰是GAE所不同意的。
PS:
文中提到软件的版本:
spring-2.5.X
googleappengine-1.2.5
java主要分三块,j2se:java的基础核心语言。j2me:java的微型模块,专门针对内存小,没有持续电源等小型设备。j2ee:java的企业模块,专门针对企业数据库服务器的连接维护。 |
|