SpringMVC——注解配置SpringMVC

注解配置SpringMVC

本文要介绍用注解方式代替web.xml与SpringMVC的配置文件

一、注解web.xml文件

实现步骤

(1)创建初始化配置类

创建一个初始化配置类,继承AbstractAnnotationConfigDispatcherServletInitializer,重写里面的三个方法。第一个方法getRootConfigClasses获取spring指定的配置类,用来返回spring配置类的一个数组;第二个方法getServletConfigClasses获取springMVC指定的配置类,用来返回springMVC配置类的一个数组;第三个方法getServletMappings指定DispatcherServlet的映射路径,就是设置url-pattern,返回的是url-pattern配置的值。

public class WebInit extends AbstractAnnotationConfigDispatcherServletInitializer {

    /**
     * 指定spring配置类
     * @return
     */
    @Override
    protected Class<?>[] getRootConfigClasses() {
        return new Class[]{SpringConfig.class};
    }

    /**
     * 指定SpringMVC的配置类
     * @return
     */
    @Override
    protected Class<?>[] getServletConfigClasses() {
        return new Class[]{SpringMvcConfig.class};
    }

    /**
     * 指定DispatcherServlet的映射路径
     * @return
     */
    @Override
    protected String[] getServletMappings() {
        return new String[]{"/"};
    }
}

web.xml里面还有一些其他的配置:

(2)注册过滤器

我们在SpringMVC前面的学习中用到了两个过滤器,一个是编码过滤器,处理中文乱码问题;还有一个HiddenHttpMethodFilter过滤器,可以处理PUT和DELETE请求。在web.xml中配置如下:

<!--    编码过滤器-->
    <filter>
        <filter-name>CharacterEncodingFilter</filter-name>
        <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
        <init-param>
            <param-name>encoding</param-name>
            <param-value>UTF-8</param-value>
        </init-param>
        <init-param>
            <param-name>forceResponseEncoding</param-name>
            <param-value>true</param-value>
        </init-param>
        <init-param>
            <param-name>forceRequestEncoding</param-name>
            <param-value>true</param-value>
        </init-param>
    </filter>
    <filter-mapping>
        <filter-name>CharacterEncodingFilter</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>

    <!--    配置处理请求方式为PUT和DELETE的HiddenHttpMethodFilter过滤器-->
    <filter>
        <filter-name>HiddenHttpMethodFilter</filter-name>
        <filter-class>org.springframework.web.filter.HiddenHttpMethodFilter</filter-class>
    </filter>
    <filter-mapping>
        <filter-name>HiddenHttpMethodFilter</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>

用配置类也可以配置过滤器,只需要重写getServletFilters,注册对应的过滤器并返回就好了

    /**
     * 配置过滤器
     * @return
     */
    @Override
    protected Filter[] getServletFilters() {
//        配置编码过滤器
        CharacterEncodingFilter characterEncodingFilter = new CharacterEncodingFilter();
        characterEncodingFilter.setEncoding("utf-8");
        characterEncodingFilter.setForceRequestEncoding(true);
        characterEncodingFilter.setForceResponseEncoding(true);
//        配置处理请求方式为PUT和DELETE的HiddenHttpMethodFilter过滤器
        HiddenHttpMethodFilter hiddenHttpMethodFilter = new HiddenHttpMethodFilter();
        return new Filter[]{characterEncodingFilter,hiddenHttpMethodFilter};
    }

2、注解SpringMVC配置文件的配置类

springMVC配置文件里面有许多的配置,都可以通过这一个配置类来实现,具体配置有:

  • 组件扫描配置
  • thymeleaf视图解析器
  • view-controller 视图解析器
  • 开启静态资源配置
  • MVC注解驱动
  • 文件上传解析器
  • 异常处理器
  • 拦截器
    下面一一介绍配置类如何实现以上配置

(1)组件扫描注解

这里的组件扫描注解和spring里面的一样,在类上面加上@ComponentScan就可以,代表spring会将该类扫描到容器中。
等价于:

<!--    组件扫描-->
    <context:component-scan base-package="com.cx"></context:component-scan>

(2)开启SpringMVC 注解驱动

注解驱动配置是在类上面添加@EnableWebMvc注解。
等价于:

<!--    开启mvc注解驱动-->
    <mvc:annotation-driven></mvc:annotation-driven>

(3)开启静态资源配置

下面的方法要先实现WebMvcConfigurer接口

//    配置开启静态资源
    @Override
    public void configureDefaultServletHandling(DefaultServletHandlerConfigurer configurer) {
        configurer.enable();
    }

