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

江苏网站建设网站排名优化网络安全培训机构排名

江苏网站建设网站排名优化,网络安全培训机构排名,直播软件的app,漯河专业做网站的公司文章目录 一、 身份认证Demo1、创建工程2、代码编写2.1、Controller2.2、Html2.3、application.properties配置 3、启动项目并访问 二、Spring Security 默认做了什么二、底层原理1.概述2.FiltersDelegatingFilterProxyFilterChainProxySecurityFilterChainSecurity Filters 三… 文章目录 一、 身份认证Demo1、创建工程2、代码编写2.1、Controller2.2、Html2.3、application.properties配置 3、启动项目并访问 二、Spring Security 默认做了什么二、底层原理1.概述2.FiltersDelegatingFilterProxyFilterChainProxySecurityFilterChainSecurity Filters 三、程序的启动和运行DefaultSecurityFilterChainSecurityProperties 总结 一、 身份认证Demo 1、创建工程 下载完成后使用idea打开即可。 2、代码编写 2.1、Controller package com.security.demo.controller;import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.GetMapping;Controller public class IndexController {GetMapping(/)public String index(){return index;} } 2.2、Html !DOCTYPE html html xmlns:thhttps://www.thymeleaf.org langen headmeta charsetUTF-8titlehello Security/title /head bodyh1Hello Security/h1a th:href{/logout}Log Out/a /body /html2.3、application.properties配置 spring.application.namesecurity-demo server.servlet.context-path/demo spring.security.user.nameadmin spring.security.user.password1233、启动项目并访问 二、Spring Security 默认做了什么 保护应用程序URL,要求对应用程序的任何交互进行身份验证。程序启动时生成一个默认用户“user。生成一个默认的随机密码并将此密码记录在控制台上。生成默认的登录表单和注销页面。提供基于表单的登录和注销流程。对于Web请求重定向到登录页面对于服务请求返回401未经授权。处理跨站请求伪造(CSRF)攻击。处理会话劫持攻击。写入Strict-Transport-Security以确保HTTPS。写入X-Content-Type-Options以处理嗅探攻击。写入Cache Control头来保护经过身份验证的资源。写入X-Frame-Options以处理点击劫持攻击。 二、底层原理 1.概述 Spring Security 之所以默认帮助我们做了那么多事情它的底层原理是传统的Servlet过滤器。 2.Filters DelegatingFilterProxy Servlet 容器允许Filter使用自己的标准注册实例但它不知道Spring定义的Bean。而DelegatingFilterProxy可以获取注册为Spring Bean的Filter。DelegatingFilterProxy通过标准 Servlet 容器机制进行注册但将所有工作委托给实现Filter. DelegatingFilterProxy伪代码 public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) {//延迟获取注册为Spring Bean的Filter Filter delegate getFilterBean(someBeanName);//将工作委托给Spring Beandelegate.doFilter(request, response); }FilterChainProxy Spring Security 的 Servlet 支持包含在FilterChainProxy。FilterChainProxy是 Spring Security 提供的特殊功能Filter允许Filter通过委托给SecurityFilterChain许多实例。 由于FilterChainProxy是一个 Bean因此它通常包装在DelegatingFilterProxy中。 SecurityFilterChain FilterChainProxy使用SecurityFilterChain来确定应该为当前请求调用哪个Spring -SecurityFilter实例。 SecurityFilterChain中的安全过滤器通常是bean但它们是在FilterChainProxy而不是DelegatingFilterProxy中注册的。FilterChainProxy为直接注册Servlet容器或DelegatingFilterProxy提供了许多优点。 首先它为Spring Security的所有Servlet支持提供了一个起点。因此如果您试图对Spring Security的Servlet支持进行故障排除那么在FilterChainProxy中添加一个调试点是一个很好的开始。 其次由于FilterChainProxy是Spring Security使用的核心它可以执行非可选的任务。例如它清除SecurityContext以避免内存泄漏。 它还应用Spring Security的HttpFirewall来保护应用程序免受某些类型的攻击。 此外它在确定何时调用SecurityFilterChain方面提供了更大的灵活性。 在Servlet容器中仅根据URL调用Filter实例。然而FilterChainProxy可以通过使用RequestMatcher接口基于HttpServletRequest中的任何内容来确定调用。 在Multiple SecurityFilterChain图中FilterChainProxy决定应该使用哪个SecurityFilterChain。 只调用第一个匹配的SecurityFilterChain。 如果请求/api/messages/的URL它首先匹配/api/**的SecurityFilterChaing模式因此只有SecurityFilterChaing被调用即使它也匹配 如果请求/messages/的URL它与/api/**的SecurityFilterChain模式不匹配因此FilterChainProxy继续尝试每个SecurityFilterChain。 假设没有其他SecurityFilterChain实例匹配则调用SecurityFilterChain。 注意SecurityFilterChaing只配置了三个安全过滤器实例。 然而SecurityFilterChain配置了四个安全过滤器实例。 需要注意的是每个SecurityFilterChain都可以是唯一的并且可以单独配置。 事实上如果应用程序希望Spring security忽略某些请求SecurityFilterChain可能没有安全过滤器实例。 Security Filters 使用SecurityFilterChain api将安全过滤器插入到FilterChainProxy中。 这些过滤器可用于许多不同的目的如身份验证、授权、漏洞利用保护等。 过滤器按照特定的顺序执行以确保在正确的时间调用它们例如应该在执行授权的过滤器之前调用执行身份验证的过滤器。 通常不需要知道Spring Security过滤器的顺序。然而有时知道顺序是有益的如果你想知道它们你可以检查FilterOrderRegistration代码。 三、程序的启动和运行 DefaultSecurityFilterChain SecurityFilterChain接口的实现加载了默认的16个Filter。 SecurityProperties 初始化用户名密码 spring.security.user.nameadmin spring.security.user.password123总结 DelegatingFilterProxy作为过滤器的代理帮助我们调用spring容器中所有注册的过滤器FilterChainProxy帮助我们管理多个不同的过滤器链SecurityFilterChain。SecurityFilterChain帮助我们处理复杂的业务逻辑通过匹配不同的url由不同的过滤器链的组合来接收从而由不同的过滤器来完成相应的功能。
http://www.zqtcl.cn/news/82637/

