Grails 3.2.0.M2 весеннее исключение безопасности при запуске приложения

Я добавил следующее в build.gradle, чтобы добавить пружинную зависимость безопасности в мой проект

compile 'org.grails.plugins:spring-security-core:3.1.1'

Но когда я запускаю свое приложение, я получаю следующее исключение

ERROR org.springframework.boot.SpringApplication - Application startup failed
org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'grailsApplicationPostProcessor' defined in workspace.Application: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [grails.boot.config.GrailsApplicationPostProcessor]: Factory method 'grailsApplicationPostProcessor' threw exception; nested exception is java.lang.NoClassDefFoundError: grails/plugin/springsecurity/ControllerMixin
    at org.springframework.beans.factory.support.ConstructorResolver.instantiateUsingFactoryMethod(ConstructorResolver.java:599)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateUsingFactoryMethod(AbstractAutowireCapableBeanFactory.java:1123)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1018)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:510)
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:482)
    at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:306)
    at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:230)
    at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:302)
    at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:202)
    at org.springframework.context.support.PostProcessorRegistrationDelegate.invokeBeanFactoryPostProcessors(PostProcessorRegistrationDelegate.java:120)
    at org.springframework.context.support.AbstractApplicationContext.invokeBeanFactoryPostProcessors(AbstractApplicationContext.java:681)
    at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:523)
    at org.springframework.boot.context.embedded.EmbeddedWebApplicationContext.refresh(EmbeddedWebApplicationContext.java:122)
    at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:759)
    at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:369)
    at org.springframework.boot.SpringApplication.run(SpringApplication.java:313)
    at grails.boot.GrailsApp.run(GrailsApp.groovy:55)
    at grails.boot.GrailsApp.run(GrailsApp.groovy:374)
    at grails.boot.GrailsApp.run(GrailsApp.groovy:363)
    at grails.boot.GrailsApp$run.call(Unknown Source)
    at org.codehaus.groovy.runtime.callsite.CallSiteArray.defaultCall(CallSiteArray.java:48)
    at org.codehaus.groovy.runtime.callsite.AbstractCallSite.call(AbstractCallSite.java:113)
    at org.codehaus.groovy.runtime.callsite.AbstractCallSite.call(AbstractCallSite.java:133)
    at workspace.Application.main(Application.groovy:8)

Я использую JDK 8 в качестве моего SDK.

2 ответа

Решение

Похоже, вы не настроили плагин. Вам необходимо настроить плагин в вашем application.yml Например:

grails:
  plugin:
    springsecurity:
      userLookup.usernamePropertyName: 'usernameProperty'
      userLookup.userDomainClassName: 'com.yourProject.User'
      userLookup.authorityJoinClassName: 'com.yourProject.UserRole'
      authority.className: 'com.yourProject.Role'
      password:
        algorithm: bcrypt
        encodeHashAsBase64: true
        bcrypt.logrounds: 4
      rejectIfNoRule: true
      successHandler.defaultTargetUrl: /
      controllerAnnotations:
      staticRules:
        - pattern: '/**'
          access: ['permitAll']

Также вам нужны классы com.yourProject.User, com.yourProject.UserRole и com.yourProject.Role. Базовая конфигурация может быть создана с помощью скрипта q2-quickstart:

grails s2-quickstart com.yourProject User Role

Здесь вы можете найти очень хорошие документы - http://grails-plugins.github.io/grails-spring-security-core/

Другая причина этой ошибки:

Вы должны использовать это:

скомпилировать «org.grails.plugins: spring-security-core: 3.1.2»

а НЕ это:

реализация 'org.grails.plugins:spring-security-core:3.1.2' .

* Gradle: 3.4.1, Grails: 3.2.13

Другие вопросы по тегам