0

我相信我已经为我的 Spring Security 完成了所有必要的设置以使用 Unicode,但是在使用内存中身份验证时,它不适用于在用户名中包含特殊 Unicode 字符。由于 Spring 声称具有内部化支持,当使用 Unicode 字符作为用户名时,这可能是 Spring Security In-Memory 的一个错误吗?请放心,我已经查阅了参考手册、论坛帖子(例如,如何在 SPRING MVC POJO 的字段中保存日语字符),并且已经完成了设置 Spring 国际化所需的所有事情。但是,我在使用 Unicode/特殊字符匹配 Spring Security 3 In-Memory 用户名时遇到问题。请注意,我的应用程序、IDE 和文件使用 UTF-8,如果我不这样做,一切看起来都很好,而且一切都很好对用户名使用特殊的 Unicode 字符。我有一种感觉,Unicode 用户名的这种不匹配可能是 Spring Security In-Memory 内部化的一个错误,但需要确认这一点,或者如果我监督了任何事情,请告诉我?

我的片段如下...

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>

spring-servlet-context.xml

        <default-servlet-handler />

        <interceptors>      
            <beans:bean class="org.springframework.web.servlet.i18n.LocaleChangeInterceptor">
                <beans:property name="paramName" value="lang" />
            </beans:bean>

            <beans:bean class="org.springframework.web.servlet.theme.ThemeChangeInterceptor">
                <beans:property name="paramName" value="theme" />
            </beans:bean>   

        </interceptors> 


          <resources mapping="/resources/**" location="/resources/" />


        <beans:bean id="messageSource" class="org.springframework.context.support.ReloadableResourceBundleMessageSource">
            <beans:property name="basename" value="classpath:messages" />
            <beans:property name="defaultEncoding" value="UTF-8"/>
        </beans:bean>

        <beans:bean id="localeResolver" class="org.springframework.web.servlet.i18n.CookieLocaleResolver">
            <beans:property name="defaultLocale" value="en"/>
        </beans:bean>

        <!-- Theme setup --> 
        <beans:bean id="themeSource" class="org.springframework.ui.context.support.ResourceBundleThemeSource">
                <beans:property name="basenamePrefix" value="theme-" />
        </beans:bean>

        <beans:bean id="themeResolver" class="org.springframework.web.servlet.theme.CookieThemeResolver">
            <beans:property name="defaultThemeName" value="default" />
        </beans:bean>


        <beans:import resource="spring-security.xml"/>

         <context:component-scan base-package="com.myproject.platform" />

    </beans:beans>

弹簧安全.xml

      <beans:bean id="encoder" class="org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder" />              


      <authentication-manager alias="authenticationManager">
        <authentication-provider user-service-ref="userService">                
            <password-encoder ref="encoder" />                      
        </authentication-provider> 
      </authentication-manager>

      <beans:import resource="user-security-bean-config.xml"/> 

用户安全 bean-config.xml

        <user-service id="userService">
          <user name="ışığı" password="encodedpasswordstring" 
                         authorities="R_U,R_A"/>

        </user-service>

请注意,如果我有用户名,例如 isigi(没有特殊的 unicode 字符),那么一切正常。

在我的 jsp 文件中,我在最上面一行:

<%@ page language="java" session="false" contentType="text/html; charset=utf-8" pageEncoding="UTF-8"%>

...在头部,我有...

<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">

还有我的 xml 文件,在第一行声明的 UTF-8,例如,

<?xml version="1.0" encoding="UTF-8"?>

不会引发异常或错误。

4

1 回答 1

1

为了其他可能遇到类似问题的人的利益,web.xml 文件中 encodingFilter 的ORDER非常重要,它必须位于过滤器列表的顶部,否则将不起作用。尽管我已经阅读了我发布的链接,但不知何故我错过了两次,直到我昨晚深夜阅读了第三次。我忘了在我的帖子中提到,我已通过在适当的位置添加URIEncoding="UTF-8"将 Tomcat 设置正确配置为 server.xml 文件中的 UTF-8 ,如下所示:

<Connector port="8080" protocol="HTTP/1.1"
           connectionTimeout="20000"
           redirectPort="8443" 
       URIEncoding="UTF-8"/>


<Connector port="8009" protocol="AJP/1.3" redirectPort="8443" URIEncoding="UTF-8" />
于 2013-10-09T11:14:07.747 回答