zoukankan      html  css  js  c++  java
  • jsp/html页面中的路径

    Html/Jsp页面中的路径,是供浏览器使用的。“/”代表的是服务器根目录,一个服务器会有多个web应用,所以请求资源时需要加应用名才能正确访问。

    页面中使用的相对路径,也是由浏览器根据当前页面的url或<base>元素解析成完整请求路径的。

    页面中使用路径的常用方式如下:

    1.当前应用的根路径+静态资源的相对路径:

    <link type="stylesheet" href="${pageContext.request.contextPath}/satic/ css/common.css">
    <form action="${pageContext.request.contextPath}/servlet/login" method="post">

    浏览器解析时会将”/”解析为服务器。如果不加当前应用的根路径,有可能会错误地把static当作应用名,取决于部署时path的设置。所以最好统一添加应用的根路径。

    获取当前应用的根路径:

      EL表达式:${pageContext.request.contextPath};  

      JSP:<% =request.getContextPath() %>

    若工程文件就是在根目录下,通过request.getContextPath()返回的字符串为空。

    2.当前应用的绝对路径+静态资源的相对路径:

    <%@ page language="java" pageEncoding="GBK" contentType="text/html;charset=gbk" isELIgnored="false"%>
    <%
      String appContext= request.getContextPath();//  获取当前应用的根路径构建当前应用的绝对路径(/appName)
      String basePath = request.getScheme() + "://" + request.getServerName() + ":" + request.getServerPort() + appContext ;
      // 将basePath存入pageContext中,将来用EL表达式读取
      pageContext.setAttribute("basePath",basePath);
    %>
    <html>
        <body>
            <a href="${pageScope.basePath}/jsp/login.jsp">
        </body>
    </html>

    缺点:每个请求前都要加${pageScope.basePath}

     

    3.利用<base>标签

    默认情况下,页面中相对路径的请求都是相对于当前页面的url发出的;如果当前页面存在<base>标签,则请求是相对<base>中设定的值。

    <%@ page language="java" pageEncoding="GBK" contentType="text/html;charset=gbk" isELIgnored="false"%>
    <%
        String appContext= request.getContextPath();// 获得当前应用的根路径
        String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort() + appContext ;
    %>
    <html>
        <head>
           <base href="<%=basePath%>">      <!--设定base标签-->
        </head>
        <body>
            <a href="/jsp/login.jsp">Login</a>
        </body>
    </html>

    缺点: 对于被包含的文件依然无效。

    Servlet内所有的路径都要用绝对路径,即以”/”开头,代表当前的web应用。

    req.getRequestDispatcher("/pages/login.jsp").forward(req, resp);转发路径中”/”代表当前应用。   

    以上皆为个人理解,如有错误之处,欢迎留言指正。
  • 相关阅读:
    欢天喜地七仙女——Alpha冲刺(11.30)第六天
    欢天喜地七仙女——Alpha冲刺(11.29)第五天
    欢天喜地七仙女——Alpha冲刺(11.28)第四天
    欢天喜地七仙女——Alpha冲刺(11.27)第三天
    欢天喜地七仙女——Alpha冲刺(11.26)第二次
    欢天喜地七仙女——Alpha冲刺(11.25)第一天
    fist-总结随笔
    fist-第十天随笔
    fist-第九天冲刺随笔
    fist-第八天冲刺随笔
  • 原文地址:https://www.cnblogs.com/kevin2chen/p/6542690.html
Copyright © 2011-2022 走看看