"/"代表webapps目錄的常見應用場景

①.使用sendRedirect實現請求重定向

1 response.sendRedirect("/JavaWeb_HttpServletResponse_Study_20140615/index.jsp");

  服務器發送一個URL地址給瀏覽器,瀏覽器拿到URL地址之後,再去請求服務器,所以這個"/"是給瀏覽器使用的,此時"/"代表的就是webapps目錄,"/JavaWeb_HttpServletResponse_Study_20140615/index.jsp"這個地址指的就是"webapps\JavaWeb_HttpServletResponse_Study_20140615\index.jsp"

  response.sendRedirect("/項目名稱/文件夾目錄/頁面");這種寫法是將項目名稱寫死在程序中的做法,不靈活,萬一哪天項目名稱變了,此時就得改程序,所以推薦使用下面的靈活寫法:

1 response.sendRedirect("/JavaWeb_HttpServletResponse_Study_20140615/index.jsp");

  這種寫法改成

1 response.sendRedirect(request.getContextPath()+"/index.jsp");

  request.getContextPath()獲取到的內容就是"/JavaWeb_HttpServletResponse_Study_20140615",這樣就比較靈活了,使用request.getContextPath()代替"/項目名稱",推薦使用這種方式,靈活方便!

②.使用超鏈接跳轉

1 <a href="/JavaWeb_HttpServletResponse_Study_20140615/index.jsp">跳轉到首頁</a>

  這是客戶端瀏覽器使用的超鏈接跳轉,這個"/"是給瀏覽器使用的,此時"/"代表的就是webapps目錄。

  使用超鏈接訪問web資源,絕對路徑的寫法推薦使用下面的寫法改進:

1 <a href="${pageContext.request.contextPath}/index.jsp">跳轉到首頁</a>

  這樣就可以避免在路徑中出現項目的名稱,使用${pageContext.request.contextPath}取代"/JavaWeb_HttpServletResponse_Study_20140615"

③.Form表單提交

1 <form action="/JavaWeb_HttpServletResponse_Study_20140615/servlet/CheckServlet" method="post">    
2         <input type="submit" value="提交">
3 </form>

  這是客戶端瀏覽器將form表單提交到服務器,所以這個"/"是給瀏覽器使用的,此時"/"代表的就是webapps目錄。

 對於form表單提交中action屬性絕對路徑的寫法,也推薦使用如下的方式改進:

1 <form action="${pageContext.request.contextPath}/servlet/CheckServlet" method="post">
2          <input type="submit" value="提交">
3 </form>

  ${pageContext.request.contextPath}得到的就是"/JavaWeb_HttpServletResponse_Study_20140615"

  ${pageContext.request.contextPath}的效果等同於request.getContextPath(),兩者獲取到的都是"/項目名稱"

 

<%--使用絕對路徑的方式引用js腳本--%>
 <script type="text/javascript" src="${pageContext.request.contextPath}/js/index.js"></script>
 <%--${pageContext.request.contextPath}與request.getContextPath()寫法是得到的效果是一樣的--%>
 <script type="text/javascript" src="<%=request.getContextPath()%>/js/login.js"></script>
 <%--使用絕對路徑的方式引用css樣式--%>
 <link rel="stylesheet" href="${pageContext.request.contextPath}/css/index.css" type="text/css"/>
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <title>"/"代表webapps目錄的常見應用場景</title>
    <%--使用絕對路徑的方式引用js腳本--%>
    <script type="text/javascript" src="${pageContext.request.contextPath}/js/index.js"></script>
    <%--${pageContext.request.contextPath}與request.getContextPath()寫法是得到的效果是一樣的--%>
    <script type="text/javascript" src="<%=request.getContextPath()%>/js/login.js"></script>
    <%--使用絕對路徑的方式引用css樣式--%>
      <link rel="stylesheet" href="${pageContext.request.contextPath}/css/index.css" type="text/css"/>
  </head>
  
  <body>
      <%--form表單提交--%>
       <form action="${pageContext.request.contextPath}/servlet/CheckServlet" method="post">
           <input type="submit" value="提交">
       </form>
       <%--超鏈接跳轉頁面--%>
       <a href="${pageContext.request.contextPath}/index.jsp">跳轉到首頁</a>
  </body>
</html>

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章