原文: https://howtodoinjava.com/spring-security/http-basic-authentication-example-using-spring-3/

基本身份验证通常用于无状态客户端,该客户端在每个请求上传递其凭据。 通常将其与基于表单的身份验证结合使用,在这种情况下,既可以通过基于浏览器的用户界面也可以通过网络服务来使用应用程序。 但是,基本身份验证以纯文本形式传输密码,因此,仅应在诸如 HTTPS 之类的加密传输层上实际使用该密码。

由于必须随每个 HTTP 请求一起发送基本身份验证标头,因此 Web 浏览器需要在合理的时间内缓存凭据,以避免不断提示用户输入用户名和密码。 缓存策略因浏览器而异。

Spring Security 中的BasicAuth

实现基本 http 身份验证的最简单解决方案是在 Spring Security配置文件中使用“ http-basic”标签,如下所示:

  1. <http>
  2. <intercept-url pattern="/**" access="ROLE_USER" />
  3. <http-basic />
  4. </http>

应用程序中的上述设置将强制用户验证应用程序中的任何网页或任何其他资源。 有趣的是,您无需创建任何登录页面或会话管理机制。 浏览器将在用户代表您之前显示一个登录框。 并且因为每个请求都包含 http 无状态机制中的身份验证信息,所以您也不需要维护会话。

基本身份验证演示

在 Spring Security配置中配置basic-auth

在基于 Spring 登录表单的安全示例中创建的员工管理应用程序中,我们手动创建了登录表单并将其配置为各种 URL 模式。

让我们对其进行修改以使用 http 基本身份验证。 我们修改后的application-security.xml现在看起来像这样。

application-security.xml

  1. < ?xml version="1.0" encoding="UTF-8"?>
  2. xmlns="http://www.springframework.org/schema/security"
  3. xmlns:beans="http://www.springframework.org/schema/beans"
  4. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  5. xsi:schemaLocation="http://www.springframework.org/schema/beans
  6. http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
  7. http://www.springframework.org/schema/security
  8. http://www.springframework.org/schema/security/spring-security-3.0.3.xsd">
  9. <http auto-config="true" use-expressions="true">
  10. <intercept-url pattern="/login" access="permitAll" />
  11. <intercept-url pattern="/logout" access="permitAll" />
  12. <intercept-url pattern="/accessdenied" access="permitAll" />
  13. <intercept-url pattern="/**" access="hasRole('ROLE_USER')" />
  14. <logout logout-success-url="/logout" />
  15. <http-basic />
  16. </http>
  17. <authentication-manager alias="authenticationManager">
  18. <authentication-provider>
  19. <user-service>
  20. <user lokesh" password="password" authorities="ROLE_USER" />
  21. </user-service>
  22. </authentication-provider>
  23. </authentication-manager>

验证BasicAuth

现在,让我们再次构建应用程序,然后在应用程序服务器中运行它。

1)在浏览器中点击网址http://localhost:8080/Spring3HibernateIntegration

出现登录窗口。 请注意,这是浏览器生成的登录框,应用程序仅向浏览器提供了相关的标头。

Spring Security 基本身份验证示例 - 图1

HTTP 基本认证窗口

2)输入错误的用户名和密码

这将使浏览器再次显示清除的登录框,或者在某些情况下将显示错误页面。

Spring Security 基本身份验证示例 - 图2

HTTP 基本认证中的登录错误

3)输入正确的用户名和密码

正确的用户名和密码:“lokesh”和“password”。 当您输入上述凭证时,员工管理屏幕将出现在浏览器屏幕中。

Spring Security 基本身份验证示例 - 图3

员工管理界面

如果您在运行上述配置时发现任何问题,请告诉我。

学习愉快!