当前位置: 首页 > news >正文

怎样建立一个企业网站天津手网站开发

怎样建立一个企业网站,天津手网站开发,合肥城建,专业商城网站建设报价单文章目录 0.前言漏洞Spring Security介绍 1.参考文档2.基础介绍3.解决方案3.1. 升级版本3.2. 临时替代方案 4.Spring Security使用教程简单代码示例 0.前言 背景#xff1a;公司项目扫描到 Spring-security 组件 注销后未正确保存空的SecurityContext CVE-2023-20862 漏洞 高… 文章目录 0.前言漏洞Spring Security介绍 1.参考文档2.基础介绍3.解决方案3.1. 升级版本3.2. 临时替代方案 4.Spring Security使用教程简单代码示例 0.前言 背景公司项目扫描到 Spring-security 组件 注销后未正确保存空的SecurityContext CVE-2023-20862 漏洞 高风险 | 2023年4月17日 | CVE-2023-20862 在Spring Security中5.7.x版本之前的5.7.8版本5.8.x版本之前的5.8.3版本以及6.0.x版本之前的6.0.3版本如果使用序列化版本注销支持不会正确清理安全上下文。此外无法将空的安全上下文显式保存到HttpSessionSecurityContextRepository。这种漏洞可能会使用户在注销后仍然保持认证状态。 Spring Security介绍 Spring Security是一个功能强大且高度可定制的身份验证和访问控制框架。它是保护基于Spring的应用程序的实际标准。Spring Security提供了一套完整的安全性解决方案是构建安全性强的企业级应用程序的理想选择。它的模块化和可扩展性使得开发者能够满足各种各样的安全需求从简单的应用级别的安全到复杂的方法级别的安全Spring Security都能够提供支持。Spring Security对于所有种类的身份验证机制提供了很好的支持包括内存存储的用户列表、JDBC基于数据库的认证、LDAP认证、表单认证、CAS等。它不仅支持一大堆认证机制还支持很多种权限控制的方式如基于角色的访问控制、访问控制列表ACL等。 正因为它是专门搞权限验证授权等安全验证功能在它上面的漏洞简直层出不穷防不胜防。所以最近又发布了一个它的漏洞 1.参考文档 CVE 官方网站 https://www.cve.org/CVERecord?idCVE-2023-20862spring官方网站 https://spring.io/security/cve-2023-20862 https://docs.spring.io/spring-security/reference/5.8/migration/servlet/session-management.html#_require_explicit_saving_of_securitycontextrepositoryhttps://docs.spring.io/spring-security/reference/servlet/authentication/session-management.html#store-authentication-manuallyhttps://docs.spring.io/spring-security/reference/5.8.3/servlet/authentication/session-management.html#properly-clearing-authentication 2.基础介绍 在Spring Security中5.7.x版本之前的5.7.8版本5.8.x版本之前的5.8.3版本以及6.0.x版本之前的6.0.3版本如果使用序列化版本注销支持不会正确清理安全上下文。此外无法将空的安全上下文显式保存到HttpSessionSecurityContextRepository。这种漏洞可能会使用户在注销后仍然保持认证状态。 受影响的Spring产品和版本 Spring Security 6.0.0至6.0.2 5.8.0至5.8.2 5.7.0至5.7.7 3.解决方案 3.1. 升级版本 受影响版本的用户应该应用以下缓解。5.7.x的用户应该升级到5.7.8。5.8.x的用户应该升级到5.8.3。6.0.x的用户应该升级到6.0.3。没有其他必要的步骤。已修复此问题的版本包括 已修复此问题的版本 Spring Security 版本 5.7.8 5.8.3 6.0.33.2. 临时替代方案 正在使用SecurityContextHolderFilter或requireExplicitSave(true)并且正在使用Spring Security的注销支持与序列化会话例如Spring Session和invalidateHttpSession(false)通过将一个空的SecurityContext保存到HttpSessionSecurityContextRepository来手动注销用户有一个不依赖HttpSession的自定义SecurityContextRepository 4.Spring Security使用教程简单代码示例 添加Spring Security依赖 dependencygroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-security/artifactId /dependency创建Spring Security配置类 创建 SecurityConfig的Java类这个类需要继承WebSecurityConfigurerAdapter类并覆盖其configure方法来实现安全配置。也需要配置一个PasswordEncoder bean来处理密码的编码。 Configuration EnableWebSecurity public class SecurityConfig extends WebSecurityConfigurerAdapter {Overrideprotected void configure(HttpSecurity http) throws Exception {http.authorizeRequests().anyRequest().authenticated().and().formLogin().loginPage(/login).permitAll().and().httpBasic();}Autowiredpublic void configureGlobal(AuthenticationManagerBuilder auth) throws Exception {auth.inMemoryAuthentication().passwordEncoder(passwordEncoder()).withUser(user).password(passwordEncoder().encode(password)).roles(USER);}Beanpublic PasswordEncoder passwordEncoder() {return new BCryptPasswordEncoder();} }配置指定了所有的请求必须经过身份验证。它还指定一个自定义的登录页面这个页面对所有用户都是可用的。最后它配置了一个在内存中的用户存储包含一个用户名为user密码为password的用户。 创建登录页面 在src/main/resources/templates目录下创建一个名为login.html的文件。此文件的内容可以根据的需求进行定制 !DOCTYPE html html xmlns:thhttp://www.thymeleaf.org headtitleLogin/title /head body form th:action{/login} methodpostdivinput typetext nameusername placeholderUsername//divdivinput typepassword namepassword placeholderPassword//divdivinput typesubmit valueSign In//div /form /body /html在控制器中使用认证用户信息 在需要使用认证用户信息的地方可以使用AuthenticationPrincipal注解来获取当前认证用户 GetMapping(/hello) public String hello(AuthenticationPrincipal User user) {return Hello, user.getUsername(); }
http://www.hkea.cn/news/14568124/

相关文章:

  • 网站建设的技术亮点酒店协会网站集静态模板
  • 网站seo优化加推广支付宝小程序代理
  • 邮件模板网站怎么做好手机网站开发
  • 网页制作与网站设计思路wordpress电影站
  • 做网站教程流程网络营销策略4p4c
  • 微信官方网站首页域名服务费多少钱一年
  • 手机微网站第二年续费吗哪个平台推广效果最好
  • 郑州做网站公做的最好的相亲网站有哪些
  • 无锡网站维护公司哪个网站百度收录快
  • 建设网站基本思路网络广告投放平台
  • 网站域名会赠送几个邮箱企业网站建设绪论
  • 网站制作 深圳变性人做网站
  • 天河建设网站公司搜索不到的网站
  • 网站建设执行力如何让百度快速收录新网站
  • 怎么用ps做网站首页微信小程序页面跳转
  • 曲周企业做网站推广响应式网站的概念
  • 华亭县建设局网站2017wordpress分类的feed
  • 手机软件开发外包百度seo怎么提高排名
  • 打码网站怎么做接口苏州晶体公司网站建设
  • 企业网站怎么建设公司免费功能网站
  • 建e网官方网站wordpress数字链接出现404
  • 网站制作需求文档网站建设公司青岛
  • wordpress 购物网站主题国内做视频课程的网站有哪些
  • 东莞做网站推广公司杭州网络安全公司
  • html网站开发心得体会做网站的是哪类公司
  • 淘客网站怎么与pidwordpress appcan
  • 河北邯郸做移动网站中国2022年企业500强一览表
  • 望江县住房和城乡建设局网站国外网站空间租用哪个好
  • 江苏网站建设培训包头市建设厅官方网站
  • 长沙网站设计优秀柚v米科技wordpress 取中等大小