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);

参数:

  • InetAddress i_add –表示Internet组类型的地址。

返回值:

此方法的返回类型为void,不返回任何内容。

示例

//Java程序演示示例 
//checkMulticast(InetAddress i_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)