java - Spring 安全: Form login special characters

标签 java spring spring-security

我在使用 Spring Security 表单登录时需要解决问题的帮助。表单登录将带有转义特殊字符的用户名发送到服务器,但 spring 不会转义此参数并且在数据库中找不到用户。

我使用自定义 UserDetailsS​​ervice 但用户名参数包含 scape 特殊字符。可以转义特殊字符吗?

我正在尝试对特殊字符进行转义,但更改失败。

数据: - Spring 3.1.1.发布 - Spring安全3.1.1.发布 - Tomcat 7.X

编辑:

我认为通过将 enconding 过滤器放入 web.xml 文件中可以解决问题。

<filter>
    <filter-name>encodingFilter</filter-name>
    <filter-class>
        org.springframework.web.filter.CharacterEncodingFilter
    </filter-class>
    <init-param>
        <param-name>encoding</param-name>
        <param-value>UTF-8</param-value>
    </init-param>
    <init-param>
        <param-name>forceEncoding</param-name>
        <param-value>true</param-value>
    </init-param>
</filter>
<filter-mapping>
    <filter-name>encodingFilter</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>

最佳答案

您不必做任何复杂的事情,只需使用设置的标准字符串

 <form name="f" id="f" action="<c:url value='/j_spring_security_check'/>" method="POST">
   <label for="j_username">E-mail :&nbsp;</label><input type='text' id='j_username' name='j_username'/><br/>
   <label for="j_password">Password :&nbsp;</label><input type='password' id='j_password' name='j_password'><br>

关于java - Spring 安全: Form login special characters,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15880366/

相关文章:

java - java中如何在函数返回之前等待某个回调方法被调用?

mysql - Hibernate:在删除父集合时不删除子集合

java - Null GrantedAuthority 获取 Spring Security 的 UserDetails

java - 运行 servlet 显示错误

java - 在 PHP 中编码 base64 和在 Java 中解码 base64 的问题

java - 创建名称为 'projectingArgumentResolverBeanPostProcessor' 的 bean 时出错

spring-security - BadCredentialsException 预期,但得到 AccountExpiredException

java - 在 Spring 中,如何将自定义参数自动填充到 web @Controller 方法?

java - 在 Java 中调用 Oracle 存储过程时遇到问题

java - Spring MVC - 使用 java 为 Controller 创建 httprequest