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

网站上线后想修改模板网站五金

网站上线后想修改,模板网站五金,如何规划电子商务网站,昆明百度关键词优化Filter顺序 Spring Security的官方文档向我们提供了filter的顺序#xff0c;实际应用中无论用到了哪些#xff0c;整体的顺序是保持不变的: ChannelProcessingFilter#xff0c;重定向到其他协议的过滤器。也就是说如果你访问的channel错了#xff0c;那首先就会在channel…Filter顺序 Spring Security的官方文档向我们提供了filter的顺序实际应用中无论用到了哪些整体的顺序是保持不变的: ChannelProcessingFilter重定向到其他协议的过滤器。也就是说如果你访问的channel错了那首先就会在channel之间进行跳转如http变为https。SecurityContextPersistenceFilter请求来临时在SecurityContextHolder中建立一个SecurityContext然后在请求结束的时候清空SecurityContextHolder。并且任何对SecurityContext的改变都可以被copy到HttpSession。ConcurrentSessionFilter因为它需要使用SecurityContextHolder的功能而且更新对应session的最后更新时间以及通过SessionRegistry获取当前的SessionInformation以检查当前的session是否已经过期过期则会调用LogoutHandler。认证处理机制如UsernamePasswordAuthenticationFilterCasAuthenticationFilterBasicAuthenticationFilter等以至于SecurityContextHolder可以被更新为包含一个有效的Authentication请求。SecurityContextHolderAwareRequestFilter它将会把HttpServletRequest封装成一个继承自HttpServletRequestWrapper的SecurityContextHolderAwareRequestWrapper同时使用SecurityContext实现了HttpServletRequest中与安全相关的方法。JaasApiIntegrationFilter如果SecurityContextHolder中拥有的Authentication是一个JaasAuthenticationToken那么该Filter将使用包含在JaasAuthenticationToken中的Subject继续执行FilterChain。RememberMeAuthenticationFilter如果之前的认证处理机制没有更新SecurityContextHolder并且用户请求包含了一个Remember-Me对应的cookie那么一个对应的Authentication将会设给SecurityContextHolder。AnonymousAuthenticationFilter如果之前的认证机制都没有更新SecurityContextHolder拥有的Authentication那么一个AnonymousAuthenticationToken将会设给SecurityContextHolder。ExceptionTransactionFilter用于处理在FilterChain范围内抛出的AccessDeniedException和AuthenticationException并把它们转换为对应的Http错误码返回或者对应的页面。FilterSecurityInterceptor保护Web URI进行权限认证并且在访问被拒绝时抛出异常。 自定义过滤器 除了这些过滤器外我们可能还需要在认证链路中自定义一些过滤器。 oauth2拦截器在初始化完成后共会生成三个拦截器调用链分别对应oauth/token等的oauth2认证拦截器调用链对resource资源访问的拦截器调用链springsecurity的拦截器调用链。 oauth2认证拦截器调用链 通过AuthorizationServerSecurityConfigurer的addTokenEndpointAuthenticationFilter()方法我们可以在BasicAuticaitonFilter前加入拦截器。 这个过滤器是在ClientCredentialsTokenEndpointFilter之后的所以如果想在ClientCredentialsTokenEndpointFilter过滤器之前加过滤器的话 我还没找到方法 Configuration public class OAuth2ServerFilterConfig extends AuthorizationServerConfigurerAdapter {Overridepublic void configure(AuthorizationServerSecurityConfigurer configurer) throws Exception {configurer.addTokenEndpointAuthenticationFilter(oauth2JsonClientAuthFilter());}private Filter oauth2JsonClientAuthFilter() {Oauth2JsonClientAuthFilter oauth2JsonClientAuthFilter new Oauth2JsonClientAuthFilter();oauth2JsonClientAuthFilter.setAuthenticationSuccessHandler(new AuthenticationSuccessHandler() {Overridepublic void onAuthenticationSuccess(HttpServletRequest request, HttpServletResponse response,Authentication authentication) throws IOException, ServletException {}});return oauth2JsonClientAuthFilter;} } 2. resource资源拦截器调用链 Configuration public class AuthResourceServerConfigurer extends ResourceServerConfigurerAdapter {Overridepublic void configure(ResourceServerSecurityConfigurer resources) throws Exception {super.configure(resources);}Overridepublic void configure(HttpSecurity http) throws Exception {http.authorizeRequests().anyRequest().authenticated();//这个是对所有url都进行拦截因为没设置发现只有对部分url生效http.requestMatcher(AnyRequestMatcher.INSTANCE);} } 3.springsecurity认证拦截器 public class WebSecurityConfig extends WebSecurityConfigurerAdapter {Beanpublic BCryptPasswordEncoder passwordEncoder() {return new BCryptPasswordEncoder();}Overridepublic void configure(HttpSecurity http) throws Exception {//其余代码省略http.addFilterBefore(mutiLoginDemoFilter(httpSecurity), BasicAuticaitonFilter.class);} } 这里springsecurity的加入的过滤器都比addTokenEndpointAuthenticationFilter加入的过滤器执行晚,通过代码就可以看出 public final class HttpSecurity extendsAbstractConfiguredSecurityBuilderDefaultSecurityFilterChain, HttpSecurityimplements SecurityBuilderDefaultSecurityFilterChain,HttpSecurityBuilderHttpSecurity {Overrideprotected DefaultSecurityFilterChain performBuild() {//这里获取所有的拦截器filters.sort(comparator) 将所有的过滤器排序后返回filters.sort(comparator);return new DefaultSecurityFilterChain(requestMatcher, filters);}}public HttpSecurity addFilterBefore(Filter filter,Class? extends Filter beforeFilter) {comparator.registerBefore(filter.getClass(), beforeFilter);return addFilter(filter);}
http://www.hkea.cn/news/14535456/

相关文章:

  • 建网站外包公司周口建设企业网站公司
  • 做一张网站图得多少钱国外html5网站模版
  • sem网站做推广版面设计教案
  • 迅雷黄冈网站推广软件网站建设详细需求说明书
  • 外国人做中国英语视频网站吗seo关键词快速排名软件
  • 网站建设需要备案吗工业设计公司是做什么的
  • 陕西专业网站开发公司长沙 服务
  • 网站中搜索关键词wordpress外部调用插件
  • 住房和城乡建设部网站倪虹南宁网站建设官网
  • 在阿里巴巴上怎样做网站网络推广培训班网络推广培训机构
  • 专业的佛山网站建设上海家装十强企业
  • 社交信息共享网站开发外包小程序商城使用教程
  • wordpress全站搜索做视频资源网站
  • 佛山商城网站制作wordpress头像禁用
  • 无需下载的网站建设一个境外网站
  • 如和做视频解析网站工程公司名字
  • 年度网站信息化建设工作计划泉州关键词排名seo
  • 什么样的网站需要改版重庆建设工程信息网网
  • 太原定制网站制作流程网页游戏传奇游戏
  • 装修网站应该怎么做免费十大软件app
  • 顺义的网站建设公司零基础网站建设教学视频
  • 凡科建站好用吗厦门网站建设格
  • 珠海网站制作定制如何软件网站优化公司
  • 优秀集团网站设计网站怎么做会员系统
  • 建设网站基本流程食品网站开发毕业设计
  • 建设网站的语言微信怎么建公众号
  • 建设网站宣传页网络推广外包业务怎么样
  • 呼市做引产z首大网站wordpress插件 图片
  • 福建省建设银行招聘网站adsl做网站
  • 专门做摩托车的网站开封建网站的公司