在 Java 中,private
访问修饰符被认为是安全的,因为它在类之外是不可见的。那么外界也不知道这种方法。
但我认为Java反射可以用来打破这个规则。考虑以下情况:
public class ProtectedPrivacy{
private String getInfo(){
return "confidential";
}
}
现在从另一个班级我会得到信息:
public class BreakPrivacy{
public static void main(String[] args) throws Exception {
ProtectedPrivacy protectedPrivacy = new ProtectedPrivacy();
Method method = protectedPrivacy.getClass().getDeclaredMethod("getInfo", null);
method.setAccessible(true);
Object result = method.invoke(protectedPrivacy);
System.out.println(result.toString());
}
}
此时我只是认为私有方法仍然是安全的,因为要执行上述操作,我们必须知道方法名称。但是,如果包含由其他人编写的私有方法的类,我们将无法看到这些方法。
但是由于下面的代码行,我的观点变得无效。
Method method[] = new ProtectedPrivacy().getClass().getDeclaredMethods();
现在这method[]
包含了上面需要做的所有事情。我的问题是,有没有办法避免使用 Java 反射做这种事情?
我从Java 文档中引用了一些观点来澄清我的问题。
选择访问级别的提示:
如果其他程序员使用您的类,您要确保不会发生误用错误。访问级别可以帮助您做到这一点。使用对特定成员有意义的最严格的访问级别。除非您有充分的理由不这样做,否则请使用私有。