Java AccessController.doPrivileged 简单的操作

package com.xiuye.security;


public class Privilege {

	public static void main(String[] args) {

		System.setProperty("java.security.policy", "security.policy");
		System.setSecurityManager(new SecurityManager());
//		PrivilegedAction<String> readPropertiesAction = ()->{
//
//			log(System.getProperty("java.security.manager"));
//
//			return "OK";
//		};
//		log("Read Properties ? : "+AccessController.doPrivileged(readPropertiesAction));

		PrivilegeUtil.doPrivileged();
		log("===================================");
		PrivilegeUtil.printlnProperties("called by Main");

		log("===================================");
		Class<Privilege> clazz = Privilege.class;
		log("ProtectDomain := "+ clazz.getProtectionDomain());

	}

	private static<T> void log(T t){
		System.out.println(t);
	}

}

package com.xiuye.security;

import java.security.AccessController;
import java.security.PrivilegedAction;

public class PrivilegeUtil {

	public static void doPrivileged(){

		PrivilegedAction<String> readPropertiesAction = ()->{

			log("doPrivileged");
			printlnProperties("called by doPrivileged");

			return "OK";
		};
		log("Read Properties ? : "+AccessController.doPrivileged(readPropertiesAction));

	}

	public static void printlnProperties(String s){
		log("printlnProperties "+s);
		log(System.getSecurityManager());
	}

	private static<T> void log(T t) {
		System.out.println(t);
	}

}

grant {
	permission java.lang.RuntimePermission "getProtectionDomain";
	permission java.util.PropertyPermission "java.security.manager", "read";
	permission java.util.PropertyPermission "java.security.manager", "write";
	permission java.util.PropertyPermission "java.security.policy", "write";
	permission java.util.PropertyPermission "java.security.policy", "read";
};// 这里也需要";"!


doPrivileged
printlnProperties called by doPrivileged
java.lang.SecurityManager@3abc88
Read Properties ? : OK
===================================
printlnProperties called by Main
java.lang.SecurityManager@3abc88
===================================
ProtectDomain := ProtectionDomain  (file:/D:/programming/DevelopingProjects/JavaAPILearning/bin/ <no signer certificates>)
 sun.misc.Launcher$AppClassLoader@19e0bfd
 <no principals>
 java.security.Permissions@128cdfa (
 ("java.lang.RuntimePermission" "exitVM")
 ("java.io.FilePermission" "\D:\programming\DevelopingProjects\JavaAPILearning\bin\-" "read")
)






java.lang.IllegalStateException: mBeanFactory.removeContext.addServicedFail at org.apache.catalina.mbeans.MBeanFactory.removeContext(MBeanFactory.java:767) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) at java.lang.reflect.Method.invoke(Method.java:498) at org.apache.tomcat.util.modeler.BaseModelMBean.invoke(BaseModelMBean.java:294) at com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.invoke(DefaultMBeanServerInterceptor.java:819) at com.sun.jmx.mbeanserver.JmxMBeanServer.invoke(JmxMBeanServer.java:801) at com.sun.jmx.remote.security.MBeanServerAccessController.invoke(MBeanServerAccessController.java:468) at javax.management.remote.rmi.RMIConnectionImpl.doOperation(RMIConnectionImpl.java:1468) at javax.management.remote.rmi.RMIConnectionImpl.access$300(RMIConnectionImpl.java:76) at javax.management.remote.rmi.RMIConnectionImpl$PrivilegedOperation.run(RMIConnectionImpl.java:1309) at java.security.AccessController.doPrivileged(Native Method) at javax.management.remote.rmi.RMIConnectionImpl.doPrivilegedOperation(RMIConnectionImpl.java:1408) at javax.management.remote.rmi.RMIConnectionImpl.invoke(RMIConnectionImpl.java:829) at sun.reflect.GeneratedMethodAccessor49.invoke(Unknown Source) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) at java.lang.reflect.Method.invoke(Method.java:498) at sun.rmi.server.UnicastServerRef.dispatch(UnicastServerRef.java:357) at sun.rmi.transport.Transport$1.run(Transport.java:200) at sun.rmi.transport.Transport$1.run(Transport.java:197) at java.security.AccessController.doPrivileged(Native Method) at sun.rmi.transport.Transport.serviceCall(Transport.java:196) at sun.rmi.transport.tcp.TCPTransport.handleMessages(TCPTransport.java:573) at sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run0(TCPTransport.java:834) at sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.lambda$run$0(TCPTransport.java:688) at java.security.AccessController.doPrivileged(Native Method) at sun.rmi.transport.tcp.TCPTransport$ConnectionHandler.run(TCPTransport.java:687) at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149) at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624) at java.lang.Thread.run(Thread.java:748)
06-03
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值