JSP、Servlet中的相對路徑和絕對路徑 頁面跳轉問題

weixin_33890499發表於2016-06-21

**1.JSP、Servlet中的相對路徑和絕對路徑 **
前提:假設你的Http地址為http://192.168.0.1/你的web應用為test,path="/test"那麼你的web應用URL為http://192.168.0.1/test/
如果JSP,JS檔案放在WEB-INF目錄下根本無法訪問的,JSP如果放在WEB-INF目錄下可以通過伺服器內部轉向進行訪問(主要是為了頁面的安全),但是JS是通過客戶端向伺服器請求的,所以圖片以及一些JS,CSS只能放在WEB-INF外面 web應用的目錄結構: test/web/
css/ js/
test.js
web-inf/ classes/ lib/ user/ a.jsp b.jsp images/ web.xml <servlet-mapping> <servlet-name>handleservlet</servlet-name> <url-pattern>/handleservlet</url-pattern>此對映是相對於當前web應用的 </servlet-mapping> 所有相對路徑都是由"/"開頭的 。如:/image/a.gif,/user/main.jsp,大家知道在html中的相對路徑是這樣的:
有個html檔案:a.html,其中有<link href="one.css" rel="stylesheet" type="text/css">,其中href屬性表示引用的css檔案的路徑。 one.css:表示one.css和a.hmtl處於同一個目錄 user/one.css:表示one.css處於a.html所在目錄的子目錄user中,即user是a.html在同一個目錄 。 ../one.css:表示one.css位於a.hmtl上一級目錄下, ../../one.css:表示one.css位於a.hmtl上一級目錄的上一級目錄下, ./:表示和a.hmtl同一目錄 我們稱上述相對路徑為html相對路徑
1、 伺服器端的地址 伺服器端的相對地址指的是相對於你的web應用的地址,這個地址是在伺服器端解析的 (不同於html和JavaScript中的相對地址,他們是 由客戶端瀏覽器解析的 )也就是說這時候在jsp和servlet中的相對地址應該是相對於你的web應用,即相對於http://192.168.0.1/test/的。 其用到的地方有: forward:servlet中的request.getRequestDispatcher(address);這個address是在伺服器端解析的,所以,你要forwarder到user/a.jsp應該這麼寫:request.getRequestDispatcher("/user/a.jsp ")這個/相對於當前的web應用test,其絕對地址就是:http://192.168.0.1/test/user/a.jsp。 redirect:在jsp中<%response.sendRedirect("/rtccp/user/a.jsp");%> 2、 客戶端的地址 所有的html中的相對地址都是相對於http://192.168.0.1/的,而不是http://192.168.0.1/test/的 。 Html中的form表單的action屬性的地址應該是相對於http://192.168.0.1/的,所以,如果提交到user/a.jsp為:action="/test/ user/a.jsp" ;提交到servlet為action="/test/handleservlet" Javascript也是在客戶端解析的,所以其相對路徑和form表單一樣。 3、 站點根目錄和css路徑問題 (jsp是伺服器端程式,地址是變化的,引用時一般用站點根目錄的相對路徑) 我們稱類似這樣的相對路徑/test/…. 為相對於站點根目錄 的相對路徑 。 當在jsp中引入css時,如果其相對路徑相對於當前jsp檔案的,而在一個和這個jsp的路徑不一樣的servlet中forward這個jsp時,就會發現這個css樣式根本沒有起作用。這是因為在servlet中轉發時css的路徑就是相對於這個servlet的相對路徑而非jsp的路徑了。所以這時候不能在jsp中用這樣的路徑:<link href="one.css" rel="stylesheet" type="text/css">或者<link href="../../one.css" rel="stylesheet" type="text/css">類似href="one.css"和../../one.css的html相對路徑是相對於引用這個css的檔案(a.jsp)的相對路徑 。而在servlet中轉發時就是相對於這個servlet的相對路徑了,因為jsp路徑和servlet路徑是不一樣的 ,所以這樣的引用肯定是出錯的。 所以這個時候,要用站點根目錄,就是相對於http://192.168.0.1/的目錄,以“/”開頭。 因此上述錯誤應更正為href=”/test/one.css” 類似的站點根目錄的相對目錄。這樣在servlet轉發後和jsp中都是相對於站點根目錄的相對路徑 ,就能正確使用所定義的css樣式了。

頁面跳轉問題:

Forward 高, Redirect 低, 因為Redirect 的流程是這樣的, request1 sent to server, server return back to client, 然後
request2 then sent to server. 但是Forward 僅在server side處理, 對client side 是透明的. 由於Redirect 有兩次傳輸, 所以效率低. 範圍: 由於對request.setAttribute() 來說, 它攜帶的物件生存範圍只在request內, 所以Redirect 方式會導致request攜帶的物件丟失.

使用說明:
1. sendRedirect
servlet和jsp裡面一樣
response.sendRedirect();

**2. **include 這種也是上面提到的forward形式,request的值會儲存
1) servlet裡面
request.getRequestDispatcher( "jsp2.jsp" ).include(request, response);
2) jsp裡面
<jsp:include page= "include.jsp" />
說明 頁面會同時包含頁面1和頁面2的內容,位址列不變。 使用request.setAttribute的內容,可以正常使用

3. forword
1) servlet裡面
request.getRequestDispatcher( "jsp2.jsp" ).forward(request, response); 2) jsp裡面
<jsp:forward page= "include.jsp" />
說明 頁面會是頁面2的內容,位址列不變 使用request.setAttribute的內容,可以正常使用


3.JSP中用相對路徑引用JS,CSS檔案的三種情況
** 第一種情況** 最常見的情況 一個tomcat上都跑多個工程, 用工程名來區分 因為我的的URL是 :http://localhost/工程名 /home/index.jsp 多了一個工程名,所以要加 <%=request.getContextPath() %> 如:<script src="<%=request.getContextPath() %> /home/test.js"></script>
寫<%=request.getContextPath() %>太麻煩,可以在每一個jsp檔案頂部加入以下內容後,

Java程式碼

<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://" +request.getServerName()+":"+request.getServerPort()+path+"/" ;
%>
<base href="<%=basePath%>" >

 就可直接使用 <script src=" /home/test.js"></script>了

** 第二, 直接訪問jsp檔案** 真實專案中, 一個tomcat上要是也跑了多個工程, 並用IP來區分 url 是這樣的: http://localhost/home/index.jsp 注意這裡,是直接訪問JSP檔案(jsp檔案不在web-inf下,可以直接訪問),不是servlet也不是struts 。 test2.js 與index.jsp 放在同一資料夾下,下面用相對路徑來引入JS檔案 是OK 的: <script src=test2.js></script>
index.jsp可以找到test2.js檔案

第三種情況: servlet轉發到jsp(jsp在web-inf下,必須用servlet或action訪問)
在第二情況的基礎上,一個tomcat上要是也跑了多個工程, 並用IP來區分。
我們訪問的是servlet 或是struts的action , 再轉發到 ****index.jsp url 是: http://localhost/***.do
url 是: http://localhost/index.action
這裡不是訪問JSP檔案了

下面是OK 的.     <script src=/home/ test2.js></script>
test2.js 前面一定要有/home/
實際專案中, 訪問 servlet或是struts的action最多, 所以這裡要使用<script src=/home/test2.js></script>。

相關文章