婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 詳解Tomcat常用的過濾器

詳解Tomcat常用的過濾器

熱門標簽:怎么找到沒有地圖標注的店 打400電話怎么辦理收費 麗江真人語音電話外呼系統 上海申請高400開頭的電話 宿城區電話機器人找哪家 400電話辦理介紹信 河南防封號電銷機器人是什么 福州企業電銷機器人排名 10086外包用的什么外呼系統

一、跨域過濾器CorsFilter

org.apcache.catalina.filters.CorsFilter是跨域資源共享規范的一個實現,常常用于前后端分離,靜態資源與后端分離等情況。它主要在HttpServletResponse中增加Access-Control-*頭,同時保護HTTP響應避免拆分,如果請求無效或者禁止訪問,則返回403響應碼。

1.1、配置示例

<filter>
  <filter-name>CorsFilter</filter-name>
  <filter-class>org.apache.catalina.filters.CorsFilter</filter-class>
  <init-param>
    <param-name>cors.allowed.origins</param-name>
    <param-value>*</param-value>
  </init-param>
  <init-param>
    <param-name>cors.allowed.methods</param-name>
    <param-value>GET,POST,HEAD,OPTIONS,PUT</param-value>
  </init-param>
  <init-param>
    <param-name>cors.allowed.headers</param-name>
    <param-value>Content-Type,X-Requested-With,accept,Origin,Access-Control-Request-Method,Access-Control-Request-Headers</param-value>
  </init-param>
  <init-param>
    <param-name>cors.exposed.headers</param-name>
    <param-value>Access-Control-Allow-Origin,Access-Control-Allow-Credentials</param-value>
  </init-param>
  <init-param>
    <param-name>cors.support.credentials</param-name>
    <param-value>true</param-value>
  </init-param>
  <init-param>
    <param-name>cors.preflight.maxage</param-name>
    <param-value>10</param-value>
  </init-param>
