栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

如何在Spring Boot中将GenericFilterBean数据传递到WebSecurityConfigurerAdapter?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

如何在Spring Boot中将GenericFilterBean数据传递到WebSecurityConfigurerAdapter?

这是解决此问题的解决方案。根据调查,由于8080和8082用于识别HTTP通信和HTTPS通信,因此添加了一些代码来检查端口号,而不是“
isSecure”,以确定是否重定向HTTP请求。代码如下:

public class IsSecureFilter extends GenericFilterBean {private boolean isSecure;private int port;@Overridepublic void doFilter(ServletRequest request, ServletResponse response,        FilterChain chain) throws IOException, ServletException {    HttpServletRequest req = new RequestWrapper((HttpServletRequest) request);    HttpServletResponse res = (HttpServletResponse) response;    this.isSecure = req.isSecure();    this.port = req.getLocalPort();    System.out.println("[DEBUG] : isSecure FILTER :: " + isSecure);    System.out.println("[DEBUG] : port FILTER :: " + port);    System.out.println("[DEBUG] : URL :: " + req.getRequestURL());    String url = req.getRequestURL().toString().toLowerCase();    if(url.endsWith("/login") && url.startsWith("http:") && port == 8080){        url = url.replace("http:", "https:");        String queries = req.getQueryString();        if (queries == null) { queries = "";        } else { queries = "?" + queries;        }        url += queries;        res.sendRedirect(url);    }    else {        chain.doFilter(req, response);    }}public boolean isSecure() {    return this.isSecure;}public boolean setIsSecure(boolean isSecure) {    return this.isSecure = isSecure;}public int getPort() {    return port;}public void setPort(int port) {    this.port = port;}

}

并在WebSecurityConfiguration类中删除http.requiresChannel()。anyRequest()。requiresSecure()。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/382782.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号