JSP Servlet 路徑解析 路徑設置

轉自:http://ethen.iteye.com/blog/800415javascript

 

在用JSP和Servlet編寫Web應用時,常常遇到的問題就是找不到.do路徑,或者.do路徑不能解析,其實歸根到底就是Servlet路徑設置的問題,本文將結合實例來進行講解。css

    首先,web應用名爲MyApp,應用部署容器爲Tomcat。html

    目錄結構以下所示:  java

—MyAppweb

  —WEB-INF/瀏覽器

    —classes/服務器

      —login.classesapp

      —login.java框架

    —lib/webapp

    —web.xml

  —index.jsp

  —pages/

    —login.jsp

 

     web.xml 中配置

 

<servlet> 
  <servlet-name>loginhandle</servlet-name>
   <servlet-class>/login</servlet-class>
 </servlet> 
<servlet-mapping>
   <servlet-name>loginhandle</servlet-name>
   <url-pattern>/login.do</url-pattern> 
</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中。

三、../one.css:表示one.css位於a.hmtl上一級目錄下,

四、../../one.css:表示one.css位於a.hmtl上一級目錄的上一級目錄下,

五、./:表示和a.hmtl同一目錄

咱們稱上述相對路徑爲html相對路徑。

 

服務器端的地址

    服務器端的相對地址指的是相對於你的web應用的地址,這個地址是在服務器端解析的(不一樣於html和javascript中的相對地址,他們是由客戶端瀏覽器解析的)也就是說這時候在jsp和servlet中的相對地址應該是相對於你的web應用,即相對於http://localhost:8080/MyApp/的。

   其用到的地方有:

forwarder:servlet中的request.getRequestDispatcher(address);這個address是在服務器端解析的,因此,你要forwarder到login.jsp應該這麼寫:request.getRequestDispatcher("/pages/login.jsp")這個/相對於當前的web應用webapp,其絕對地址就是:http://localhost:8080/MyApp/pages/login.jsp

sendRedirect:在jsp中<%response.sendRedirect("/pages/login.jsp");%>

 

客戶端的地址

   全部的html中的相對地址都是相對於http://localhost:8080/的,而不是http://localhost:8080/MyApp/的。

    Html中的form表單的action屬性的地址應該是相對於http://localhost:8080/的,因此,若是提交到login.jsp爲:action="/MyApp/pages/login.jsp";提交到servlet爲action="/MyApp/login.do"

   Javascript也是在客戶端解析的,因此其相對路徑和form表單同樣。

 

站點根目錄和css路徑問題

咱們稱相似這樣的相對路徑/MyApp/...爲相對於站點根目錄的相對路徑。

當在jsp中引入css時,若是其相對路徑相對於當前jsp文件的,而在一個和這個jsp的路徑不同的servlet中forwarder這個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的文件的相對路徑。而在servlet中轉發時就是相對於這個servlet的相對路徑了,由於jsp路徑和servlet路徑是不同的,因此這樣的引用確定是出錯的。

因此這個時候,要用站點根目錄,就是相對於http://localhost:8080/的目錄,以"/"開頭。

所以上述錯誤應更正爲href="/MyApp/one.css"相似的站點根目錄的相對目錄。這樣在servlet轉發後和jsp中都是相對於站點根目錄的相對路徑,就能正確使用所定義的css樣式了。

 

看到這裏,相信在路徑設置方面應該有一些小成了吧。再看下面這幾個實例。

 

一、 在index.jsp中有<form action="login.do" method="post"></form>,而且該頁面的訪問地址是http://localhost:8080/MyApp/login.do。此處使用的是相對路徑,其中相對路徑是相對於當前訪問的頁面,而當前頁面爲index.jsp因此當前的上下文路徑即爲/MyApp。當提交表單後,瀏覽器地址欄中的信息變爲http://localhost:8080/MyApp/login.do,這時候能找到login.do由於已經配置到了web.xml文件中。若是在/pages/login.jsp中包含上面的form表單,則最後的瀏覽器信息會變爲http://localhost:8080/MyApp/pages/login.do。頁面確定會提示錯誤,由於找不到該路徑。

二、在web.xml中的<servlet-mapping>中的<url-pattern>標記中只能使用絕對路徑,即必需要以"/"開頭。能夠這樣理解:一個應用對應於一個web.xml,因此這裏的絕對路徑表示應用的根,而不是服務器的根。(一個特殊狀況就是在<url-pattern>中使用模式匹配的*.do,但仍然應該理解成從/開始。)

三、RequestDispatcher view = request.getRequestDispatcher("/pages/login.jsp");

   RequestDispatcher view = request.getRequestDispatcher("pages/login.jsp");

  這裏可使用相對路徑和絕對路徑。相對路徑是當執行到該代碼所在的Servlet的時候地址欄上顯示的路徑。

  若是使用絕對路徑,則"/"表示應用的根。

四、RequestDispatcher view = getServletContext().getRequestDispatcher("/pages/login.jsp");

  這裏必須使用絕對路徑,"/"表示應用的根。能夠這麼理解:在ServletContext上調用請求轉發,若是使用相對路徑,則沒法得知到底相對於該應用的什麼位置,只能根據絕對路徑來判斷。因爲是在應用上下文上調用的方法,因此"/"就表示應用的根。

五、servletContext中的getResourceAsStream(String),其中的參數應該是以"/"開頭的絕對路徑,其中"/"表示應用的根。

 

    若是應用struts框架,那麼恭喜你,這些事struts都幫你作了。在struts中,<html:form> 標籤自動將action的路徑解析爲應用路徑。

相關文章
相關標籤/搜索