web工程中URL地址的推薦寫法

在javaWeb開發中,只要是寫URL地址,那麼建議最好以「/」開頭,也就是使用絕對路徑的方式,那麼這個「/」到底表明什麼呢?能夠用以下的方式來記憶「/」:若是「/」是給服務器用的,則表明當前的web工程,若是「/」是給瀏覽器用的,則表明webapps目錄javascript

1.「/」表明當前web工程的常見應用場景css

a.ServletContext.getRealPath(String path) 獲取資源的絕對路徑html

1 /*
2 ServletContext.getRealPath("/down.jpg")是用來獲取服務器上的某個資源,這裏的「/」就是給服務器用的,表明此時的web工程
3 */
4 this.getServletContext().getRealPath("/down.jpg")

b.在服務器端forward到其餘頁面java

1 /*
2 forward
3 客戶端請求某個web資源,服務器跳轉到另外一個web資源,這個forward也是給服務器用的,此時「/」表明的就是web工程
4 */
5 this.getServletContext().getRequestDispatcher("/index.jsp").forward(request,response);

c.使用include指令或者<jsp:include>標籤引入頁面web

1 <%@include file="jsp/head.jsp"%>
2 <jsp:include page="jsp/index.jsp"/>

 

2."/"表明webapp目錄的常見應用場景瀏覽器

a.使用sendRedirect實現請求重定向服務器

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

服務器發送一個url地址給瀏覽器,瀏覽器拿到url地址以後,再去請求服務器,因此這裏的「/」是給瀏覽器使用的,此時「/」表明的就是webapp目錄,app

"/JavaWeb_HttpServletResponse_Study/index.jsp"
這個地址指的是"webapp/JavaWeb_HttpServletResponse_Study/index.jsp"

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

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

request.getContextPath()獲取到的內容就是「jsp

"/JavaWeb_HttpServletResponse_Study"

這樣就比較靈活了

2.使用超連接跳轉

1 <!--這是客戶端使用的超連接跳轉,'/'表示的是webapp的目錄,可是這種寫法不靈活-->
2 <a href="/JavaWeb_HttpServletResponse_Study/index.jsp">跳轉到首頁</a>
3 <!--推薦使用如下方式,這樣能夠避免把項目的名稱寫死-->
4 <a href="${pageConetxt.request.contextPath}/index.jsp">跳轉到首頁</a>

3.Form表單提交

1 <!--第一種寫法,這是客戶端瀏覽器將表單提交到服務器,這裏的‘/’表示的webapp目錄,可是這種寫法將項目名稱寫死,不靈活,不推薦使用-->
2 <form action="/JavaWeb_HttpServletResponse_Study/servley/CheckServlet" method="post">
3     <input type="submit" value="submit">
4 </form>
5 
6 <!--第二種寫法,使用絕對絕對路徑寫法,這裏的${pageContext.request.contextPath}等價於request.getContextPath(),二者獲取的都是「/項目名稱」,即"/JavaWeb_HttpServletResponse_Study"-->
7 <form action = "${pageContext.request.contextPath}/servlet/CheckServlet" method="post">
8     <input type="submit" value="submit"/>
9 </form>

4.js腳本和css樣式文件的引用

1 <%--使用絕對路徑的方式引用js腳本 --%>
2 <script type="text/javascript" src="${pageContext.request.contextPath}/js/index.js">
3 </script>
4 
5 <%--使用絕對路徑的方式引用css樣式--%>
6 <link rel="stylesheet" href="${pageContext.request.contextPath}/css/index.css"/>

參考連接:

https://www.cnblogs.com/xdp-gacl/p/3791993.html

相關文章
相關標籤/搜索