常用springmvc注解,spring注解和springmvc的注解
目录
春季手动音量调节注解配置方式一、创建初始化类二、春天的配置类三、WebConfig配置类剩余配置
SpringMVC注解配置方式
使用配置类和注解代替web.xml和学习笔记一配置文件的功能。
一、创建初始化类
在Servlet3.0环境中,容器会在类路径中查找实现javax。servlet。servletcontainerinitializer接口的类,如果找到的话就用它来配置小型应用程序容器。
弹簧提供了这个接口的实现,名为SpringServletContainerInitializer,这个类反过来又会查找实现WebApplicationInitializer的类并将配置的任务交给它们来完成。
春天3.2引入了一个便利的WebApplicationInitializer基础实现,名为abstranationconfigdispatcherservletinitializer,当我们的类扩展了abstrannationconfigdispatcherservletinitializer并将其部署到Servlet3.0容器的时候,容器会自动发现它,并用它来配置小型应用程序上下文。
这里新建一个工程来演示。
pom.xml里的依赖可以复制之前的内容,web.xml和学习笔记一已经不需要再进行创建了。
包com。平果。MVC。配置;导入org。spring框架。网络。过滤器。字符编码过滤器;导入org。spring框架。网络。过滤器。hiddenhttpmethodfilter导入组织。spring框架。网络。servlet。支持。abstractannotationconfigdispatcherservletinitializer;导入javax。servlet。过滤器;公共类WebInit扩展abstrannationconfigdispatcherservletinitializer {/* * *指定弹簧的配置类* @ return */@覆盖受保护的类?[]getrootconfigclass(){ return new Class[]{ spring config。class };} /** * 指定学习笔记一的配置类* @ return */@覆盖受保护的类?[]getServletConfigClasses(){ return new Class[]{ webconfig。class };} /** * 指定前端控制器的映射规则,即URL-pattern * @ return */@ Override protected String[]getServletMappings(){ return new String[]{ / };} /** * 添加过滤器* @ return */@ Override protected Filter[]getServletFilters(){ character encoding Filter encoding Filter=new character encoding Filter();编码过滤器。设置编码(“UTF-8”);编码过滤器。setforcerequestencoding(true);HiddenHttpMethodFilter HiddenHttpMethodFilter=new HiddenHttpMethodFilter();返回新筛选器[]{encodingFilter,hiddenHttpMethodFilter };}}初始化类里面要指定弹簧的配置类、SpringMVC的配置类,给创建出来即可,记得带上@配置注解,标记为配置类。
其实就是把之前各种配置文件里的内容转到配置类里了,这些都会在项目启动时候
初始化。另外,返回的都是数组,所以每个类里都可以返回多个配置。
二、spring的配置类
当使用ssm整合之后,spring的配置信息写在spring的配置类中,这里暂时用不到,写出来无妨。
package com.pingguo.mvc.config;import org.springframework.context.annotation.Configuration;@Configurationpublic class SpringConfig {}
三、WebConfig 配置类
这个配置类是代替之前 springMVC.xml 配置文件里的内容:
扫描组件视图解析器view-controllerdefault-servlet-handlermvc注解驱动文件上传解析器异常处理拦截器
// 标识当前类为配置类@Configuration// 扫描组件@ComponentScan("com.pingguo.mvc")// mvc 注解驱动@EnableWebMvcpublic class WebConfig { //配置生成模板解析器 @Bean public ITemplateResolver templateResolver() { WebApplicationContext webApplicationContext = ContextLoader.getCurrentWebApplicationContext(); // ServletContextTemplateResolver需要一个ServletContext作为构造参数,可通过WebApplicationContext 的方法获得 ServletContextTemplateResolver templateResolver = new ServletContextTemplateResolver( webApplicationContext.getServletContext()); templateResolver.setPrefix("/WEB-INF/templates/"); templateResolver.setSuffix(".html"); templateResolver.setCharacterEncoding("UTF-8"); templateResolver.setTemplateMode(TemplateMode.HTML); return templateResolver; } //生成模板引擎并为模板引擎注入模板解析器 @Bean public SpringTemplateEngine templateEngine(ITemplateResolver templateResolver) { SpringTemplateEngine templateEngine = new SpringTemplateEngine(); templateEngine.setTemplateResolver(templateResolver); return templateEngine; } //生成视图解析器并未解析器注入模板引擎 @Bean public ViewResolver viewResolver(SpringTemplateEngine templateEngine) { ThymeleafViewResolver viewResolver = new ThymeleafViewResolver(); viewResolver.setCharacterEncoding("UTF-8"); viewResolver.setTemplateEngine(templateEngine); return viewResolver; }}
有了这几样,就可以写一个index页面测试一下了,写出页面和controller类。
<!DOCTYPE html><html lang="en" xmlns:th="http://www.thymeleaf.org"><head> <meta charset="UTF-8"> <title>index首页</title></head><body><h1>首页</h1></body></html>
控制器:
@Controllerpublic class TestController { @RequestMapping("/") public String index() { return "index"; }}
设置下部署,启动可以打开首页。
剩余配置
接下来,需要 WebConfig 类实现一个接口WebMvcConfigurer,来重写里面的方法。
配置 default-servlet-handler
@EnableWebMvcpublic class WebConfig implements WebMvcConfigurer { //使用默认的servlet处理静态资源 default-servlet-handler public void configureDefaultServletHandling(DefaultServletHandlerConfigurer configurer) { configurer.enable(); }... ...
配置 拦截器
继续增加。
... ... //配置拦截器 public void addInterceptors(InterceptorRegistry registry) { TestInterceptor firstInterceptor = new TestInterceptor(); registry.addInterceptor(firstInterceptor).addPathPatterns("/**"); }... ...
拦截器还是要像之前的那样创建,这里就创建了一个拦截器 TestInterceptor :
public class TestInterceptor implements HandlerInterceptor { public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { return true; } public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception { } public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception { }}
配置 view-controller
当仅做视图跳转时候可以使用这个配置。
//配置视图控制 public void addViewControllers(ViewControllerRegistry registry) { registry.addViewController("/").setViewName("index"); }
配置文件上传解析器
... ... //配置文件上传解析器 @Bean public MultipartResolver multipartResolver(){ CommonsMultipartResolver commonsMultipartResolver = new CommonsMultipartResolver(); return commonsMultipartResolver; }... ...
配置异常处理
//配置异常映射 public void configureHandlerExceptionResolvers(List<HandlerExceptionResolver> resolvers) { SimpleMappingExceptionResolver exceptionResolver = new SimpleMappingExceptionResolver(); Properties prop = new Properties(); prop.setProperty("java.lang.ArithmeticException", "error"); //设置异常映射 exceptionResolver.setExceptionMappings(prop); //设置共享异常信息的键 exceptionResolver.setExceptionAttribute("ex"); resolvers.add(exceptionResolver); }
里面的功能与之前使用配置文件实现的一样,可以逐一测试一下。
以上就是SpringMVC使用注解配置方式的详细内容,更多关于SpringMVC注解配置的资料请关注盛行IT其它相关文章!
郑重声明:本文由网友发布,不代表盛行IT的观点,版权归原作者所有,仅为传播更多信息之目的,如有侵权请联系,我们将第一时间修改或删除,多谢。