</filter>
<filter-mapping>
  <filter-name>CorsFilter</filter-name>
  <url-pattern>/*</url-pattern>
</filter-mapping>

1.2、參數說明

1、cors.allowed.origins

允許訪問的跨域資源列表,"*"表示允許訪問來自任何域的資源,多個域用逗號分隔,默認為"*"

2、cors.allowed.methods

可以用于訪問資源的HTTP方法列表,","分隔,用于跨域請求。這些方法將出現在Prefligh(預檢請求)響應頭Access-Control-Allow-Methods的一部分,t默認為"GET, POST, HEAD, OPTIONS"

3、cors.allowed.headers

構造請求時可以使用的請求頭,以","分隔,這些方法將出現在Prefligh(預檢請求)響應頭Access-Control-Allow-Headers的一部分,默認為Origin, Accept, X-Requested-With, Content-Type, Access-Control-Request-Method, Access-Control-Request-Headers

4、cors.exposed.headers

瀏覽器允許訪問的頭部信息列表,","分隔。這些方法將出現在Prefligh(預檢請求)響應頭Access-Control-Allow-Headers的一部分,默認為空。

5、cors.preflight.maxage

瀏覽器允許緩存的Preflght請求結果的時間,單位為秒。如果為負數,則表示CorsFilter不會添加頭到Preflight響應,這些方法將出現在Prefligh(預檢請求)響應頭Access-Control-Max-Age的一部分,默認為1800.

6、cors.support.credentials

表示資源是否支持用戶證書,這些方法將出現在Prefligh(預檢請求)響應頭Access-Control-Allow-Credentials的一部分,默認為true

7、cors.request.decorate

Cors規范屬性是否已經添加到HttpServletRequest,默認為true。CorsFiter會為HttpServletRequest添加請求相關信息,cors.request.decorate配置為true,那么以下屬性將會被添加

1)cors.isCorsRequest:用于請求是否為Cors請求。

2)cors.request.origin:源URL,請求源自的頁面URL。

3)cors.request.type:Cors的請求類型,如下:

SIMPLE:非Preflight請求為先導的請求。

ACTUAL:以Preflight請求為先導的請求。

PRE_FLIGHT:Preflight請求

NOT_CORS:正常同域請求

INVALID_CORS:無效的域請求

4)cors.request.headers:作為Preflight請求Access-Control-Request-Header頭發送的請求頭信息。

二、CSRF保護過濾器CsrfPreventionFilter

org.apcache.catalina.filters.CsrfPreventionFilter為Web應用提供了基本的CSRF保護。返回的客戶端的所有鏈接均通過HttpServletResponse.encodeRedirectURL(String)與HttpServletResponse.encodeURL(String)進行編碼,該過濾器生成一個隨機數并存儲到會話session中進行對比,URL使用該隨機數進行編碼。當接收到下一個請求時,請求中隨機數與會話中的進行對比,只有兩者相同時,請求才會被允許。

2.1、配置示例

<filter>
    <filter-name>CsrfPreventionFilter</filter-name>
    <filter-class>org.apache.catalina.filters.CsrfPreventionFilter</filter-class>
    <init-param>
        <param-name>denyStatus</param-name>
        <param-value>403</param-value>
    </init-param>
    <init-param>
        <param-name>entryPoints</param-name>
        <param-value>/html,/html/list</param-value>
    </init-param>
    <init-param>
        <param-name>nonceCacheSize</param-name>
        <param-value>5</param-value>
    </init-param>
</filter>
<filter-mapping>
    <filter-name>CsrfPreventionFilter</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>

2.2、參數說明

1、denyStatus:HTTP響應嗎,用于駁回拒絕請求,默認為403  

2、entryPoints:以","為分隔的URL列表,這些列表將不會進行隨機數檢測(主要用于通過導航離開受保護應用,之后再返回) 

if ("GET".equals(req.getMethod()) && this.entryPoints.contains(this.getRequestedPath(req))) {
                skipNonceCheck = true;
 }

3、nonceCacheSize:隨機數緩存大小。先前發布的隨機數被緩存到一個LRU緩存中以支持并發請求,有限的用于瀏覽器刷新等行為(可能導致隨機數不是當前的),默認為5

private int nonceCacheSize = 5;
....
if (nonceCache == null) {
    nonceCache = new CsrfPreventionFilter.LruCache(this.nonceCacheSize);
      if (session == null) {
           session = req.getSession(true);
       }

    session.setAttribute("org.apache.catalina.filters.CSRF_NONCE", nonceCache);
}

4、randomClass:用于生成隨機數的類,必須是java.util.Random實例,如不設置默認為java.security.SecureRandom

三、防止參數丟失過濾器FailedRequestFilter

org.apcache.catalina.filters.FailedRequestFilter用于觸發請求的參數解析,當參數解析失敗時,將會拒絕請求,該Filter用于確保客戶端提交的參數信息不發生丟失。該過濾器的原理是:先調用ServletRequest.getParameter(首次調用會觸發Tomcat服務器的請求參數解析,如果參數解析失敗,將結果放到請求屬性org.apache.catalina.parameter_parse_failed中),之后判斷屬性org.apache.catalina.parameter_parse_failed的值,如果不為空則直接返回400。

為了能正確解析參數,需要該Filter之前設置字符集編碼過濾器SetCharacterEncodingFilter。此外,該過濾器是不支持r初始化參數的

// 判斷是否為有效的請求:org.apache.catalina.parameter_parse_failed為null
private boolean isGoodRequest(ServletRequest request) {
    request.getParameter("none");
    return request.getAttribute("org.apache.catalina.parameter_parse_failed") == null;
}

四、獲取客戶端IP過濾器RemoteAddrFilter

org.apcache.catalina.filters.RemoteAddrFiler允許比較提交的客戶端IP地址(通過ServletRequest.getRemoteAddr獲取)是否符合指定正則表達式。

4.1、配置示例

<filter>
    <filter-name>Remote Address Filter</filter-name>
    <filter-class>org.apache.catalina.filters.RemoteAddrFilter</filter-class>
    <init-param>
    <param-name>allow</param-name>
    <param-value>127\.\d+\.\d+\.\d+|::1|0:0:0:0:0:0:0:1</param-value>
    </init-param>
</filter>
<filter-mapping>
    <filter-name>Remote Address Filter</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>

4.2、參數說明  

1、allow:指定允許訪問的客戶端IP地址  

2、deny:拒絕訪問的客戶端地址  

3、denyStatus:拒絕請求時返回的HTTP響應嗎。

五、獲取客戶端Host過濾器RemoteHostFilter

org.apcache.catalina.filters.RemoteHostFiler允許比較提交請求的客戶端主機名是否符合指定的正則表達式,以確定是否允許繼續處理請求。參數同RemoteAddrFilter

六、獲取原始客戶端IP過濾器RemoteIpFilter

 當客戶端通過HTTP代理或者負載均衡訪問服務器時,對于服務器來說,請求直接源自前置的代理服務器,此時獲取到的遠程IP實際為代理服務器的IP地址。

6.1、如何獲得原始的客戶端的IP地址

HTTP協議通過X-Forwarded-For頭信息記錄了資客戶端到應用服務器前置代理的IP地址,RemoteIpFilter通過解析該請求頭,將請求中的IP地址與主機名替換為客戶端真實的IP地址和主機信息,此外還可以通過X-Forwardred-Proto請求頭替換當前的協議名稱http/https、服務器端口及request.secure。

X-Forwarded-For的格式如下:

X-Forwarded-For: client, proxy1, proxy2

最左側client為最原始的客戶端IP,如上示例中客戶端經過了proxy1、proxy2、proxy3三級代理(最后一層proxy3不顯示,通過ServletRquest.getRemoteAddr獲取)。在負載均衡的情況下,RemoteAddrFilter和RemoteHostFilter需要與該過濾器配合使用,否則無法正確限制訪問客戶端。

通常我們獲取X-Forwarded-For使用如下Java代碼:

public static String getIp(HttpServletRequest request) {
    String requestAddr = request.getHeader("x-forwarded-for");
    if (requestAddr == null || requestAddr.length() == 0 || "unknown".equalsIgnoreCase(requestAddr)) {
        requestAddr = request.getHeader("Proxy-Client-IP");
    }

    if (requestAddr == null || requestAddr.length() == 0 || "unknown".equalsIgnoreCase(requestAddr)) {
        requestAddr = request.getHeader("WL-Proxy-Client-IP");
    }

    if (requestAddr == null || requestAddr.length() == 0 || "unknown".equalsIgnoreCase(requestAddr)) {
        requestAddr = request.getRemoteAddr();
    }

    return requestAddr;
}

6.2、配置示例

1)基本處理X-Forwarded-For頭的配置

<filter>
    <filter-name>RemoteIpFilter</filter-name>
    <filter-class>org.apache.catalina.filters.RemoteIpFilter</filter-class>
</filter>

<filter-mapping>
    <filter-name>RemoteIpFilter</filter-name>
    <url-pattern>/*</url-pattern>
    <dispatcher>REQUEST</dispatcher>
</filter-mapping>

2)處理X-Forwarded-For與x-forwarded-proto頭部的配置

<filter>
    <filter-name>RemoteIpFilter</filter-name>
    <filter-class>org.apache.catalina.filters.RemoteIpFilter</filter-class>
    <init-param>
    <param-name>protocolHeader</param-name>
    <param-value>x-forwarded-proto</param-value>
    </init-param>
</filter>

<filter-mapping>
    <filter-name>RemoteIpFilter</filter-name>
    <url-pattern>/*</url-pattern>
    <dispatcher>REQUEST</dispatcher>
</filter-mapping>

3)使用內部代理的高級配置

<filter>
    <filter-name>RemoteIpFilter</filter-name>
    <filter-class>org.apache.catalina.filters.RemoteIpFilter</filter-class>
    <init-param>
        <param-name>allowedInternalProxies</param-name>
        <param-value>192\.168\.0\.10|192\.168\.0\.11</param-value>
    </init-param>
    <init-param>
        <param-name>remoteIpHeader</param-name>
        <param-value>x-forwarded-for</param-value>
    </init-param>
    <init-param>
        <param-name>remoteIpProxiesHeader</param-name>
        <param-value>x-forwarded-by</param-value>
    </init-param>
    <init-param>
        <param-name>protocolHeader</param-name>
        <param-value>x-forwarded-proto</param-value>
    </init-param>
</filter>

4)使用可信任代理高級配置

<filter>
    <filter-name>RemoteIpFilter</filter-name>
    <filter-class>org.apache.catalina.filters.RemoteIpFilter</filter-class>
    <init-param>
        <param-name>allowedInternalProxies</param-name>
        <param-value>192\.168\.0\.10|192\.168\.0\.11</param-value>
    </init-param>
    <init-param>
        <param-name>remoteIpHeader</param-name>
        <param-value>x-forwarded-for</param-value>
    </init-param>
    <init-param>
        <param-name>remoteIpProxiesHeader</param-name>
        <param-value>x-forwarded-by</param-value>
    </init-param>
    <init-param>
        <param-name>trustedProxies</param-name>
        <param-value>proxy1|proxy2</param-value>
    </init-param>
</filter>

七、字符集編碼過濾器SetCharacterEncodingFilter

提供了一種設置字符集編碼的方式,通常情況下默認ISO-8859-1編碼,但實際生產環境推薦使用UTF-8編碼,而請求中的編碼可以在未指定編碼時使用,也可以強制覆蓋。

7.1、配置示例

<filter>
    <filter-name>SetCharacterEncodingFilter</filter-name>
    <filter-class>org.apache.catalina.filters.SetCharacterEncodingFilter</filter-class>
    <init-param>
        <param-name>encoding</param-name>
        <param-value>UTF-8</param-value>
    </init-param>
    <init-param>
        <param-name>ignore</param-name>
        <param-value>false</param-value>
    </init-param>
</filter>
<filter-mapping>
    <filter-name>SetCharacterEncodingFilter</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>

7.2、參數說明  

1、encoding:指定的字符集編碼    

2、ignore:表示是否忽略客戶端請求設置的字符集編碼,如果為true那么都會將請求字符集編碼覆蓋,如果為false,請求沒有指定字符集編碼時設置。默認為false

以上就是詳解Tomcat常用的過濾器的詳細內容,更多關于Tomcat過濾器的資料請關注腳本之家其它相關文章!

標簽:連云港 隴南 遵義 面試通知 雞西 朝陽 運城 荊門

巨人網絡通訊聲明:本文標題《詳解Tomcat常用的過濾器》,本文關鍵詞  詳解,Tomcat,常用的,常,用的,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《詳解Tomcat常用的過濾器》相關的同類信息!
  • 本頁收集關于詳解Tomcat常用的過濾器的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    午夜久久福利影院| 国产精品免费视频一区| 久草在线在线精品观看| 国产精品黄色在线观看| 日韩精品一区二区三区蜜臀| 色婷婷久久久久swag精品| 精品亚洲porn| 亚洲va欧美va人人爽| 亚洲国产高清在线观看视频| 日韩一区二区三区观看| 日本高清成人免费播放| 国产成人免费视频网站高清观看视频| 天天操天天综合网| 亚洲综合男人的天堂| 综合欧美一区二区三区| 国产亚洲精品久| 欧美一区二区三区四区久久| 欧美色图在线观看| 91网站黄www| 成人精品视频一区| 蜜臀av一区二区| 欧美bbbbb| 日日摸夜夜添夜夜添精品视频| 亚洲综合一区二区精品导航| 国产精品污www在线观看| 久久免费的精品国产v∧| 精品国免费一区二区三区| 欧美丰满美乳xxx高潮www| 在线成人av网站| 欧美一区二区精品| 欧美成人一级视频| 亚洲精品在线一区二区| 久久蜜桃香蕉精品一区二区三区| 欧美少妇xxx| 欧美精品乱码久久久久久| 欧美三级电影精品| 欧美一区二区三区四区视频| 亚洲精品一区二区三区蜜桃下载| 26uuu欧美日本| 国产亚洲精品福利| 国产精品久久久久久久午夜片| 国产精品久久久久影院亚瑟| 国产精品久久久久久久久图文区 | 久久久www免费人成精品| 国产女主播在线一区二区| 亚洲国产精品激情在线观看| 中文字幕一区二区三区在线观看| 亚洲精品高清在线观看| 婷婷成人综合网| 精彩视频一区二区三区| 99视频一区二区| 欧美大片一区二区| 樱花草国产18久久久久| 久久er99热精品一区二区| 91一区二区三区在线观看| 7777女厕盗摄久久久| 中文一区一区三区高中清不卡| 亚洲一区二区三区美女| 国产一区二区三区四区五区入口 | 一区二区三区精品| 国产在线播放一区| 欧美在线啊v一区| 久久先锋影音av| 一区二区三区四区不卡视频| 国产一区二区在线免费观看| 色综合天天综合网国产成人综合天| 欧美一级黄色大片| 国产精品精品国产色婷婷| 亚洲一区二区三区四区五区黄| 天堂蜜桃一区二区三区| 美女一区二区三区在线观看| 国产美女一区二区| 激情都市一区二区| 5858s免费视频成人| 欧美日韩久久不卡| 欧美午夜片在线看| 欧美一区二区久久| 欧美日韩1区2区| 亚洲免费成人av| 国产91精品免费| 国产蜜臀97一区二区三区| 久久久久国产免费免费| 国产精品久久久久影院色老大| 国产精品乱人伦一区二区| √…a在线天堂一区| 欧美精品在线一区二区三区| 亚洲精品国久久99热| 亚洲日本免费电影| 亚洲国产精品久久久男人的天堂| 亚洲妇熟xx妇色黄| 久久精品免费观看| jlzzjlzz欧美大全| 国产在线视频不卡二| 26uuu色噜噜精品一区| 欧美日韩国产综合一区二区三区| 欧美一卡2卡3卡4卡| 欧美激情一区二区在线| 亚洲午夜久久久久| 国产麻豆一精品一av一免费 | 亚洲高清免费观看| 丝袜美腿亚洲一区| 一区二区三区在线观看网站| 色婷婷精品大视频在线蜜桃视频| 6080yy午夜一二三区久久| 欧美xxxx在线观看| 亚洲日本乱码在线观看| 蜜臀av性久久久久蜜臀aⅴ四虎 | 日本乱码高清不卡字幕| 欧美色视频一区| 国产三级精品三级| 18欧美乱大交hd1984| 亚洲h在线观看| 国产精品一线二线三线精华| 日本vs亚洲vs韩国一区三区二区| 中文字幕一区二区三区不卡在线| 亚洲精品高清在线| 欧美一区二区成人| 在线免费观看一区| 久久综合色8888| 亚洲一区二区三区影院| 国产成人精品综合在线观看| 欧美在线观看视频一区二区| 国产日韩高清在线| 久久夜色精品一区| 欧美亚洲丝袜传媒另类| 国产女人水真多18毛片18精品视频| 亚洲欧美日韩国产成人精品影院| 久久精品二区亚洲w码| 在线国产电影不卡| 日韩一区日韩二区| 国产精品一区三区| 亚洲成人一区二区| 色猫猫国产区一区二在线视频| 久久精品人人做| 蜜桃久久久久久| 欧美日韩第一区日日骚| 国产精品视频一二三区| 亚洲午夜视频在线观看| 久久综合狠狠综合久久综合88| 日本在线不卡一区| 欧美一级生活片| 日本vs亚洲vs韩国一区三区 | 国产精品亚洲午夜一区二区三区| 亚洲精品一二三区| 99re66热这里只有精品3直播| 久久久精品中文字幕麻豆发布| 免费观看久久久4p| 91精品国产日韩91久久久久久| 日本欧洲一区二区| av资源站一区| 国产一本一道久久香蕉| 久久久99免费| 丁香婷婷综合色啪| 综合久久给合久久狠狠狠97色| 91香蕉视频在线| 欧美激情艳妇裸体舞| 日韩久久免费av| 国产91丝袜在线18| 亚洲另类中文字| 欧美日韩国产首页| 久久99精品久久久久久国产越南 | 亚洲欧洲av色图| 在线免费观看日本欧美| 午夜影院久久久| 欧美zozo另类异族| 一区二区三区小说| 最新欧美精品一区二区三区| 一本大道综合伊人精品热热| 亚洲成人动漫av| 欧美大胆一级视频| 成人网男人的天堂| 亚洲精品欧美专区| 美国十次了思思久久精品导航| 午夜私人影院久久久久| 久久奇米777| 99精品视频一区二区| 亚洲国产精品麻豆| 亚洲国产精品ⅴa在线观看| 久久久久久久久久久久电影 | 韩国中文字幕2020精品| 亚洲丝袜制服诱惑| 精品国产一区a| 欧美午夜免费电影| 国产精品一品二品| 亚洲成人免费在线观看| 亚洲国产电影在线观看| 国产精品嫩草久久久久| 欧美疯狂做受xxxx富婆| 91亚洲国产成人精品一区二三| 美日韩一区二区三区| 一区二区免费在线| 色综合久久久久综合体| 在线一区二区三区| 成人av网站大全| 国产一区二区网址| 亚洲国产成人91porn| 中文字幕 久热精品 视频在线| 在线观看亚洲a| 国产精品一区二区黑丝| 欧美日韩国产一区|