0

アプリにセキュリティを実装しようとしています:

次のように web.xml を使用するアプリケーションがあります。

<web-app>
<display-name>myapp</display-name>

<servlet>
    <servlet-name>tmodel</servlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    <load-on-startup>1</load-on-startup>
</servlet>

<servlet-mapping>
    <servlet-name>tmodel</servlet-name>
    <url-pattern>/tm/*</url-pattern>
</servlet-mapping>
</web-app>

そして、ここに私の *-servlet.xml があります:

<context:annotation-config />
<context:component-scan base-package="net.nls"/>

<bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter">
    <property name="webBindingInitializer">
        <!-- Configures Spring MVC DataBinder instances -->
        <bean class="org.springframework.web.bind.support.ConfigurableWebBindingInitializer">
            <property name="validator" ref="validator" />
        </bean>
    </property>
</bean>

<bean id="jacksonMessageConverter" class="org.springframework.http.converter.json.MappingJacksonHttpMessageConverter"/>

<!-- Creates the JSR-303 Validator -->
<bean id="validator" class="org.springframework.validation.beanvalidation.LocalValidatorFactoryBean" />


<bean id="beansConfiguration" class="net.nls.tm.config.BeansConfiguration"/>

<bean id="jmsFactory" class="org.apache.activemq.pool.PooledConnectionFactory"
      destroy-method="stop">
    <property name="connectionFactory">
        <bean id="cf" class="org.apache.activemq.ActiveMQConnectionFactory"
              p:brokerURL="tcp://localhost:61616"
              p:useAsyncSend="true"
                />
    </property>
</bean>

<!-- Spring JMS Template -->
<bean id="myJmsTemplate" class="org.springframework.jms.core.JmsTemplate">
    <property name="connectionFactory">
        <ref local="jmsFactory"/>
    </property>
</bean>

<task:annotation-driven executor="myExecutor" scheduler="myScheduler"/>
<task:executor id="myExecutor" pool-size="50"/>
<task:scheduler id="myScheduler" pool-size="10"/>

<bean id="viewResolver"
      class="org.springframework.web.servlet.view.UrlBasedViewResolver">
    <property name="viewClass" value="org.springframework.web.servlet.view.JstlView"/>
    <property name="prefix" value="/jsp/"/>
    <property name="suffix" value=".jsp"/>
</bean>

春のセキュリティ ドキュメント バージョン 3.2 を見たとき、指示の 1 つは次を追加することでした。

<filter>
    <filter-name>springSecurityFilterChain</filter-name>
    <filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class>
</filter>

<filter-mapping>
    <filter-name>springSecurityFilterChain</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>

そして、これを私の *-servlet.xml に追加しました

<http auto-config='true'>
    <intercept-url pattern="/**" access="ROLE_USER" />
</http>

<authentication-manager>
    <authentication-provider>
        <user-service>
            <user name="jimi" password="jimispassword" authorities="ROLE_USER, ROLE_ADMIN" />
            <user name="bob" password="bobspassword" authorities="ROLE_USER" />
        </user-service>
    </authentication-provider>
</authentication-manager>

アプリをコンパイルして実行すると、次の例外が発生しました。

java.lang.IllegalStateException: No WebApplicationContext found: no ContextLoaderListener registered?
org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:251)

ウェブを検索すると、人が追加されていることがわかりました

    <listener>
    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>

そして、すべてが機能しなくなりました。

なにが問題ですか?私がこの問題を解決するにはどうすればよいですか?

*-servlet.xml 内でフィルターを移動できますか? はいの場合、どのように?

4

1 に答える 1

0

*-servlet.xmlにリスナーを追加したようです。

   <listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>

web.xmlへ

于 2013-02-07T05:05:52.863 に答える