Java SecurityManager checkMulticast()方法与示例
SecurityManager类checkMulticast()
方法
checkMulticast()方法在java.lang包中可用。
checkMulticast()方法调用SocketPermission(i_add.getHostAddress(),“accept,connect”)权限以发送,接收,加入和离开IP多播。
checkMulticast()方法是一种非静态方法,只能通过类对象访问,如果尝试使用类名称访问该方法,则会收到错误消息。
在确定IP地址时,checkMulticast()方法可能会引发异常。
SecurityException-当不允许调用线程使用发送,接收,加入和离开IP多播时,可能引发此异常。
NullPointerException-当给定参数值为null时,可能引发此异常。
语法:
public void checkMulticast(InetAddress i_add);
参数:
InetAddressi_add–表示Internet组类型的地址。
返回值:
此方法的返回类型为void,不返回任何内容。
示例
//Java程序演示示例 //checkMulticast(InetAddressi_add) //SecurityManager的方法 import java.net.*; public class CheckMulticast extends SecurityManager { public static void main(String[] args) throws Exception { InetAddress i_add = InetAddress.getLocalHost(); //通过使用setProperty()方法是设置策略属性 //与安全经理 System.setProperty("java.security.policy", "file:/C:/java.policy"); //实例化CheckMulticast对象 CheckMulticast cm = new CheckMulticast(); //通过使用setSecurityManager()方法是设置 //安全经理 System.setSecurityManager(cm); //通过使用CheckMulticast(i_add)方法来检查 //该IP地址可以访问 cm.checkMulticast(i_add); //显示消息 System.out.println("Not Restricted.."); } }
输出结果
Exception in thread "main" java.security.AccessControlException: access denied ("java.net.SocketPermission" "127.0.0.1" "connect,accept,resolve") at java.base/java.security.AccessControlContext.checkPermission(AccessControlContext.java:472) at java.base/java.security.AccessController.checkPermission(AccessController.java:897) at java.base/java.lang.SecurityManager.checkPermission(SecurityManager.java:322) at java.base/java.lang.SecurityManager.checkMulticast(SecurityManager.java:971) at CheckMulticast.main(CheckMulticast.java:23)