@FeignClient中的@RequestMapping也被SpringMVC加载的问题解决

简介: @FeignClient中的@RequestMapping也被SpringMVC加载的问题解决

问题描述

在之前发布《Spring Cloud实战小贴士:Feign的继承特性(伪RPC模式)》一文中,我们介绍了如果使用Feign的继承特性来完成服务的提供以及服务的消费,实现了类似RPC的编程模式。但是,仔细一些的读者可能已经发现一个问题:当我们将服务消费者运行起来的时候,定义在服务提供方的那些请求映射关系也被加载到了服务消费者中,这就会带来两个问题:

  • 由于服务消费者并不提供这些接口,对于开发者来说容易造成误解
  • 由于加载了一些外部服务的接口定义,还存在与自身接口定义冲突的潜在风险

问题分析

那么这些外部请求接口定义是如何被加载到消费端的呢?我们先来看看Spring MVC处理请求映射的RequestMappingHandlerMapping实现片段:

@Override
protected boolean isHandler(Class<?> beanType) {
  return (AnnotatedElementUtils.hasAnnotation(beanType, Controller.class) ||
      AnnotatedElementUtils.hasAnnotation(beanType, RequestMapping.class));
}

我们可以发现如上的这段实现,该函数用来判断是否要处理请求映射的判断依据。从实现中我们看到,只要被扫描的类包含了@Controller注解或@RequestMapping注解,那么就会被加载进来。虽然@FeignClient定义修饰的服务消费端没有声明这些注解,但是当我们使用了继承特性的时候,那么这些注解就也会被服务消费者解析和加载,所以出现了上面所描述的现象。

解决方法

既然已经找到了问题所在,那么我们可以针对性的扩展处理:扩展RequestMappingHandlerMappingisHandler函数。

@Configuration
@ConditionalOnClass({Feign.class})
public class FeignConfiguration {
    @Bean
    public WebMvcRegistrations feignWebRegistrations() {
        return new WebMvcRegistrationsAdapter() {
            @Override
            public RequestMappingHandlerMapping getRequestMappingHandlerMapping() {
                return new FeignRequestMappingHandlerMapping();
            }
        };
    }
    private static class FeignRequestMappingHandlerMapping extends RequestMappingHandlerMapping {
        @Override
        protected boolean isHandler(Class<?> beanType) {
            return super.isHandler(beanType) &&
                    !AnnotatedElementUtils.hasAnnotation(beanType, FeignClient.class);
        }
    }
}

如上实现的isHandler函数继承了原来的实现,同时增加了一个条件:不能被@FeignClient注解修饰的类才会进行解析加载。

相关阅读

目录
相关文章
|
8月前
|
Java Spring
SpringMVC中bean的加载控制
SpringMVC中bean的加载控制
51 0
|
XML 存储 前端开发
解析 SpringMVC 父子容器及九大内置组件加载过程
解析 SpringMVC 父子容器及九大内置组件加载过程
126 1
|
小程序 Java 程序员
SpringMVC bean加载控制 -- SpringMVC快速入门保姆级教程(二)
SpringMVC bean加载控制 -- SpringMVC快速入门保姆级教程(二)
SpringMVC何时加载的controller里的mapping方法
疑问 其实我一直有一个疑问,因为我在跟自己写的controller的生命周期源码的时候,没有发现解析mapping的代码,然后我就在想,什么时候解析并加载的mapping呢??? 结果是一个新的类 RequestMappingHandlerMapping ,惊呆了,我的小伙伴
108 0
|
Java 应用服务中间件 Maven
|
Java Spring
SpringMVC的bean的加载及控制
SpringMVC的bean的加载及控制
125 0
|
Java Spring
Spring整合SpringMVC时避免Spring加载两次bean的配置方法
Spring整合SpringMVC时避免Spring加载两次bean的配置方法
|
Java 数据库连接 网络架构
SpringMVC加载配置Properties文件的几种方式
SpringMVC加载配置Properties文件的几种方式 最近开发的项目使用了SpringMVC的框架,用下来感觉SpringMVC的代码实现的非常优雅,功能也非常强大, 网上介绍Controller参数绑定、URL映射的文章都很多了,写这篇博客主要总结一下SpringMVC加载配置Properties文件的几种方式 1.
3514 0
|
Java 数据格式 容器
利用spring的ApplicationListener实现springmvc容器的初始化加载
1、我们在使用springmvc进行配置的时候一般初始化都是在web.xml里面进行的,但是自己在使用的时候经常会测试一些数据,这样就只有加载spring-mvc.xml的配置文件来实现。为了更方便的使用注解,而不影响具体的实现效果,我今天看到了一个初始化的方式,就是实现ApplicationListener接口 2、导包pom.
1329 0