本文實(shí)例講述了jsp filter 過濾器功能與簡單用法。分享給大家供大家參考,具體如下:
過濾器的作用是什么?
過濾器可以動(dòng)態(tài)地?cái)r截請(qǐng)求和響應(yīng),以變換或使用包含在請(qǐng)求或響應(yīng)中的信息。
可以將一個(gè)或多個(gè)過濾器附加到一個(gè) Servlet 或一組 Servlet。過濾器也可以附加到 JavaServer Pages (JSP) 文件和 HTML 頁面。
- 在客戶端的請(qǐng)求訪問后端資源之前,攔截這些請(qǐng)求。
- 在服務(wù)器的響應(yīng)發(fā)送回客戶端之前,處理這些響應(yīng)。
過濾器的實(shí)現(xiàn)要實(shí)現(xiàn) java.servlet.Filter 這個(gè)接口類
一個(gè)簡易的filter 類示例
package demo;
import java.io.IOException;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
public class DemoFilter implements Filter
{
private String name=null;
@Override
public void destroy()
{
}
@Override
public void doFilter(ServletRequest arg0, ServletResponse arg1,
FilterChain arg2) throws IOException, ServletException
{
arg0.setAttribute("name", "init text string : " + name);
arg2.doFilter(arg0, arg1);
}
@Override
public void init(FilterConfig arg0) throws ServletException
{
//獲得web.xml中filter init-param 中的配置
name = arg0.getInitParameter("name");
}
}
僅僅只是寫好了這個(gè)過濾器類還不行。我們要在web.xml中聲明哪些請(qǐng)求需要過濾器的調(diào)用
web.xml
!--聲明一個(gè)filter-->
filter>
!--filter的名稱-->
filter-name>demoFilter/filter-name>
!--filter 類-->
filter-class>demo.DemoFilter/filter-class>
!--該filter類需要的配置-->
init-param>
param-name>name/param-name>
param-value>my name is tanyong/param-value>
/init-param>
/filter>
!--為url-pattern 中相匹配的url鏈接 映射至相應(yīng)的filter filter 通過 filter-name來識(shí)別-->
filter-mapping>
filter-name>demoFilter/filter-name>
!--匹配映射規(guī)則,我這里用的是所有請(qǐng)求都要在demoFilter filter 里面去兜晃一圈-->
url-pattern>/*/url-pattern>
/filter-mapping>
希望本文所述對(duì)大家jsp程序設(shè)計(jì)有所幫助。
您可能感興趣的文章:- 通過過濾器(Filter)解決JSP的Post和Request中文亂碼問題
- JSP過濾器Filter配置過濾類型全部匯總
- JSP 開發(fā)中過濾器filter設(shè)置編碼格式的實(shí)現(xiàn)方法
- JSP使用Servlet過濾器進(jìn)行身份驗(yàn)證的方法
- JSP過濾器防止Xss漏洞的實(shí)現(xiàn)方法(分享)
- JSP使用過濾器防止SQL注入的簡單實(shí)現(xiàn)
- jsp實(shí)現(xiàn)登錄驗(yàn)證的過濾器
- jsp中過濾器選擇過濾器的寫法詳解
- 詳解JSP中使用過濾器進(jìn)行內(nèi)容編碼的解決辦法
- servlet+jsp實(shí)現(xiàn)過濾器 防止用戶未登錄訪問
- JSP使用過濾器防止Xss漏洞