在SSH结构的web应用中,如何让自定义的过滤器Filter获取spring管理的实例

版权声明:本文为博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/WWWHPUZH/article/details/84626106

       最近我在做项目中遇到一个问题,就是自定义一个过滤器Filter,我想在改过滤器里面获取Service,从而进行一些业务操作,但是,我怎么也获得不到交给spring管理的Service,后来在网上找了很久,终于把这个问题解决了,这个错误就是我在web.xml里面配置是按照Servlet过滤器配置的,在过滤器初始化的时候,spring的实例还没有初始化,所以无法获得spring的实例,后来参考网上的方案,使用DelegatingFilterProxy解决了这个问题。

          DelegatingFilterProxy就是一个对于servlet filter的代理,用这个类的好处主要是通过Spring容器来管理servlet filter的生命周期,还有就是如果filter中需要一些Spring容器的实例,可以通过spring直接注入,另外读取一些配置文件这些便利的操作都可以通过Spring来配置实现。

        DelegatingFilterProxy的使用方法,

         首先在web.xml中配置:

 

<filter>
    <filter-name>urlFilter</filter-name>
    <filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class>
</filter>
<filter-mapping>
    <filter-name>urlFilter</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping> 

 

    然后在Spring的配置文件中,配置具体的Filter类的实例。

 

<bean id="urlFilter" class="com.nxt.count.filter.UrlFilter">
	<property name="visitLogService" ref="visitLogService"/>
</bean>

    注意:在Spring中配置的bean的name要和web.xml中的<filter-name>必须一致

     

    或者在DelegatingFilterProxy的filter配置中配置初始参数:targetBeanName,对应到Spring配置中的beanname。 

 

   如果要保留Filter原有的init,destroy方法的调用,还需要配置初始化参数targetFilterLifecycle为true,该参数默认为false

展开阅读全文

web应用Spring如何注入Servlet实例

09-21

在Spring中是否可以注入Servlet实例?rnrn下面是我写的一个servlet,想法是当请求提交到该servlet时,如果在Spring中进行了相关配置,那么该servlet的成员rnmessage是否已经被初始化。rnpublic class LoginServlet extends HttpServlet rn private String message;rn public void setMessage(String message)this.message=message;rnrn public void doGet(HttpServletRequest request, HttpServletResponse response)rn throws ServletException, IOException rn PrintWriter out=response.getWriter();rn out.println("message:"+message);rn rn rnrn public void doPost(HttpServletRequest request, HttpServletResponse response)rn throws ServletException, IOException rn doGet(request,response);rn rnrn在applicationContext.xml的配置rnrnrn rn rn rnrnrnrn以上例子我试过了(当然环境已经搭建好了)不过获取不到message的值,提示错误是message值为nullrnrn假如该servlet有个成员对象User user,且在配置文件中做了配置,那么可以使用WebApplicationContextUtil类的getWebApplicationContext()方法获取spring容器,然后getBean方法获得user的值,但是如果不用这种方法,直接rn用以上例子的方法不行么?也就是说只要该servlet的成员变量(普通类型或者对象类型)设置了set方法,且在Spring配置文件中rn配置了相应的bean,并在loginServlet中设置了相应的property属性,那么是否只要有请求到该servlet时,该servlet的成员rn就会被Spring容器初始化了呢?望大家赐教。rnrn 论坛

HBase自定义过滤器Filter)的问题

02-10

HBase中,添加其自带的过滤器不会出错,如SingleColumnValueFilter,PageFilter,但要添加自己的过滤器(防止出现代码错误,暂时把自定义过滤器的实现跟SingleColumnValueFilter一样)却总是报错,错误及代码如下,哪位高手能帮忙分析分析[code=Java]rnScan s = new Scan();rn Filter filter2 = new SingleColumnValueFilter("myColumFamily1".getBytes(),"myColum".getBytes(),CompareOp.NOT_EQUAL,"5".getBytes());rn Filter filter3 = new SingleColumnMatchValueFilter("myColumFamily1".getBytes(),"myColum".getBytes(),CompareOp.NOT_EQUAL,"5".getBytes());rn s.setFilter(filter3);rn ResultScanner ss = table2.getScanner(s);rn System.out.println();rn for(Result r:ss)rn System.out.println(new String(r.getRow())+":"+r.getCellValues().length);rn for(KeyValue kv:r.raw())rn System.out.println(kv.getKeyString()+"_______"+new String(kv.getValue()));rn rn rn[/code]rn错误rn[code=Java]rnrnException in thread "main" org.apache.hadoop.hbase.client.RetriesExhaustedException: Trying to contact region server 10.10.11.112:60020 for region tabletest04,,1296182193609, row '', but failed after 10 attempts.rnExceptions:rnjava.io.IOException: Call to /10.10.11.112:60020 failed on local exception: java.io.EOFExceptionrnjava.io.IOException: Call to /10.10.11.112:60020 failed on local exception: java.io.EOFExceptionrnjava.io.IOException: Call to /10.10.11.112:60020 failed on local exception: java.io.EOFExceptionrnjava.io.IOException: Call to /10.10.11.112:60020 failed on local exception: java.io.EOFExceptionrnjava.io.IOException: Call to /10.10.11.112:60020 failed on local exception: java.io.EOFExceptionrnjava.io.IOException: Call to /10.10.11.112:60020 failed on local exception: java.io.EOFExceptionrnjava.io.IOException: Call to /10.10.11.112:60020 failed on local exception: java.io.EOFExceptionrnjava.io.IOException: Call to /10.10.11.112:60020 failed on local exception: java.io.EOFExceptionrnjava.io.IOException: Call to /10.10.11.112:60020 failed on local exception: java.io.EOFExceptionrnjava.io.IOException: Call to /10.10.11.112:60020 failed on local exception: java.io.EOFExceptionrnrn at org.apache.hadoop.hbase.client.HConnectionManager$TableServers.getRegionServerWithRetries(HConnectionManager.java:1045)rn at org.apache.hadoop.hbase.client.HTable$ClientScanner.nextScanner(HTable.java:2003)rn at org.apache.hadoop.hbase.client.HTable$ClientScanner.initialize(HTable.java:1923)rn at org.apache.hadoop.hbase.client.HTable.getScanner(HTable.java:403)rn at test.Test.main(Test.java:94)rn[/code] 论坛

没有更多推荐了,返回首页