如何在xml中检查条件?

时间:2014-12-17 09:40:19

标签: java xml saml opensaml

当我点击login1时我有2个链接login1和login2,这应该避免在xml中有登录过滤器的过滤节点,这意味着它不应该读取<filter-name>LoginFilter</filter-name>我已经google了一些例子如何使用java修改xml但是有没有办法可以在不更改xml文件的情况下检查条件

这是我的xml文件:

    <?xml version="1.0" encoding="UTF-8"?>
    <web-app id="WebApp_ID" version="2.4"
        xmlns="http://java.sun.com/xml/ns/j2ee"
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd" >

        <display-name>OIOSAML-J</display-name>
        <env-entry>
            <env-entry-name>oiosaml-j.home</env-entry-name>
            <env-entry-type>java.lang.String</env-entry-type>
            <env-entry-value>c:\oiosaml-config</env-entry-value>
        </env-entry>

        <!--<env-entry>
            <env-entry-name>oiosaml-j.name</env-entry-name>
            <env-entry-type>java.lang.String</env-entry-type>
            <env-entry-value>demo</env-entry-value>
        </env-entry>-->

        <listener>
            <listener-class>dk.itst.oiosaml.sp.service.session.SessionDestroyListener</listener-class>
        </listener>  

        <servlet>
            <servlet-name>SAMLDispatcherServlet</servlet-name>
            <servlet-class>
                dk.itst.oiosaml.sp.service.DispatcherServlet
            </servlet-class>
            <load-on-startup>1</load-on-startup>
        </servlet>

        <servlet-mapping>
            <servlet-name>SAMLDispatcherServlet</servlet-name>
            <url-pattern>/saml/*</url-pattern>
        </servlet-mapping>
    <filter>
    <filter-name>PrimeFaces FileUpload Filter</filter-name>
    <filter-class>org.primefaces.webapp.filter.FileUploadFilter</filter-class>
  </filter>
        <filter>
            <filter-name>LoginFilter</filter-name>
            <filter-class>dk.itst.oiosaml.sp.service.SPFilter</filter-class>
        </filter>
        <filter-mapping>
            <filter-name>LoginFilter</filter-name>
            <url-pattern>/sp/*</url-pattern>
        </filter-mapping>
<filter-mapping>
    <filter-name>PrimeFaces FileUpload Filter</filter-name>
    <servlet-name>Faces Servlet</servlet-name>
  </filter-mapping>
        <welcome-file-list>
            <welcome-file>index.jsp</welcome-file>
        </welcome-file-list>
    </web-app>

这是我的观看代码:

<html xmlns="http://www.w3.org/1999/xhtml"  
        xmlns:h="http://java.sun.com/jsf/html"  
        xmlns:f="http://java.sun.com/jsf/core"  
        xmlns:p="http://primefaces.org/ui"
        xmlns:ui="http://java.sun.com/jsf/facelets"
        xmlns:c="http://java.sun.com/jsp/jstl/core"
        >  
   <h:body>
       <div><a href="sp/">Login1</a></div>|<div><a href="sp/">login2</a></div>
    </h:body>
  </html>

1 个答案:

答案 0 :(得分:0)

每次发送到/ sp /下的任何目标的请求都会触发LoginFilter。 如果您希望网页不触发此过滤器,则必须确保该页面不在将触发过滤器的路径上。可能有这样的结构。

/
/sp/
/public/

并将登录页面置于公开