• Security5国际化


    默认提示信息是英文,如登录失败时返回的是Bad Credentials。提示很不友好,需要自定义本地化的提示信息。网上搜索,很多人跟踪源码后,还是要配置xml,重写MessageSource等。

    仔细想了一下,国际化应该是针对整个项目的,应该不只是Security,应该可以通用配置。于是就在配置文件配置了自定义的路径 :

    spring:
    messages:
    basename: i18n/messages_zh_CN
    encoding: UTF-8

    然后在resources目录下,把messages_zh_CN.properties拷到对应位置。然后Security果然也返回对应的中文提示了。

    Security5.2的中文提示已经非常友好了,我直接拷过来用的。

    AbstractAccessDecisionManager.accessDenied=不允许访问
    AbstractLdapAuthenticationProvider.emptyPassword=用户名或密码错误
    AbstractSecurityInterceptor.authenticationNotFound=未在SecurityContext中查找到认证对象
    AbstractUserDetailsAuthenticationProvider.badCredentials=用户名或密码错误
    AbstractUserDetailsAuthenticationProvider.credentialsExpired=用户凭证已过期
    AbstractUserDetailsAuthenticationProvider.disabled=用户已失效
    AbstractUserDetailsAuthenticationProvider.expired=用户帐号已过期
    AbstractUserDetailsAuthenticationProvider.locked=用户帐号已被锁定
    AbstractUserDetailsAuthenticationProvider.onlySupports=仅仅支持UsernamePasswordAuthenticationToken
    AccountStatusUserDetailsChecker.credentialsExpired=用户凭证已过期
    AccountStatusUserDetailsChecker.disabled=用户已失效
    AccountStatusUserDetailsChecker.expired=用户帐号已过期
    AccountStatusUserDetailsChecker.locked=用户帐号已被锁定
    AclEntryAfterInvocationProvider.noPermission=给定的Authentication对象({0})根本无权操控领域对象({1})
    AnonymousAuthenticationProvider.incorrectKey=展示的AnonymousAuthenticationToken不含有预期的key
    BindAuthenticator.badCredentials=用户名或密码错误
    BindAuthenticator.emptyPassword=用户名或密码错误
    CasAuthenticationProvider.incorrectKey=展示的CasAuthenticationToken不含有预期的key
    CasAuthenticationProvider.noServiceTicket=未能够正确提供待验证的CAS服务票根
    ConcurrentSessionControlAuthenticationStrategy.exceededAllowed=已经超过了当前主体({0})被允许的最大会话数量
    DigestAuthenticationFilter.incorrectRealm=响应结果中的Realm名字({0})同系统指定的Realm名字({1})不吻合
    DigestAuthenticationFilter.incorrectResponse=错误的响应结果
    DigestAuthenticationFilter.missingAuth=遗漏了针对'auth' QOP的、必须给定的摘要取值; 接收到的头信息为{0}
    DigestAuthenticationFilter.missingMandatory=遗漏了必须给定的摘要取值; 接收到的头信息为{0}
    DigestAuthenticationFilter.nonceCompromised=Nonce令牌已经存在问题了,{0}
    DigestAuthenticationFilter.nonceEncoding=Nonce未经过Base64编码; 相应的nonce取值为 {0}
    DigestAuthenticationFilter.nonceExpired=Nonce已经过期/超时
    DigestAuthenticationFilter.nonceNotNumeric=Nonce令牌的第1部分应该是数字,但结果却是{0}
    DigestAuthenticationFilter.nonceNotTwoTokens=Nonce应该由两部分取值构成,但结果却是{0}
    DigestAuthenticationFilter.usernameNotFound=用户名{0}未找到
    JdbcDaoImpl.noAuthority=没有为用户{0}指定角色
    JdbcDaoImpl.notFound=未找到用户{0}
    LdapAuthenticationProvider.badCredentials=用户名或密码错误
    LdapAuthenticationProvider.credentialsExpired=用户凭证已过期
    LdapAuthenticationProvider.disabled=用户已失效
    LdapAuthenticationProvider.expired=用户帐号已过期
    LdapAuthenticationProvider.locked=用户帐号已被锁定
    LdapAuthenticationProvider.emptyUsername=用户名不允许为空
    LdapAuthenticationProvider.onlySupports=仅仅支持UsernamePasswordAuthenticationToken
    PasswordComparisonAuthenticator.badCredentials=用户名或密码错误
    #PersistentTokenBasedRememberMeServices.cookieStolen=Invalid remember-me token (Series/token) mismatch. Implies previous cookie theft attack.
    ProviderManager.providerNotFound=未查找到针对{0}的AuthenticationProvider
    RememberMeAuthenticationProvider.incorrectKey=展示RememberMeAuthenticationToken不含有预期的key
    RunAsImplAuthenticationProvider.incorrectKey=展示的RunAsUserToken不含有预期的key
    SubjectDnX509PrincipalExtractor.noMatching=未在subjectDN: {0}中找到匹配的模式
    SwitchUserFilter.noCurrentUser=不存在当前用户
    SwitchUserFilter.noOriginalAuthentication=不能够查找到原先的已认证对象
    

      

  • 相关阅读:
    03《软件需求分析教程》
    02《软件需求分析教程》
    01《软件需求分析教程》
    03《需求模式——软件建模与分析》
    02《需求模式——软件建模与分析》
    密码管理器
    01《需求模式——软件建模与分析》
    2020软件工程助教工作期末总结
    第十七周助教工作周小结
    第十六周助教工作周小结
  • 原文地址:https://www.cnblogs.com/zhouyu629/p/12307090.html
Copyright © 2020-2023  润新知