CTOCIO IT专家网

天极传媒 比特网 | 天极网 | IT专家网 | IT商网 | 52PK游戏网 | 手机天极 | IT分众 |
IT专家网搜索

您现在的位置: IT专家网 > Web服务子站 > Java技术

编写安全的Java代码

作者: yongbing ,  出处:IT专家网论坛, 责任编辑: 包春林, 
2008-05-16 04:00
  本文是来自Sun官方站点的一篇关于如何编写安全的Java代码的指南,开发者在编写一般代码时,可以参照本文的指南

  保护包

  有时需要在全局防止包被不可信任代码访问,本节描述了一些防护技术:

  • 防止包注入:如果不可信任代码想要访问类的包保护成员,可以尝试在被攻击的包内定义自己的新类用以获取这些成员的访问权。防止这类攻击的方式有两种:

  1. 通过向java.security.properties文件中加入如下文字防止包内被注入恶意类。

  ...

  package.definition=Package#1 [,Package#2,...,Package#n]

  ...

  这会导致当试图在包内定义新类时类装载器的defineClass方法会抛出异常,除非赋予代码一下权限:

  ...

  RuntimePermission("defineClassInPackage."+package)

  ...

  2. 另一种方式是通过将包内的类加入到封装的Jar文件里。

  (参看http://java.sun.com/j2se/sdk/1.2/docs/guide/extensions/spec.html)

  通过使用这种技巧,代码无法获得扩展包的权限,因此也无须修改java.security.properties文件。

  • 防止包访问:通过限制包访问并仅赋予特定代码访问权限防止不可信任代码对包成员的访问。通过向java.security.properties文件中加入如下文字可以达到这一目的:

  ...

  package.access=Package#1 [,Package#2,...,Package#n]

  ...

  这会导致当试图在包内定义新类时类装载器的defineClass方法会抛出异常,除非赋予代码一下权限:

  ...

  RuntimePermission("defineClassInPackage."+package)

  ...

共4页。 9 1 2 3 4 :

网友评论

笔名 
请您注意:遵守国家有关法律、法规,尊重网上道德,承担一切因您的行为而直接或间接引起的法律责任。    IT专家网友拥有管理笔名和留言的一切权利。
  • 周排行榜
  • 月排行榜

邮件订阅

       
天极服务 | 关于我们 | 网站律师 | 加入我们 | 联系我们 | 广告业务 | 友情链接 | 我要挑错
All Rights Reserved, Copyright 2004-2008, Ctocio.com.cn
渝ICP证B2-20030003号 如有意见请与我们联系 powered by 天极内容管理平台CMS4i