1.创建拦截器(在执行业务前拦截实现pre方法,业务之后post,返回试图前用after)
拦截器是单例的,需要注意线程安全问题
public class LoginIntercepter extends HandlerInterceptorAdapter{
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)
throws Exception {
Calendar calendar=Calendar.getInstance();
calendar.set(Calendar.HOUR_OF_DAY, 8);
calendar.set(Calendar.MINUTE, 25);
calendar.set(Calendar.SECOND, 0);
long startTime=calendar.getTimeInMillis();
calendar.set(Calendar.HOUR_OF_DAY, 18);
long endTime=calendar.getTimeInMillis();
long nowTime=System.currentTimeMillis();
if(nowTime<=startTime||nowTime>=endTime)
{
throw new Exception("未在指定时间内登录");
}
return true;
}
}
没有xml的情况下配置
@Configuration
@ComponentScan("com.cy.pj")
@EnableWebMvc//此注解表示加载spring的默认bean
public class SpringWebConfig implements WebMvcConfigurer{
//配置静态资源处理
@Override
public void configureDefaultServletHandling(DefaultServletHandlerConfigurer configurer) {
configurer.enable();
}
//配置视图解析
@Override
public void configureViewResolvers(ViewResolverRegistry registry) {
registry.jsp("/WEB-INF/pages/", ".html");
}
@Override
public void addInterceptors(InterceptorRegistry registry) {
LoginIntercepter loginInter=new LoginIntercepter();
registry.addInterceptor(loginInter).addPathPatterns("/login");
}
}
在spring-xml中配置
<mvc:interceptors>
<mvc:interceptor>
<mvc:mapping path="/login"></mvc:mapping>
<bean class="拦截器类路径"></bean>
</mvc:interceptor>
</mvc:interceptors>
配置方式二选一