當前位置:首頁 » 文件傳輸 » 攔截器如何不訪問靜態資源
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

攔截器如何不訪問靜態資源

發布時間: 2023-01-31 20:24:34

『壹』 Spring mvc 中,怎麼用註解配置靜態資源不需要被控制器調用

Spring MVC搭建項目的時候,想使用html頁面作為前端的視圖,你會發現html頁面不能訪問,原因是由於Spring攔截器將其攔截尋找控制器的緣故,解決辦法就是配置靜態資源:

1 <mvc:resources mapping="/js/*.js" location="/js/" />
2 <mvc:resources mapping="/**/*.html" location="/html/" />
3 <!-- <mvc:resources location="/" mapping="/**/*.html"/>
4 <mvc:resources location="/" mapping="/**/*.js"/>
5 <mvc:resources location="/" mapping="/**/*.css"/>
6 <mvc:resources location="/" mapping="/**/*.png"/>
7 <mvc:resources location="/" mapping="/**/*.gif"/> -->

『貳』 SpringMVC框架,controller層返回頁面不能訪問靜態資源的問題。

如果你的spring-mvc配置了請求攔截器,那你可以用轉發的方法跳轉到你想要的頁面,這是請求攔截:

『叄』 spring mvc的靜態資源攔截器怎麼配置

初學者基本上使用1,2,3方案:

  1. 所有請求全部攔截,都在spring mvc 處理,靜態資源如下配置

    <mvc:resources mapping="/images/**" location="/images/" cache-period="31556926"/>

  2. 所有請求全部攔截,但是在web.xml中添加對靜態資源的默認訪問,如下

    <servlet-mapping>
    <servlet-name>default</servlet-name>
    <url-pattern>*.jpg</url-pattern>
    </servlet-mapping>

  3. 所有請求全部攔截,在springmvc配置文件中添加如下,這種方式對spring版本必須要求3.0.5及以上。

    <mvc:default-servlet-handler/>

  4. 然後是我極力推薦的一種,web.xml中配置DispatcherServlet的時候mapping如下配置,url-pattern不要全部攔截,把需要springmvc處理的請求添加自定義頭。這種方法性能最好。

    <servlet-mapping>
    <servlet-name>spring</servlet-name>
    <url-pattern>/自定義</url-pattern>
    </servlet-mapping>

『肆』 springMVC的攔截器不攔截直接訪問jsp的請求

你好,分享一下我的攔截器,多多指教,代碼如下:

在spring的配置文件裡面進行配置攔截器