等价于:

<!--    开放对静态资源的访问-->
    <mvc:default-servlet-handler></mvc:default-servlet-handler>

(4)配置拦截器

配置拦截器需要定义好拦截器,然后在注册,最后添加。我自己写了一个拦截器TestInterceptor 。addPathPatterns()方法是配置拦截路径,excludePathPatterns()方法是排除拦截路径。

//    配置拦截器
    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        TestInterceptor testInterceptor = new TestInterceptor();
        registry.addInterceptor(testInterceptor).addPathPatterns("/*");
        registry.addInterceptor(testInterceptor).excludePathPatterns("/");
    }

等价于:

    <mvc:interceptors>
        <mvc:interceptor>
            <mvc:mapping path="/*"/>
            <mvc:exclude-mapping path="/"/>
            <ref bean="testInterceptor"></ref>
        </mvc:interceptor>
    </mvc:interceptors>

(5)配置ViewController视图解析器

//    配置ViewController视图解析器
    @Override
    public void addViewControllers(ViewControllerRegistry registry) {
        registry.addViewController("/").setViewName("index");
    }

等价于:

<!--    配置视图解析器-->
    <mvc:view-controller path="/" view-name="index"></mvc:view-controller>

(6)配置文件上传解析器

//    配置文件上传解析器
    @Bean
    public MultipartResolver multipartResolver(){
        CommonsMultipartResolver commonsMultipartResolver = new CommonsMultipartResolver();
        return commonsMultipartResolver;
    }

等价于:

<!--    配置文件上传解析器,将上传的文件封装成MultipartFile-->
    <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"></bean>

(7)配置异处理器

//    配置异常处理器
    @Override
    public void extendHandlerExceptionResolvers(List<HandlerExceptionResolver> resolvers) {
        SimpleMappingExceptionResolver simpleMappingExceptionResolver = new SimpleMappingExceptionResolver();
        Properties properties = new Properties();
        properties.setProperty("java.lang.ArithmeticException","error");
        simpleMappingExceptionResolver.setExceptionMappings(properties);
        simpleMappingExceptionResolver.setExceptionAttribute("ex");
        resolvers.add(simpleMappingExceptionResolver);
    }

等价于:

<!--    配置异常处理器-->
    <bean class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver">
        <property name="exceptionMappings">
            <props>
                <prop key="java.lang.ArithmeticException">error</prop>
            </props>
        </property>
        <property name="exceptionAttribute" value="ex"></property>
    </bean>
  • 9
    点赞
  • 45
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
Spring MVC中使用Redis注解配置需要进行以下步骤: 1. 添加Redis依赖:在项目的pom.xml文件中添加Redis依赖,例如使用Jedis客户端: ```xml <dependency> <groupId>redis.clients</groupId> <artifactId>jedis</artifactId> <version>3.6.0</version> </dependency> ``` 2. 配置Redis连接信息:在Spring配置文件中配置Redis连接信息,包括主机、端口、密码等。可以使用JedisConnectionFactory来配置连接,例如: ```xml <bean id="jedisConnectionFactory" class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory"> <property name="hostName" value="localhost" /> <property name="port" value="6379" /> <property name="password" value="yourPassword" /> </bean> ``` 3. 配置RedisTemplate:配置RedisTemplate来操作Redis数据,例如: ```xml <bean id="redisTemplate" class="org.springframework.data.redis.core.RedisTemplate"> <property name="connectionFactory" ref="jedisConnectionFactory" /> <property name="keySerializer" ref="stringRedisSerializer" /> <property name="valueSerializer" ref="stringRedisSerializer" /> </bean> <bean id="stringRedisSerializer" class="org.springframework.data.redis.serializer.StringRedisSerializer" /> ``` 4. 在需要使用Redis的类或方法上添加注解:使用Spring提供的注解来操作Redis数据,例如: ```java @RestController public class RedisController { @Autowired private RedisTemplate<String, String> redisTemplate; @RequestMapping("/get/{key}") public String get(@PathVariable String key) { return redisTemplate.opsForValue().get(key); } @RequestMapping("/set/{key}/{value}") public void set(@PathVariable String key, @PathVariable String value) { redisTemplate.opsForValue().set(key, value); } } ``` 在上述示例中,使用`@Autowired`注解将RedisTemplate注入到Controller中,然后使用`opsForValue()`方法来进行操作。 这就是使用注解配置Spring MVC中的Redis。当然,你也可以使用其他客户端来操作Redis,只需要相应地配置连接和使用对应的方法即可。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我没得冰阔落.

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值