Spring Security OAuth2经过负载均衡导致redirect_uri使用http而不是https报redirect_uri mismatch错误

解决办法:添加前置过滤器,强制将scheme配置为https,将serverPort配置为443

@Slf4j
public class MyPreFilter implements Filter {

    @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain)
            throws IOException, ServletException {
        HttpServletRequest httpRequest = (HttpServletRequest) servletRequest;
        MyRequestWrapper myRequestWrapper = new MyRequestWrapper(httpRequest);

        filterChain.doFilter(myRequestWrapper, servletResponse);
    }
}

@Slf4j
public class MyRequestWrapper extends HttpServletRequestWrapper {

    public MyRequestWrapper(HttpServletRequest request) {
        super(request);
    }

    @Override
    public String getScheme() {
        return "https";
    }

    @Override
    public int getServerPort() {
        return 443;
    }
}
上一篇 Spring Security Bigcommerce OAuth2 调试记录
下一篇 Spring Boot向Filter过滤器中的Request对象添加额外的参数
目录
文章列表
1 Appium运行报错:does not have permission android.permission.CLEAR_APP_USER_DATA to clear data of package
Appium运行报错:does not have permission android.permission.CLEAR_APP_USER_DATA to clear data of package
2
Gradle 设置 Nexus 用户名密码
Gradle 设置 Nexus 用户名密码
3
Android微信支付SDK开发
Android微信支付SDK开发
4
No modifications are allowed to a locked ParameterMap 解决方案
No modifications are allowed to a locked ParameterMap 解决方案
5
使用Composer安装Magento 2.4
使用Composer安装Magento 2.4
最新评论
一位WordPress评论者
一位WordPress评论者
2月12日
您好,这是一条评论。若需要审核、编辑或删除评论,请访问仪表盘的评论界面。评论者头像来自 Gravatar。