gpt4 book ai didi

java - 404 与 response.sendRedirect

转载 作者:塔克拉玛干 更新时间:2023-11-03 03:54:39 41 4
gpt4 key购买 nike

我正在为我的应用程序使用 spring 安全登录机制并测试了所有内容。一切正常。我有以下用例

  1. 如果客户未登录,应用程序会将客户重定向到登录页面。
  2. 成功登录后,应用程序会将客户重定向回他们被重定向到登录页面的同一页面

这是用于将用户重定向到其原始位置的 Java 代码

final SavedRequest savedRequest = this.requestCache.getRequest(request, response);
targetUrl = savedRequest.getRedirectUrl();
getRedirectStrategy().sendRedirect(request, response, targetUrl);

这里使用的 RedirectionStrategy 是 DefaultRedirectStrategy ,一切正常。应用程序现在部署在预生产服务器上,现在这似乎不起作用,我收到 404 错误。

当客户被重定向到主页时,targetUrl 显示为“/”,我有一个以此映射命名的 Spring Controller

@RequestMapping("/")
public class HomePageController{ // home page code }

我的应用程序当前的 Pre-Prod urs 是 prepd-www.mysite.com 所以当 sendredirect 开始行动时,网页 URL 正在更改为 prepd-www.mysite.com/prepd-www.mysite.com

我不确定是什么导致了这个问题。是因为代理服务器设置?谁能告诉我这个问题的可能根本原因?

我已经在所有本地机器上试过了,在我们的 QA 上也试过了,但一切都运行良好。

发生这种情况的环境的当前设置是

  1. 我们有 4 个应用服务器
  2. 我们有一个负载均衡器,它将流量重定向到其中一个应用服务器。

最佳答案

这只是一个大胆的猜测,因为您无法提供反向代理配置,也无法提供预生产和开发中使用的确切 URL。

你说你正在使用来自 Spring security 的 DefaultRedirectStrategy。此策略有一个选项 (contextRelative),将 ServletContext 路径添加到 URL。如果在您的开发系统中您正在使用根上下文,也就是说,如果您正在访问主页(例如):http://localhost:8080/ serlet 上下文为空。

但是如果现在在 preprod 中,servlet 上下文不再是 root 而是说 /myApp 一旦被 apache 反向代理翻译,当你重定向时你会得到一个 URL /myApp/myApp 可以转换回您提供的内容。

您可以尝试在 DefaultRedirectStrategy 中控制是否将 contextRelative 设置为 true 如果是,则可以将 if 设置为 false 并控制如果您重定向到绝对或相对 URL。

关于java - 404 与 response.sendRedirect,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27057399/

41 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com