java.lang.SecurityException: Prohibited package name: java.com.xx异常抛出

博客介绍了在IDEA中尝试启动包含'java'包名的主函数时遇到的安全异常。异常源于Java的双亲委派模型,该模型规定下层类加载器不能加载已被上层加载器加载的类,尤其是'java.*'包。这种机制是Java安全模型的一部分,防止恶意代码冒充系统类。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

使用idea创建了一个新的工程,然后建了一个名为“java”的文件夹,当启动里面的主函数时,出现如下异常:

根据异常信息,定位到java.lang.ClassLoader.preDefineClass进行排查,发现以下代码片断:


   
   
  1. /* Determine protection domain, and check that:
  2. - not define java.* class,
  3. - signer of this class matches signers for the rest of the classes in package.
  4. */
  5. private ProtectionDomain preDefineClass( String name,
  6. ProtectionDomain protectionDomain)
  7. {
  8. if (! checkName(name))
  9. throw new NoClassDefFoundError( "IllegalName: " + name);
  10. if ((name != null) && [color=red]name. startsWith( "java.")[/color]) {
  11. throw new SecurityException( "Prohibited package name: " +
  12. name. substring( 0, name. lastIndexOf( '.')));
  13. }
  14. if (protectionDomain == null) {
  15. protectionDomain = getDefaultDomain();
  16. }
  17. if (name != null)
  18. checkCerts(name, protectionDomain. getCodeSource());
  19. return protectionDomain;
  20. }
  21. ......
  22. // true if the name is null or has the potential to be a valid binary name
  23. private boolean checkName( String name) {
  24. if ((name == null) || (name. length() == 0))
  25. return true;
  26. if ((name. indexOf( '/') != - 1)
  27. || (! VM. allowArraySyntax() && (name. charAt( 0) == '[')))
  28. return false;
  29. return true;
  30. }

可以看出preDefineClass方法首先对类名进行了检查,发现以java作为一级包名,则抛出安全异常:禁止使用的包名!

这条安全异常是由Java类加载的“双亲委派模型”(详见这里)所导致的。在双亲委派模型中,由父加载类加载的类,下层加载器是不能加载的。本例中最高层加载器BootstrapClassLoader加载了classpath路径下所定义的java.*包内的类,而java.research包就不能由BootstrapClassLoader的下层加载器AppClassLoader加载了。这也是java安全机制中对于恶意代码所采取的防护措施。

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值