java - 将 Spring MVC 安全定向更改为登录

标签 java spring spring-security

我正在尝试使用 Spring 的安全包。默认情况下,当定向到根 URL 时,安全 Controller 将接管并显示 login.html 页面。

我想要的是一个带有“登录”选项的漂亮登陆页面,该选项将显示 login.html。

我怎样才能改变这种行为。我对 Spring 很陌生。

我的拦截配置为:

<http auto-config="true" use-expressions="true">
    <intercept-url pattern="/assets/css/**" access="isAnonymous()"/>
    <intercept-url pattern="/assets/js/**" access="isAnonymous()"/>
    <intercept-url pattern="/assets/img/**" access="isAnonymous()"/>
    <intercept-url pattern="/header.html" access="isAnonymous() or hasRole('ROLE_USER')"/>
    <intercept-url pattern="/welcome.html" access="isAnonymous() or hasRole('ROLE_USER')"/>
    <intercept-url pattern="/login.html" access="isAnonymous()"/>
    <intercept-url pattern="/loginFailed.html" access="isAnonymous()"/>
    <intercept-url pattern="/logout.html" access="hasRole('ROLE_USER')"/>
    <intercept-url pattern="/403.html" access="isAnonymous()"/>
    <intercept-url pattern="/**" access="hasRole('ROLE_USER')"/>
    <form-login login-page="/login.html" authentication-failure-url="/loginFailed.html"/>
    <logout logout-success-url="/logout.html"/>
    <access-denied-handler error-page="/403.html"/>
</http>

web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">

    <context-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>
            classpath:/jpaContext.xml
            /WEB-INF/config/security-config.xml
        </param-value>
    </context-param>

    <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>

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

    <filter>
        <filter-name>SpringOpenEntityManagerInViewFilter</filter-name>
        <filter-class>org.springframework.orm.jpa.support.OpenEntityManagerInViewFilter</filter-class>
    </filter>

    <servlet>
        <servlet-name>myServlet</servlet-name>
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
        <init-param>
            <param-name>contextConfigLocation</param-name>
            <param-value>/WEB-INF/config/servlet-config.xml</param-value>
        </init-param>
    </servlet>

    <servlet-mapping>
        <servlet-name>myServlet</servlet-name>
        <url-pattern>*.html</url-pattern>
    </servlet-mapping>

    <servlet-mapping>
        <servlet-name>myServlet</servlet-name>
        <url-pattern>/pdfs/**</url-pattern>
    </servlet-mapping>

    <servlet-mapping>
        <servlet-name>myServlet</servlet-name>
        <url-pattern>/images/**</url-pattern>
    </servlet-mapping>

    <servlet-mapping>
        <servlet-name>myServlet</servlet-name>
        <url-pattern>*.json</url-pattern>
    </servlet-mapping>

    <display-name>Archetype Created Web Application</display-name>
</web-app>

最佳答案

更改isAnonymous()permitAll - 否则登录后您可能会得到一些奇怪的结果。

尤其要记住让 Web 应用程序的根目录保持可访问 - 这可能就是您立即重定向到登录页面的原因。

例如 <intercept-url pattern="/" access="permitAll" />

哦,改变这个<intercept-url pattern="/**" access="hasRole('ROLE_USER')"/>

<intercept-url pattern="/**" access="denyAll" />

这确保默认情况下一切都是安全的,然后您必须通过 PermitAll、hasRole 或 isAuthenticated() 显式授予权限。否则,登录用户可以访问您未手动保护的所有内容,这可能是一个明显的安全风险。

一旦根目录和登录页面设置为 permitAll然后,您可以自由设置自己的登录页面,用户可以选择登录,而不是像目前的情况一样立即被迫这样做。

关于java - 将 Spring MVC 安全定向更改为登录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29216866/

相关文章:

java - 升级到 TIBCO TRA 5.7.4 (JRE 1.6.0_30) 后 SQL Server JDBC 连接超时

java - Tomcat更改javascript文件无需重启服务器

java - 关于为多个项目设置maven的建议

java - 如何仅加载配置文件特定的属性文件并忽略默认的 application.properties?

grails - 我如何在 Spring Security Grails 上自定义/登录/验证?

java - Spring中的模块集成和安全

java - Android 多个通知只显示最后一个

java - Soundcloud Flash Widget,尝试播放页面上的下一首歌曲

java - 持久化xml文件与spring boot等效的java配置

Spring Security OAuth2,它决定了安全性?