Java反射获取私有构造函数、属性、方法

我一直以为类的私有构造函数、属性、方法除了类自身其他类是无法访问的,前几天正好学习Spring框架,在学习Spring框架基础 Bean包时,写了一个简单的例子,类似如下:
  package study.spring.bean;

  public class SimpleBean

  {

  private String beanName;

  private SimpleBean() {

  System.out.println( " SimpleBean " );

  }

  /** */ /**

  * @return Returns the beanName.

  */

  public String getBeanName()

  {

  return beanName;

  }

  /** */ /**

  * @param beanName The beanName to set.

  */

  public void setBeanName(String beanName)

  {

  this .beanName = beanName;

  }

  }

  发现居然也能调用成功,当时很惊讶,反射机制平时在以前的项目中也常使用,但不能构造只有私有构造函数的类。

  自己做了一个简单例子:

  package study.spring.bean;

  import java.lang.reflect.Constructor;

  import java.lang.reflect.InvocationTargetException;

  public class SimpleTest

  {

  /** *//**

  * @param args

  */

  public static void main(String[] args)

  {

  // TODO Auto-generated method stub

  try

  {

  Constructor[] cts=Class.forName("study.spring.bean.SimpleBean").getDeclaredConstructors();

  for(int i=0;i<cts.length;i++){

  cts[i].newInstance(null);

  }

  }

  catch (SecurityException e)

  {

  // TODO Auto-generated catch block

  e.printStackTrace();

  }

  catch (ClassNotFoundException e)

  {

  // TODO Auto-generated catch block

  e.printStackTrace();

  }

  catch (IllegalArgumentException e)

  {

  // TODO Auto-generated catch block

  e.printStackTrace();

  }

  catch (InstantiationException e)

  {

  // TODO Auto-generated catch block

  e.printStackTrace();

  }

  catch (IllegalAccessException e)

  {

  // TODO Auto-generated catch block

  e.printStackTrace();

  }

  catch (InvocationTargetException e)

  {

  // TODO Auto-generated catch block

  e.printStackTrace();

  }

  }

  }

  也是如我所想 抛出java.lang.IllegalAccessException异常,当时就怀疑Spring框架是否使用反射的一些特性,后来查了相关文档才知道原因何在:

  实际上java在反射创建一个类的实例时,默认会检测是否符合相关安全,该检测开关可以关闭。

  Constructor、Field、Method都是继承于AccessibleObject,对应实例调用setAccessible(true)就关闭该开关

  如上面的例子,在代码 cts[i].newInstance(null);行前调用上述方法: cts[i].setAccessible(true);

  这样就可以创建只有构造函数的实例、调用私有构造方法,访问类的私有属性。

  呵呵,这样好像java安全性就大大降低.如果你非常注重应用的安全性,java当然考虑到这方面,你可以在JVM启动参数增加 -Djava.security.manager 启用安全管理器,如果有该参数,它将检测正在关闭接入检测的代码是否许可了这样做,上述代码执行时会抛出java.security.AccessControlException异常。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值