相关文章:

  • 岳阳网站建设团队织梦个人网站模版
  • 网站建设费应该怎样入账成都最专业做网站的
  • 如何更改网站源码品网站建设
  • 培训通网站建设wordpress 切换域名
  • 手机可以建设网站吗wordpress 程序
  • 外贸网站模板建立wordpress主题显示不完整
  • 互动型网站杭州建设局网站
  • linux系统如何做网站做网做网站建设
  • 保定网站建设设计房网房天下官网
  • 怎么做婚介网站建设网上银行官网
  • 韩国网站后缀潍坊vi设计公司
  • 国内投资咨询网站 html模板档案网站建设的步骤
  • 中小学网站模板源码168电商平台
  • 大气宽屏网站模板企业源码带后台网络品牌传播推广策略
  • 医院网站前置审批文件专业信息门户网站建设
  • 网站跳转是什么意思企业信息系统有哪些类型
  • 缙云 网站建设有名网站建设公司
  • 网站建设调研报告百度账号申诉
  • html5网站正在建设中cocos2d-js可以做网站吗
  • 网站建设定金合同范本哪个电商平台好做
  • 网站产品怎么改顺序做漫画视频在线观看网站
  • 个体户营业执照科研做企业网站吗广告发布网站模板
  • 石家庄规划建设局网站北京展览网站建设
  • 网站建设 招聘需求哪个公司的app开发
  • 建设银行网站每天几点更新什么是域名空间
  • 怎么查询网站开发公司团购网站app制作
  • .net做网站之前设置吕梁做网站公司
  • 百度站长工具官网店招免费设计在线生成
  • 品牌策划 网站源码中宁网站建设公司
  • 南京市溧水建设局网站济南网站建设小程序开发