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

门户网站标题居中加大设计公司介绍

门户网站标题居中加大,设计公司介绍,店铺设计素材,潘家园做网站的公司SpringSecurity的高级用法#xff0c;包括自定义loginUrl携带参数#xff0c;自定义认证校验逻辑#xff0c;自定义权限校验逻辑。 示例项目 https://github.com/qihaiyan/springcamp/tree/master/spring-advanced-security 一、概述 在项目实际开发过程中#xff0c;Spr…SpringSecurity的高级用法包括自定义loginUrl携带参数自定义认证校验逻辑自定义权限校验逻辑。 示例项目 https://github.com/qihaiyan/springcamp/tree/master/spring-advanced-security 一、概述 在项目实际开发过程中SpringSecurity默认的认证和权限校验逻辑不能实现很高的业务复杂度这种情况下我们需要自定义这些逻辑包括自定义loginUrl携带参数自定义认证校验逻辑自定义权限校验逻辑。 二、自定义loginUrl携带参数 SpringSecurity在跳转login页面时虽然可以指定login的url但是无法让url中携带动态参数不如跳转到login?paramfoo其中foo需要根据特定条件动态变化要实现这种效果我们需要通过exceptionHandling指定自定义LoginUrlAuthenticationEntryPoint。 public class CustomLoginUrlAuthenticationEntryPoint extends LoginUrlAuthenticationEntryPoint {private final RedirectStrategy redirectStrategy new DefaultRedirectStrategy();public CustomLoginUrlAuthenticationEntryPoint(String loginFormUrl) {super(loginFormUrl);}Overridepublic void commence(HttpServletRequest request, HttpServletResponse response, AuthenticationException authException)throws IOException, ServletException {if (!super.isUseForward()) {String redirectUrl this.buildRedirectUrlToLoginPage(request, response, authException);// change login urlredirectUrl redirectUrl ?paramtest;this.redirectStrategy.sendRedirect(request, response, redirectUrl);} else {String redirectUrl null;if (super.isForceHttps() http.equals(request.getScheme())) {redirectUrl this.buildHttpsRedirectUrlForRequest(request);}if (redirectUrl ! null) {this.redirectStrategy.sendRedirect(request, response, redirectUrl);} else {String loginForm this.determineUrlToUseForThisRequest(request, response, authException);RequestDispatcher dispatcher request.getRequestDispatcher(loginForm);dispatcher.forward(request, response);}}} }以上代码自定义CustomLoginUrlAuthenticationEntryPoint在commence方法中我们可以按照业务需要实现自己的跳转逻辑通过修改redirectUrl实现。 在SpringSecurity配置中通过exceptionHandling引用CustomLoginUrlAuthenticationEntryPoint exceptionHandling(customizer -customizer.authenticationEntryPoint(new CustomLoginUrlAuthenticationEntryPoint(/login)))三、自定义认证校验逻辑 SpringSecurity默认的认证逻辑是校验用户名密码是否合法如果想增加其它的校验逻辑需要实现AuthenticationProvider然后在authenticationManager中指定我们自己实现的AuthenticationProvider。 public class CustomAuthenticationProvider extends DaoAuthenticationProvider {Autowiredprivate CustomUserDetailsService customUserDetailsService;PostConstructpublic void init() {this.setUserDetailsService(customUserDetailsService);}Overrideprotected void additionalAuthenticationChecks(UserDetails userDetails, UsernamePasswordAuthenticationToken authentication) {super.additionalAuthenticationChecks(userDetails, authentication);HttpServletRequest req ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest();String username userDetails.getUsername();// 自定义认证校验逻辑if (username.equals(need approval)) {log.info(invalid request is: {}, req);throw new AuthenticationServiceException(Your account is pending approval for access);}} }在上面自定义的CustomAuthenticationProvider中通过重写additionalAuthenticationChecks方法进行自定义认证逻辑的实现。 然后在authenticationManager中指定CustomAuthenticationProvider Bean public AuthenticationManager authenticationManager() {return new ProviderManager(customAuthenticationProvider); }四、自定义权限校验逻辑 SpringSecurity可以通过在配置中通过requestMatchers指定较为灵活的权限校验策略但是缺少一些动态特性比如对 /foo/{param} 这种rest风格的带变量的url就处理不了 这种情况我们可以通过自定义AuthorizationManager来实现然后在requestMatchers中通过access方法来指定我们自定义的AuthorizationManager。 public class MyRequestAuthorizationManager implements AuthorizationManagerRequestAuthorizationContext {private final SecurityExpressionHandlerRequestAuthorizationContext expressionHandler new DefaultHttpSecurityExpressionHandler();public MyRequestAuthorizationManager() {}// 自定义授权校验逻辑Overridepublic AuthorizationDecision check(SupplierAuthentication authentication, RequestAuthorizationContext context) {EvaluationContext ctx this.expressionHandler.createEvaluationContext(authentication, context);String checkParam Optional.ofNullable(ctx.lookupVariable(param)).map(String::valueOf).orElse(null);// the /public url doesnt need authenticationif (checkParam ! null (checkParam.equals(public))) {return new AuthorizationDecision(true);}return new AuthorizationDecision(!ObjectUtils.isEmpty(authentication.get().getCredentials()));} }在MyRequestAuthorizationManager中通过重写check方法来实现自定义权限校验rest风格的带变量的url中的变量可以通过EvaluationContext的lookupVariable方法获取变量值。 指定自定义AuthorizationManager: MyRequestAuthorizationManager myRequestAuthorizationManager new MyRequestAuthorizationManager(); http.authorizeHttpRequests(authorize - authorize.requestMatchers(/{param}).access(myRequestAuthorizationManager))
http://www.hkea.cn/news/14298528/

相关文章:

  • 网站建设管理风险超变传奇手游刀刀切割无会员散人
  • 做蛋糕需要建议网站不提供手机网站建设推荐
  • 晋城网站建设网站wordpress手机模版
  • 在服务器上部署网站电商产品开发流程
  • 二道江网站建设未备案网站 赚钱
  • 泰安企业公司什么叫做seo
  • 宣传部网站建设方案wordpress 外部链接
  • wordpress cms下载地址seo监控系统
  • 网站建设芜湖建站空间
  • 金华专业网站制作公司wordpress二次元网站
  • 淘宝网站建设没法上传怎么办好的产品设计网站
  • 天气预报网站开发山东建设监理协会继续教育网站
  • 福田做商城网站建设哪家便宜龙岗网站建设流程
  • 石家庄有学校交做网站和优化的吗wordpress被植入广告
  • 如何设计网站建设引导页这么做输入文字的网站
  • 鼓楼微网站开发深圳建设集团有限公司官网
  • 信息网站 模板创意设计公司官网
  • 微信公众号的网站企业营销是啥意思
  • 哪个域名注册网站好西安网站建设多少钱
  • 网站建设颜色注意事项电子商城网站建设参考文献
  • 网站建设介绍推广用语西安网站建立
  • 教学成果申报网站 化工专业建设买了网站模版怎么做
  • 成都专业网站营销北辰手机网站建设
  • 有创意的网站开发都匀网站建设公司
  • 网站目录权限设置东莞软文推广
  • 关于怎样把网站建设好的一些建议cms影视源码采集
  • 校园局域网站建设费用给个网站能用的2022
  • 做网站需要备案吗服装网站建设发展状况
  • 哪个网站代做ppt便宜长清网站建设
  • 石家庄集团公司网站建设wordpress主题怎么设置tdk