⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 policyinterceptor.java

📁 这是一个法律事务所系统源码
💻 JAVA
字号:
/* * ==================================================================== * * The Apache Software License, Version 1.1 * * Copyright (c) 1999 The Apache Software Foundation.  All rights  * reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * 1. Redistributions of source code must retain the above copyright *    notice, this list of conditions and the following disclaimer.  * * 2. Redistributions in binary form must reproduce the above copyright *    notice, this list of conditions and the following disclaimer in *    the documentation and/or other materials provided with the *    distribution. * * 3. The end-user documentation included with the redistribution, if *    any, must include the following acknowlegement:   *       "This product includes software developed by the  *        Apache Software Foundation (http://www.apache.org/)." *    Alternately, this acknowlegement may appear in the software itself, *    if and wherever such third-party acknowlegements normally appear. * * 4. The names "The Jakarta Project", "Tomcat", and "Apache Software *    Foundation" must not be used to endorse or promote products derived *    from this software without prior written permission. For written  *    permission, please contact apache@apache.org. * * 5. Products derived from this software may not be called "Apache" *    nor may "Apache" appear in their names without prior written *    permission of the Apache Group. * * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE * DISCLAIMED.  IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * ==================================================================== * * This software consists of voluntary contributions made by many * individuals on behalf of the Apache Software Foundation.  For more * information on the Apache Software Foundation, please see * <http://www.apache.org/>. * * [Additional notices, if required by prior licensing conditions] * */package org.apache.tomcat.context;import org.apache.tomcat.core.*;import org.apache.tomcat.core.Constants;import org.apache.tomcat.request.*;import org.apache.tomcat.util.*;import java.io.*;import java.net.*;import java.util.*;import java.security.*;import org.apache.tomcat.logging.*;/** * Set policy-based access to tomcat. * Must be hooked before class loader setter. * The context will have a single protection domain, pointing to the doc root. *  That will include all classes loaded that belong to the context ( jsps, WEB-INF/classes, * WEB-INF/lib/ * * @author  Glenn Nielsen  * @author costin@dnt.ro */public class PolicyInterceptor extends BaseInterceptor {    String securityManagerClass="java.lang.SecurityManager";    String policyFile=null;        public PolicyInterceptor() {    }    public void setSecurityManagerClass(String cls) {	securityManagerClass=cls;    }    public void setPolicyFile( String pf) {	policyFile=pf;    }        /** Set the security manager, so that policy will be used     */    public void engineInit(ContextManager cm) throws TomcatException {	if( System.getSecurityManager() != null ) return;	try {	    Class c=Class.forName(securityManagerClass);	    Object o=c.newInstance();	    System.setSecurityManager((SecurityManager)o);	    // 	    System.out.println("Security Manager set to " +	    // 			       securityManagerClass);	} catch( ClassNotFoundException ex ) {	    System.out.println("SecurityManager Class not found: " +			       securityManagerClass);	} catch( Exception ex ) {            System.out.println("SecurityManager Class could not be loaded: " +			       securityManagerClass);	}    }        /** Add a default set of permissions to the context     */    protected void addDefaultPermissions( Context context,String base,					  Permissions p )    {	// Add default read "-" FilePermission for docBase, classes, lib	// Default per context permissions	FilePermission fp = new FilePermission(base + "/-", "read");	if( fp != null )	    p.add((Permission)fp);	    }        public void contextInit( Context context)	throws TomcatException    {	//	SecurityManager sm = System.getSecurityManager();	//	if( sm==null ) return;	ContextManager cm = context.getContextManager();	String base = context.getDocBase();	    	try {		    File dir = cm.getAbsolute(new File(base));	    URL url = new URL("file:" + dir.getAbsolutePath());	    CodeSource cs = new CodeSource(url,null);	    	    /* Try the context permissions ( set in the config file of via API calls )	     */	    Permissions p = (Permissions)context.getPermissions();	    	    if( p == null ) {		p = new Permissions();	    }	    	    // Add global permissions ( from context manager )	    // XXX maybe use imply or something like that	    Permissions perms = (Permissions)cm.getPermissions();	    if( perms!= null ) {		Enumeration enum=perms.elements();		while(enum.hasMoreElements()) {		    p.add((Permission)enum.nextElement());		}	    }	    	    addDefaultPermissions( context, dir.getAbsolutePath(), p);		    /** Add whatever permissions are specified in the policy file	     */	    Policy.getPolicy().refresh();	    PermissionCollection pFileP=Policy.getPolicy().getPermissions(cs);	    if( pFileP!= null ) {		Enumeration enum=pFileP.elements();		while(enum.hasMoreElements()) {		    p.add((Permission)enum.nextElement());		}	    }	    	    ProtectionDomain pd = new ProtectionDomain(cs,p);	    context.setProtectionDomain(pd);	    // new permissions - added context manager and file to whatever was	    // specified by default	    context.setPermissions( p );	} catch(Exception ex) {	    System.out.println("Security init for Context " + base + " failed");	}    }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -