我正在 cq5.5 中处理自定义表单处理程序,并且一切顺利。我现在正在努力锁定一些安全性,我的任务之一是对表单处理程序路径实现请求限制过滤器。

目前我有类似的东西

@Component(immediate = true, metatype = true) 
 
@Service(javax.servlet.Filter.class) 
 
@Properties({ 
  @Property(name="service.pid", value="com.xxxxxx.cq.core.filter.FormFilter",propertyPrivate=false), 
  @Property(name="service.description",value="FormFilter", propertyPrivate=false), 
  @Property(name="service.vendor",value="xxxxxx - Microsites", propertyPrivate=false), 
  @Property(name = "filter.scope", value = "request"), 
  @Property(name = "sling.filter.scope", value = "request"), 
  @Property(name = "service.ranking", intValue = 100001) 
}) 
 
public class FormFilter implements javax.servlet.Filter { 
  private Logger LOGGER = LoggerFactory.getLogger(TrackingFilter.class.getName()); 
  private static final Object lock = new Object(); 
 
  @Override 
  public void doFilter(ServletRequest pRequest, ServletResponse pResponse, FilterChain pChain) throws IOException, ServletException { 
      //my filter stuff 
  } 
} 

这工作正常,但我想将其锁定为仅在特定路径上运行。

感谢您的任何见解。

- - 编辑 - - -
在做了更多研究之后,我发现一些帖子指出无法将过滤器注册到默认 ServletFilter 处理程序的指定路径。基本上我发现的这个问题的两个解决方案是为过滤器创建一个新的 OSGI 包并使用 ExtHTTPService 或 Whiteboard 注册它:

http://felix.apache.org/documentation/subprojects/apache-felix-http-service.html

或者

过滤掉过滤器本身中的 url。所以基本上在我的过滤器中添加对指定路径的检查。

IE:
  @Override 
  public void doFilter(ServletRequest pRequest, ServletResponse pResponse, FilterChain pChain) throws IOException, ServletException { 
 
      String path = pRequest.getContextPath(); 
 
      if (path.contains("my/matching/path") 
      { 
        //my filter stuff 
      } 
  } 

我很想看看这个问题是否有其他解决方案,但想分享我迄今为止所能找到的东西,希望这将有助于激发更多的想法,甚至只是帮助有同样问题的人节省一些谷歌搜索时间。

谢谢你,
布罗迪

请您参考如下方法:

@Tomek Rękawek::: 这不是真的....您可以将过滤器映射到路径。 我已经使用以下方式完成了,请参阅下面的代码。

@SlingFilter(order=1) 
@Properties({ 
    @Property(name="service.pid", value="com.videojet.hiresite.filters.AddNewUserFilter",propertyPrivate=false), 
    @Property(name="service.description",value="Authentication Filter", propertyPrivate=false), 
    @Property(name="service.vendor",value="Zensar Tech", propertyPrivate=false), 
    @Property(name="pattern",value="/services/videojet/v1/AddNewUserController/view", propertyPrivate=false)     
}) 
public class AddNewUserFilter implements javax.servlet.Filter{ 
 
    private final Logger log = LoggerFactory.getLogger(this.getClass()); 
    public void destroy() { 
        // TODO Auto-generated method stub 
 
    } 
...... 

属性“模式”将过滤器映射到 URL。
并且不要忘记使用 @SlingFilter
在模式属性中,您当然也可以使用正则表达式“/.*”,无论它是什么。 这是久经考验的代码。

也不需要在 bundle activator 或 ExtHttpSevice 中注册它。


评论关闭
IT干货网

微信公众号号:IT虾米 (左侧二维码扫一扫)欢迎添加!