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)