Java SecurityManager checkAccept()方法与示例
SecurityManager类checkAccept()
方法
checkAccept()方法在java.lang包中可用。
当前安全管理器将调用ServerSocket类的checkAccept()方法,并使用SocketPermission(host_add+“:”+port_no,“accept”)调用checkPermission。
checkAccept()方法是一种非静态方法,只能通过类对象访问,如果尝试使用类名称访问该方法,则会收到错误消息。
建立服务器连接时,checkAccept()方法可能会引发异常。
SecurityException-如果不允许调用线程接受连接,则可能引发此异常。
NullPointerException-如果给定的第一个参数为null,则可能引发此异常。
语法:
public void checkAccept(String host_add, int port_no);
参数:
字符串host_add–表示套接字连接的主机名。
intport_no–表示套接字连接的端口号。
返回值:
此方法的返回类型为void,不返回任何内容。
示例
//Java程序演示示例 //ofvoidcheckAccept(Stringhost_add,intport_no) //SecurityManager的方法 public class CheckAccept { public static void main(String[] args) { String host_add = "www.includehelp.com"; int port_no = 8080; //通过使用setProperty()方法是设置策略属性 //与安全经理 System.setProperty("java.security.policy", "file:/C:/java.policy"); //实例化SecurityManager对象 SecurityManager smgr = new SecurityManager(); //通过使用setSecurityManager()方法是设置 //安全经理 System.setSecurityManager(smgr); //通过使用checkAccept()方法是检查 //套接字连接是否启用 smgr.checkAccept(host_add, port_no); //启用连接后显示消息 System.out.println("Accepted.."); } }
输出结果
Exception in thread "main" java.security.AccessControlException: access denied ("java.net.SocketPermission" "www.includehelp.com:8080" "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.checkAccept(SecurityManager.java:940) at CheckAccept.main(CheckAccept.java:23)