SpringMVC12 - 基于注解配置SpringMVC

注解配置SpringMVC

使用配置类和注解代替web.xml和SpringMVC配置文件的功能

创建初始化类,代替web.xml

在Servlet3.0环境中,容器会在类路径中查找实现 javax.servlet.ServletContainerInitializer 接口的类,如果找到的话就用它来配置 Servlet容器 == web.xml的功能

Spring提供了这个接口的实现,名为 SpringServletContainerInitializer,这个类反过来又会查找实现 WebApplicationInitializer 的类并将配置的任务交给它们来完成。

Spring3.2引入了一个便利的 WebApplicationInitializer 基础实现

名为 AbstractAnnotationConfigDispatcherServletInitializer

继承该类并部署到 TOMCAT中 == 代替 web.xml

当我们的类扩展了 AbstractAnnotationConfigDispatcherServletInitializer 并将其部署到Servlet3.0容器的时候容器会自动发现它,并用它来配置Servlet上下文。

public class WebInit extends AbstractAnnotationConfigDispatcherServletInitializer {
    @Override
    // 1.设置配置类,代替spring的配置文件
    protected Class<?>[] getRootConfigClasses() {
        return new Class[]{SpringConfig.class};
    }

    @Override
    // 2.设置配置类,代替springMVC的配置文件
    protected Class<?>[] getServletConfigClasses() {
        return new Class[]{WebConfig.class};
    }

    @Override
    // 3.设置SpringMVC的前端控制器 DispatcherServlet的 url-pattern
    protected String[] getServletMappings() {
        return new String[]{"/"};
    }

    @Override
    //Ctrl+o 查看可以重写的抽象方法
    // 4.设置当前的过滤器
    protected Filter[] getServletFilters() {
        //创建编码过滤器 CharacterEncodingFilter
        CharacterEncodingFilter characterEncodingFilter = new CharacterEncodingFilter();
        characterEncodingFilter.setEncoding("UTF-8");
        characterEncodingFilter.setForceEncoding(true);

        //创建处理请求方式的过滤器 HiddenHttpMethodFilter
        HiddenHttpMethodFilter hiddenHttpMethodFilter = new HiddenHttpMethodFilter();

        return new Filter[] {characterEncodingFilter, hiddenHttpMethodFilter};
    }
}

创建SpringConfig配置类,代替spring的配置文件

@Configuration //将类标识位配置类
public class SpringConfig {
    //SSM整合后,spring的配置文件写在此类中
}

创建WebConfig配置类,代替SpringMVC的配置文件

代替 SpringMVC的配置文件 springmvc.xml 的内容:

扫描组件、视图解析器、默认的Servlet处理静态资源、mvc的注解驱动、视图控制器、文件上传解析器、拦截器、异常解析器

@Configuration
@ComponentScan("com.zzz.controller")   // 1.扫描组件
@EnableWebMvc   // 4.开启mvc的注解驱动
public class WebConfig implements WebMvcConfigurer {

    @Override       // 3.默认的Servlet处理静态资源
    public void configureDefaultServletHandling(DefaultServletHandlerConfigurer configurer) {
        configurer.enable(); //开启默认的Servlet
    }

    @Override
    public void addViewControllers(ViewControllerRegistry registry) {
        // 5.视图控制器,所有 "/" 请求都直接跳转到 逻辑视图 "index"
        registry.addViewController("/").setViewName("index");
    }

    //如何在类中配置 bean -- 方法的返回值为 bean的类型
    @Bean // 该注解可以将方法的返回值作为 bean进行管理,bean的id就是方法名
    public CommonsMultipartResolver multipartResolver(){
        // 6.文件上传解析器
        return new CommonsMultipartResolver();
    }

    @Override
    public void addInterceptors(InterceptorRegistry registry) {

        // 7.拦截器
        FirstInterceptor firstInterceptor = new FirstInterceptor();
        //拦截除了 /test 外的所有请求
        registry.addInterceptor(firstInterceptor).addPathPatterns("/**").excludePathPatterns("/test");
    }

    @Override
    public void configureHandlerExceptionResolvers(List<HandlerExceptionResolver> resolvers) {

        // 8.异常解析器
        SimpleMappingExceptionResolver exceptionResolver = new SimpleMappingExceptionResolver();
        Properties properties = new Properties();
        // properties中,key = 处理的异常, value = 跳转的页面的逻辑视图
        properties.setProperty("java.lang.ArithmeticException","error");
        exceptionResolver.setExceptionMappings(properties);
        exceptionResolver.setExceptionAttribute("ex");
        resolvers.add(exceptionResolver);
    }


    // 2.Thymeleaf 视图解析器 固定格式
    //配置生成模板解析器
    @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;
    }
}
posted @   LaViez  阅读(38)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· PowerShell开发游戏 · 打蜜蜂
· 在鹅厂做java开发是什么体验
· 百万级群聊的设计实践
· WPF到Web的无缝过渡:英雄联盟客户端的OpenSilver迁移实战
· 永远不要相信用户的输入:从 SQL 注入攻防看输入验证的重要性
点击右上角即可分享
微信分享提示