这是场景。

我的 Java Web 应用程序有以下路径

https://www.mywebsite.com:9443/MyWebApp

假设有一个 JSP 文件

https://www.mywebsite.com:9443/MyWebApp/protected/index.jsp

我需要检索

https://www.mywebsite.com:9443/MyWebApp 

在此 JSP 文件中。

当然,有一种相当懒惰和愚蠢的方法,只需获取 URL,然后重新跟踪路径即可。

但有没有一种程序化的方式来做到这一点?具体来说,我认为我可以获取域+端口,但是如何实际检索应用程序名称“MyWebApp”?

有帮助吗?

解决方案

Web 应用程序名称(实际上是上下文路径)可通过调用获得 HttpServletrequest#getContextPath() (因此不是 getServletPath() 正如之前有人建议的那样)。您可以通过以下方式在 JSP 中检索此内容 ${pageContext.request.contextPath}.

<p>The context path is: ${pageContext.request.contextPath}.</p>

如果您打算将其用于 JSP 页面中的所有相对路径(这将使这个问题更有意义),那么您可以使用 HTML <base> 标签:

<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%@taglib prefix="fn" uri="http://java.sun.com/jsp/jstl/functions" %>
<c:set var="req" value="${pageContext.request}" />
<c:set var="url">${req.requestURL}</c:set>
<c:set var="uri" value="${req.requestURI}" />

<!doctype html>
<html lang="en">
    <head>
        <title>SO question 2204870</title>
        <base href="${fn:substring(url, 0, fn:length(url) - fn:length(uri))}${req.contextPath}/">
        <script src="js/global.js"></script>
        <link rel="stylesheet" href="css/global.css">
    </head>
    <body>
        <ul>
            <li><a href="home.jsp">Home</a></li>
            <li><a href="faq.jsp">FAQ</a></li>
            <li><a href="contact.jsp">Contact</a></li>
        </ul>
    </body>
</html>

页面中的所有链接将自动相对于 <base> 这样您就不需要到处复制粘贴上下文路径。请注意,当相对链接以 /, ,那么它们就不会相对于 <base> 不再是这样,而是到域根目录。

其他提示

看看文件 HttpServletRequest.
为了建立URL例如,你将需要使用:

  • getScheme()
  • getServerName()
  • getServerPort()
  • getContextPath()

这里是一个方法,该方法将会回报你的例子:

public static String getURLWithContextPath(HttpServletRequest request) {
   return request.getScheme() + "://" + request.getServerName() + ":" + request.getServerPort() + request.getContextPath();
}

我强烈建议你通过的文档,对于类似的方法。如果你有兴趣在上下文路径,看看这里,的 ServletContext.getContextPath()

下面的代码可能是使用JavaScript的Web应用程序是有用的。

var newURL = window.location.protocol + "//"  + window.location.host + "" + window.location.pathname;

newURL = newURL.substring(0,newURL.indexOf(""));

如果你正在传递的URL作为字符串和要提取该应用程序的上下文根,则可以使用此正则表达式来提取它。它将为与上下文根开始完整的URL或相对URL工作。

url.replaceAll("^(.*\\/\\/)?.*?\\/(.+?)\\/.*|\\/(.+)$", "$2$3")
许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top