<!-- 攔截器 -->
<mvc:interceptors>
<mvc:interceptor>
<!-- 對所有的請求攔截使用/**-->
<mvc:mapping path="/**" />
<ref bean="userAccessInterceptor" />
</mvc:interceptor>
</mvc:interceptors>
<bean id="userAccessInterceptor"class="com.web.interceptor.UserAccessInterceptor"></bean>

攔截器如下設置,當用戶未登錄時,返回到登錄頁面
class UserAccessInterceptor extends HandlerInterceptorAdapter {

@Override
public boolean preHandle(HttpServletRequest request,HttpServletResponse response, Object handler) throws Exception {
//靜態資源直接return true
if(handler instanceof ResourceHttpRequestHandler){
return true;
}
if(Utils.isNull(UserCookie.getApploginUserId())){
response.sendRedirect(request.getContextPath()+"/login.jsp");
return false;
}
return true;
}

『伍』 過濾器、監聽器、攔截器的區別

過濾器:是web伺服器的,可以攔截任何資源。
監聽器:是web伺服器的,監聽特定事件。
攔截器:是SpringMVC的,不會攔截靜態資源,只會攔截訪問的控制器方法handler,攔截的時機是handler運行前、運行完了但未跳轉頁面之前、跳轉頁面之後。

『陸』 springmvc怎麼在攔截頁面

一、我們都知道在基於Spring的Application中,需要在web.xml中增加下面類似的配置信息:

此處需要特別強調的是 /使用的是/,而不是/*,如果使用/*,那麼請求時可以通過DispatcherServlet轉發到相應的Action或者Controller中的,但是返回的內容,如返回的jsp還會再次被攔截,這樣導致404錯誤,即訪問不到jsp。所以如果以後發現總是有404錯誤的時候,別忘了check一下 /的配置是否是/*.
二、其實Spring 的Servlet攔截器匹配規則(即 ... )都可以自己定義,例:當映射為@RequestMapping("/user/add")時
1、攔截*.do、*.htm, 例如:/user/add.do
這是最傳統的方式,最簡單也最實用。不會導致靜態文件(jpg,js,css)被攔截。
2、攔截/,例如:/user/add
可以實現現在很流行的REST風格。很多互聯網類型的應用很喜歡這種風格的URL。
弊端:會導致靜態文件(jpg,js,css)被攔截後不能正常顯示。想實現REST風格,事情就是麻煩一些。後面有解決辦法還算簡單。
3、攔截/*,這是一個錯誤的方式,請求可以走到Action中,但轉到jsp時再次被攔截,不能訪問到jsp。
三、如何訪問到靜態的文件,如jpg,js,css?
如果你的DispatcherServlet攔截"*.do"這樣的有後綴的URL,就不存在訪問不到靜態資源的問題。

如果你的DispatcherServlet攔截"/",為了實現REST風格,攔截了所有的請求,那麼同時對*.js,*.jpg等靜態文件的訪問也就被攔截了。

我們要解決這個問題。
目的:可以正常訪問靜態文件,不可以找不到靜態文件報404。
方案一:激活Tomcat的defaultServlet來處理靜態文件

特點:1. 要配置多個,每種文件配置一個。
2. 要寫在DispatcherServlet的前面, 讓 defaultServlet先攔截請求,這樣請求就不會進入Spring了。
3. 高性能。
備註:
Tomcat, Jetty, JBoss, and GlassFish 自帶的默認Servlet的名字 -- "default"
Google App Engine 自帶的 默認Servlet的名字 -- "_ah_default"
Resin 自帶的 默認Servlet的名字 -- "resin-file"
WebLogic 自帶的 默認Servlet的名字 -- "FileServlet"
WebSphere 自帶的 默認Servlet的名字 -- "SimpleFileServlet"
方案二: 在spring3.0.4以後版本提供了mvc:resources , 使用方法:

images/**映射到 ResourceHttpRequestHandler進行處理,location指定靜態資源的位置.可以是web application根目錄下、jar包裡面,這樣可以把靜態資源壓縮到jar包中。cache-period 可以使得靜態資源進行web cache

如果出現下面的錯誤,可能是沒有配置的原因。
報錯WARNING: No mapping found for HTTP request with URI [/mvc/user/findUser/lisi/770] in DispatcherServlet with name 'springMVC'

使用元素,把mapping的URI注冊到SimpleUrlHandlerMapping的urlMap中,
key為mapping的URI pattern值,而value為ResourceHttpRequestHandler,
這樣就巧妙的把對靜態資源的訪問由HandlerMapping轉到ResourceHttpRequestHandler處理並返回,所以就支持classpath目錄,jar包內靜態資源的訪問.
另外需要注意的一點是,不要對SimpleUrlHandlerMapping設置defaultHandler.因為對static uri的defaultHandler就是ResourceHttpRequestHandler,
否則無法處理static resources request.
方案三 ,使用

會把"/**" url,注冊到SimpleUrlHandlerMapping的urlMap中,把對靜態資源的訪問由HandlerMapping轉到 org.springframework.web.servlet.resource. 處理並返回.
使用就是各個Servlet容器自己的默認Servlet.
補充說明:多個HandlerMapping的執行順序問題:
的order屬性值是:0

<<SPAN class="Apple-converted-space"> mvc:resources/ > 自動注冊的 SimpleUrlHandlerMapping 的order屬性值是: 2147483646
自動注冊 的SimpleUrlHandlerMapping 的order屬性值是: 2147483647
spring會先執行order值比較小的。當訪問一個a.jpg圖片文件時,先通過 來找處理器,一定是找不到的,因為我們沒有叫a.jpg的Action。然後再按order值升序找,由於最後一個 SimpleUrlHandlerMapping 是匹配 "/**"的,所以一定會匹配上,就可以響應圖片。 訪問一個圖片,還要走層層匹配。不知性能如何?
最後再說明一下,方案二、方案三 在訪問靜態資源時,如果有匹配的(近似)總攔截器,就會走攔截器。如果你在攔截中實現許可權檢查,要注意過濾這些對靜態文件的請求。
如何你的DispatcherServlet攔截 *.do這樣的URL後綴,就不存上述問題了。還是有後綴方便。

『柒』 SpringMVC 攔截器問題

mvc:exclude-mapping 標簽不被spring-mvc-3.0.xsd支持,該配置在spring-mvc-3.2.xsd中,可以通過http://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd獲取,因此需要在spring-mvc-3.0.xsd文件中增加該標簽,處理辦法很簡單,從網上下載spring-mvc-3.2.xsd,找到標簽後,再找到spring.web.servlet-3.0.5.jar中的spring-mvc-3.0.xsd文件,將標簽加入即可

『捌』 使用springMVC的攔截器驗證登錄時,攔截器攔截了靜態的資源該怎麼解決

springmvc攔截器定義後,還需要在springmvc框架的配置文件中注冊,同時設置攔截的url路徑,即會造成對controller攔截的同時也對訪問的js和css文件進行攔截,可以通過配置不攔截js和css,例子如下

js和css放在web應用的static目錄下

<mvc:interceptors>
<mvc:interceptor>
<mvc:mappingpath="/**"/>
<mvc:exclude-mappingpath="/static/**"/>--設置不攔截static下資源
<beanclass="cn.sxt.rbac.interceptor.LoginInterceptor"></bean>
</mvc:interceptor>
<mvc:interceptor>
<mvc:mappingpath="/**"/>
<mvc:exclude-mappingpath="/static/**"/>--設置不攔截static下資源
<beanclass="cn.sxt.rbac.interceptor.UrlInterceptor"></bean>
</mvc:interceptor>
</mvc:interceptors>

這樣在攔截controller同時,不會對static裡面的js、css或者其他靜態圖片資源進行攔截。

『玖』 如何在spring-servlet.xml內設置攔截器不對上傳控制器進行驗證

我估計是想想用攔截器做許可權驗證,login和main不需要驗證吧。我的方法是,定義一個@Auth,可以加些自定義的屬性,比如訪問這個方法所需要的許可權。@Auth加在需要驗證的controller方法上。然後定義個AuthorizationInterceptor,實現HandlerInterceptor介面中的preHandle方法,該方法中有個handler參數,對於一般的請求,該參數是HandlerMethod類型,可以從中獲取到controller方法上的annotation,如果有@Auth則驗證許可權,否則放行。你想的是攔截頁面,我想的是攔截方法。因為頁面也是由方法跳轉過去的。