zoukankan      html  css  js  c++  java
  • JAVA中basepath的应用相对路径问题

      在JSP中的如果使用 "相对路径"  则有可能会出现问题. 因为 网页中的 "相对路径" , 他是相对于 "URL请求的地址" 去寻找资源.
    上面这句话是什么意思呢 ? 举个例子:
    假如我们有一个项目: MyApp 在该项目下, 有一个jsp文件夹 该文件夹下包括:
    login.jsp    // 登陆页面
    register.jps  // 注册页面
    我们在浏览器中输入地址 (注意: 地址的内容): http://localhost:8080/MyApp/jsp/login.jsp
    这时候, 浏览器会链接到 "登陆页面" (login.jsp)
    在login.jsp文件内包含了如下 "部分代码": <a href="jsp/register.jsp">注册用户 </a>
    那么,如果我们点击这个链接,就会在浏览器地址栏中, 出现如下错误链接: http://localhost:8080/MyApp/jsp/jsp/register.jsp
    为什么会出现"/jsp/jsp/register.jsp"呢?
    因为, 网页中的"相对链接", 是相对于你所 "请求的URL路径" 所决定的. 即:
    因为这里请求路径是:http://localhost:8080/MyApp/jsp/login.jsp
    那么, 浏览器 就会在这个路径下(即:http://localhost:8080/MyApp/jsp/)去找 jsp/register.jsp
    所以就会出现如下错误内容: http://localhost:8080/MyApp/jsp/jsp/register.jsp

    上面的问题,就是调用页面和被调用页面的URL不同所造成的,
    此类错误也常常会出现在2个页面之间进行 "转发"(forward) 操作的时候。
    因为forward是在后台进行的,对客户端来说是透明的。(即: URL不改变,而数据内容却是另一个页面返回来的。。。)

    那么如何解决这问题呢?
    (一)方法一:直接采用绝对路径 (不推荐)
    在JSP页面端,获得本项目的绝对地址(如果你的项目叫MyApp,那么获得到的地址就是 http://localhost:8080/MyApp/): 代码如下:

    Html代码
    1. <%@ page language="java" pageEncoding="GBK" contentType="text/html;charset=gbk" isELIgnored="false"%>    
    2. <%    
    3. String path = request.getContextPath();    
    4. // 获得本项目的地址(例如: http://localhost:8080/MyApp/)赋值给basePath变量    
    5. String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";    
    6. // 将 "项目路径basePath" 放入pageContext中,待以后用EL表达式读出。    
    7. pageContext.setAttribute("basePath",basePath);    
    8. %>    
    9. <html>    
    10. <head> </head>    
    11. <body>    
    12. <a href="${pageScope.basePath}jsp/register.jsp">    
    13. </body>    
    14. </html>   

     

    可以看到,在标签 <a>中的href属性内,我们直接采用了 “本项目路径 ${pageScope.basePath}” 加上 "jsp/register.jsp" , 从而构成一个绝对路径(即: http://localhost:8080/MyApp/jsp/register.jsp )

    但是这样做有一个很不好的地方,那就是我们必须要在每个链接的前面都要加上 “${pageScope.basePath}”
    如果这样做的话,将是一件很可怕的事情

    (二)方法二: 利用html中的 <base>标签 (推荐)
    下面是对html中的 <base>的介绍:
    base 元素可规定页面中所有链接的基准 URL 默认情况下,页面中的链接(包括样式表、脚本和图像的地址)都是相对于当前页面的地址(即:浏览器地址栏里的请求URL)。 我们可以使用 <base>标签中的href属性来设置,所有的“相对基准 URL”。

    上面说的是什么意思呢?
    这是JSP端的代码 下面的代码 (十分类似上面 "方法一" 中的JSP代码)
    但是这里我们并没有采用 ${pageScope.basePath}+"相对路径地址" 的方法,
    而是采用了html文件中的 <base>标签: 代码如下:

    Html代码
    1. <%@ page language="java" pageEncoding="GBK" contentType="text/html;charset=gbk" isELIgnored="false"%>    
    2. <%    
    3. String path = request.getContextPath();    
    4. // 获得项目完全路径(假设你的项目叫MyApp,那么获得到的地址就是 http://localhost:8080/MyApp/):    
    5. String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";    
    6. %>    
    7. <html>    
    8. <head>    
    9. <!-- base需要放到head中 -->    
    10. <base href=" <%=basePath%>">    
    11. </head>    
    12. // 这里我们就可以直接使用相对路径(即: 相对于base标签)    
    13. <a href="jsp/login.jsp">Login </a>    
    14. </html>   

    当我们去执行上面的那段JSP代码后,我们可以在浏览器中可以查看,他所返回给客户端的html代码:
    执行完上述JSP后,所返回的html代码如下:

    Java代码
    1. <html>    
    2. <head>    
    3. <base href="http://localhost:8080/MyApp/">    
    4. </head>    
    5. // 设置了 <base>后,相对路径,相对于的就是base中的路径,而不再是浏览器地址的请求路径啦~~~    
    6. <a href="jsp/login.jsp">Login </a>    
    7. </html>     

     可以看到JSP返回的html代码中,包含了 <base href="http://localhost:8080/MyApp/ ">内容。
    也就是说,在本html文件中,遇到的所有 “相对链接(例如: <a href="jsp/login.jsp">)”,都是相对于base
    的路径(即:http://localhost:8080/MyApp/),所以我们就可以进行的使用 相对链接,而不必担心,
    转发操作(forward)或 请求地址不同不同所造成的页面无法找到的错误了

    注: 利用myeclipse创建jsp页面时会自动加上

    Java代码
    1. <%      
    2. String path = request.getContextPath();      
    3. String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";      
    4. %>     
    5. <base href="<%=basePath%>">   

    作者:少帅

    出处:少帅的博客--http://www.cnblogs.com/wang3680

    您的支持是对博主最大的鼓励,感谢您的认真阅读。

    本文版权归作者所有,欢迎转载,但请保留该声明。

    支付宝 微信
  • 相关阅读:
    GithubPlus+PicGo + Typora 一键式图床
    快速掌握Linux这篇文章就够了。
    跨行程序员Java进阶--基础语法
    Prometheus(普罗米修斯)
    【学习记录】Golang
    服务器Docker-Compose 安装 Anaconda
    Kubernetes集群部署
    Jenkins部署
    Harbor部署
    Docker、Docker-Compose的安装以及相关使用
  • 原文地址:https://www.cnblogs.com/wang3680/p/3046595.html
Copyright © 2011-2022 走看看