Https被sendRedirect到Http

项目通过Nginx配置HTTPS,但后端使用sendRedirect导致返回HTTP,前端报错。分析表明sendRedirect实为客户端重定向,而请求转发为服务器行为。解决方法包括使用请求转发、设置响应状态码和头信息,或者强制转换到HTTPS。
摘要由CSDN通过智能技术生成

遇到的问题

最近,在项目中遇到了一个比较棘手的问题:

  • 项目服务器通过nignx配置CA证书,将https请求转发到http,从而支持https
  • 项目前后端分离,后台向前端提供restapi接口
  • 后台也配置了https转发,支持https请求
  • 当前端调用后台某个接口时,后台内部使用 sendRedirect 做服务器内部跳转,服务器内部跳转之后,返回给前端的是一个http请求,导致前端不支持https请求http而报header错误的信息(问题所在

分析

sendRedict 的实质是让请求在服务器中做了两次跳转

请求转发forward与请求重定向sendRedirect的区别:

  • 请求重定向:客户端行为,response
    sendRedirect() 从本质上将等同于两次请求,前一次请求的请求对象不会保存,地址栏的URL地址会改变。

  • 请求转发:服务器行为,request
    getRequestDispatcher().forward(req, resp) 是一次请求,转发后请求对象会保存,地址栏的URL地址不会改变

解决方法

1.使用forward


                
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值