控制台异常如下:
org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'securityAspect': Unsatisfied dependency expressed through field 'userService'; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'userService': Unsatisfied dependency expressed through field 'maintenanceCertificateService'; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'maintenanceCertificateServiceImpl': Unsatisfied dependency expressed through field 'maintenanceEmployeeService'; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'maintenanceEmployeeServiceImpl': Unsatisfied dependency expressed through field 'alicloudClient'; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'org.springframework.boot.autoconfigure.web.servlet.WebMvcAutoConfiguration$EnableWebMvcConfiguration': Unsatisfied dependency expressed through method 'setConfigurers' parameter 0; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'MVCConfig': Unsatisfied dependency expressed through field 'requestInterceptor'; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'requestInterceptor': Unsatisfied dependency expressed through field 'sessionServcie'; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'sessionServiceImpl': Unsatisfied dependency expressed through field 'roleService'; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'roleServiceImpl': Unsatisfied dependency expressed through field 'maintenanceCompanyService'; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'maintenanceCompanyServiceImpl': Unsatisfied dependency expressed through field 'userApplyService'; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'userApplyServiceImpl': Unsatisfied dependency expressed through field 'residentialDistrictService'; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'residentialDistrictServiceImpl': Unsatisfied dependency expressed through field 'liftService'; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'liftServiceImpl': Unsatisfied dependency expressed through field 'iotDeviceService'; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'iotDeviceServiceImpl': Unsatisfied dependency expressed through field 'restService'; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'restServiceImpl': Unsatisfied dependency expressed through field 'alicloudClient'; nested exception is org.springframework.beans.factory.BeanCurrentlyInCreationException: Error creating bean with name 'com.myhexin.platform.service.feign.AlicloudClient': Requested bean is currently in creation: Is there an unresolvable circular reference?
首先,从最后一句可以发现这是一个Spring循环依赖的问题。但是我已经设置了SpringBoot允许循环依赖。没想到这里还会报这个错。
spring.main.allow-circular-references: true
从控制台异常可以发现,这里的创建bean的链路是这样的。
securityAspect-->userService-->maintenanceCertificateServiceImpl-->maintenanceEmployeeServiceImpl-->alicloudClient-->WebMvcAutoConfiguration-->MVCConfig-->requestInterceptor→sessionServiceImpl-->roleServiceImpl-->maintenanceCompanyServiceImpl-->userApplyServiceImpl-->residentialDistrictServiceImpl-->liftServiceImpl-->iotDeviceServiceImpl-->restServiceImpl-->alicloudClient
所以很明显,这是个循环依赖
这里我奇怪的是,为什么创建alicloudClient的Bean时会需要先创建WebMvcAutoConfiguration?
这个先按下不表。
这里我的解决方案是:
让SecurityAspect这个类延迟加载,也就是添加@Lazy注解到该类上。
因为SecurityAspect这个类是一切罪恶的源头。