apache shiro: authc.loginUrl не работает - PullRequest
1 голос
/ 17 августа 2010

Я настроил Широ следующим образом:

        [main]



        [users]

        ...

        [roles]

        ...

        [urls]

        /welcome.xhtml = anon
        /overview.xhtml = authc

Как вы можете себе представить, "welcome.xhtml" содержит мою форму входа. Если я не авторизован в приложении и пытаюсь получить доступ к Overview.xhtml, меня выдает «login.jsp», которого нет в моем приложении!

Далее, если я добавлю следующее:

authc.loginUrl = /welcome.xhtml

к основной части конфигурации сиро я получаю эту ошибку, запустив tomcat:

ERROR: Exception starting filter SecurityFilter
java.lang.NoClassDefFoundError: org/apache/commons/beanutils/PropertyUtils
    at org.apache.shiro.config.ReflectionBuilder.isTypedProperty(ReflectionBuilder.java:241)
    at org.apache.shiro.config.ReflectionBuilder.applyProperty(ReflectionBuilder.java:349)
    at org.apache.shiro.config.ReflectionBuilder.applySingleProperty(ReflectionBuilder.java:200)
    at org.apache.shiro.config.ReflectionBuilder.applyProperty(ReflectionBuilder.java:161)
    at org.apache.shiro.config.ReflectionBuilder.buildObjects(ReflectionBuilder.java:121)
    at org.apache.shiro.config.IniSecurityManagerFactory.buildInstances(IniSecurityManagerFactory.java:171)
    at org.apache.shiro.config.IniSecurityManagerFactory.createSecurityManager(IniSecurityManagerFactory.java:120)
    at org.apache.shiro.config.IniSecurityManagerFactory.createSecurityManager(IniSecurityManagerFactory.java:98)
    at org.apache.shiro.config.IniSecurityManagerFactory.createInstance(IniSecurityManagerFactory.java:84)
    at org.apache.shiro.config.IniSecurityManagerFactory.createInstance(IniSecurityManagerFactory.java:42)
    at org.apache.shiro.config.IniFactorySupport.createInstance(IniFactorySupport.java:124)
    at org.apache.shiro.util.AbstractFactory.getInstance(AbstractFactory.java:48)
    at org.apache.shiro.web.servlet.IniShiroFilter.applySecurityManager(IniShiroFilter.java:353)
    at org.apache.shiro.web.servlet.IniShiroFilter.configure(IniShiroFilter.java:321)
    at org.apache.shiro.web.servlet.IniShiroFilter.init(IniShiroFilter.java:292)
    at org.apache.shiro.web.servlet.AbstractShiroFilter.onFilterConfigSet(AbstractShiroFilter.java:83)
    at org.apache.shiro.web.servlet.AbstractFilter.init(AbstractFilter.java:94)
    at org.apache.catalina.core.ApplicationFilterConfig.getFilter(ApplicationFilterConfig.java:295)
    at org.apache.catalina.core.ApplicationFilterConfig.setFilterDef(ApplicationFilterConfig.java:422)
    at org.apache.catalina.core.ApplicationFilterConfig.<init>(ApplicationFilterConfig.java:115)
    at org.apache.catalina.core.StandardContext.filterStart(StandardContext.java:4001)
    at org.apache.catalina.core.StandardContext.start(StandardContext.java:4651)
    at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1045)
    at org.apache.catalina.core.StandardHost.start(StandardHost.java:785)
    at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1045)
    at org.apache.catalina.core.StandardEngine.start(StandardEngine.java:445)
    at org.apache.catalina.core.StandardService.start(StandardService.java:519)
    at org.apache.catalina.core.StandardServer.start(StandardServer.java:710)
    at org.apache.catalina.startup.Catalina.start(Catalina.java:581)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:597)
    at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:289)
    at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:414)
Caused by: java.lang.ClassNotFoundException: org.apache.commons.beanutils.PropertyUtils
    at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1645)
    at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1491)
    ... 35 more

Здесь моя ошибка? веселит ...


MAVEN POM PART:

    <dependency>
        <groupId>org.apache.shiro</groupId>
        <artifactId>shiro-core</artifactId>
        <version>1.0.0-incubating</version>
    </dependency>
    <dependency>
        <groupId>org.apache.shiro</groupId>
        <artifactId>shiro-web</artifactId>
        <version>1.0.0-incubating</version>
    </dependency>
    <dependency>
        <groupId>org.apache.shiro</groupId>
        <artifactId>shiro-aspectj</artifactId>
        <version>1.0.0-incubating</version>
    </dependency>

1 Ответ

5 голосов
/ 17 августа 2010

Если вы используете конфигурацию Shini .ini, он использует Apache Commons Beanutils 1.7 (или более позднюю версию). Этот jar должен находиться в пути к классу вашего приложения во время выполнения.

Если вы используете Maven 2, зависимость будет автоматически включена (если кто-то явно не исключил ее из вашего POM). Если вы не используете Maven 2, вы можете скачать его здесь:

http://repo2.maven.org/maven2/commons-beanutils/commons-beanutils/1.7.0/

<dependency>
    <groupId>commons-beanutils</groupId>
    <artifactId>commons-beanutils</artifactId>
    <version>1.7</version>
</dependency>
...