`

如何防止通过反射访问私有方法

 
阅读更多
我们知道通过反射可以访问私有方法,有时候就会想有什么方法可以防止私有方法被访问呢,设定SecurityManager。默认的情况下SecurityManager是空的。
有时间可以把:SecurityManager 研究下
package com.patterns;

import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.security.Permission;
import java.security.SecurityPermission;

import sun.reflect.Reflection;



public class Test{
	public static void main(String[] args) throws NoSuchMethodException, SecurityException{
		A a = new A();
		SecurityManager sp = System.getSecurityManager();
		Class cl = a.getClass();
		
		Method m = cl.getDeclaredMethod("test", (Class[])null);
		m.setAccessible(true);
	}
}

class A{
	static{
		System.setSecurityManager(new SecurityManager());
	}
	private void test(){
		System.out.println("hello");
	}
}

另外有的同学想,你既然可以set,我也可以重新给set为null啊,注意一旦set之后,重新set会抛出异常。在think in java里提到:似乎没有什么方法可以防止访问私有方法。书中讨论了各式各样的类:嵌套类,匿名内部类。也许SecurityManager是解决这个的唯一方法。
分享到:
评论

相关推荐

    java 反射 调用私有方法(有参数私有方法)获取私有属性值

    这个能力使得开发者可以突破静态类型的束缚,实现一些在编译时期无法完成的功能,如访问私有成员、调用私有方法以及操作非公有的属性。 在Java中,私有方法和私有属性通常不允许外部类直接访问,这是为了保护类的...

    Java反射访问私有变量和私有方法.doc

    Java 反射访问私有变量和私有方法 Java 反射机制是 Java 语言中的一种强大的工具,使得我们可以在运行时装配代码,而无需在对象之间进行源代码链接,从而使代码更具灵活性。在实际测试中,我们经常需要访问类的非...

    C#net反射实现访问类中的私有变量或者方法

    除了访问私有成员外,反射还可以用来动态地创建对象实例。例如,可以通过`Activator.CreateInstance()`方法或`Type.InvokeMember`方法来创建对象。 #### 3.2 调用方法 对于方法的调用,同样可以使用反射来实现。...

    java * 反射工具类. 提供调用getter/setter方法, 访问私有变量, 调用私有方法, 获取泛型类型Class

    提供调用getter/setter方法, 访问私有变量, 调用私有方法, 获取泛型类型Class,java * 反射工具类. 提供调用getter/setter方法, 访问私有变量, 调用私有方法, 获取泛型类型Class,java * 反射工具类. 提供调用getter/...

    java反射机制,调用私有方法

    2. **访问私有成员**:通过反射,我们可以访问类的私有字段和方法,这在单元测试、调试或某些特定场景下可能需要。`Method`类提供了`getDeclaredMethod()`方法来获取类的私有方法,而`invoke()`方法则可以用来调用这...

    java 反射工具类. 提供调用getter/setter方法, 访问私有变量, 调用私有方法, 获取泛型类型Class

    提供调用getter/setter方法, 访问私有变量, 调用私有方法, 获取泛型类型Class, 被AOP过的真实类等工具函数.反射工具类. 提供调用getter/setter方法, 访问私有变量, 调用私有方法, 获取泛型类型Class, 被AOP过的真实...

    Java 反射详解(包含私有方法属性的调用)

    对于私有方法和属性的访问,Java反射提供了一种特殊的方式。通常,私有成员在外部类是不可见的,但通过`java.lang.reflect.Method`和`java.lang.reflect.Field`类,我们可以绕过访问控制。例如,`Method`类的`...

    C#私有成员反射调用类库

    尽管可以利用反射访问私有成员,但这应被视为一种特殊情况下的权宜之计,而不是常规编程实践。在单元测试中,适度使用反射可以帮助验证私有方法的行为,但也要注意保持测试的独立性和稳定性。在设计和实现代码时,应...

    反射私有内部类的例子

    #### 三、反射访问私有内部类 通常情况下,内部类是用于封装逻辑的,它们可以被声明为public、protected、默认或private。对于私有的内部类,通常只能被包含它的外部类所访问。但在某些特殊场景下,我们可能需要在...

    反射修改私有成员变量例子

    使用 `setAccessible()` 方法设置私有成员变量的可访问性为 true。 4. 修改私有成员变量的值 使用 `set()` 方法修改私有成员变量的值。 实例代码 在以下代码中,我们将使用反射机制来修改私有成员变量的值: ```...

    Java反射机制,通过对象访问调用类的私有成员或方法

    要调用私有方法,我们需要使用`Method`类,先获取到该方法的`Method`对象,然后通过`setAccessible(true)`将其访问权限设为可访问,最后通过`invoke()`方法调用: ```java Method privateMethod = personClass....

    JUnit4利用反射机制测试类的私有成员

    5. 通过`Class`对象的`getDeclaredMethod()`或`getDeclaredField()`方法获取私有方法或属性。例如,`Method setMethod = child.getClass().getDeclaredMethod("setCommodity_number", Integer.class)` 6. 使用`...

    通过反射调用静态方法

    在测试框架中,用于访问私有成员或模拟方法;在序列化库中,用于反序列化对象等。 然而,尽管反射强大,但也存在性能开销和安全性问题。频繁使用反射可能降低程序运行效率,同时,反射可以访问和修改私有成员,增加...

    对私有方法进行单元测试

    另外,可以创建一个友元类(friend class),它拥有访问私有方法的权限。这种方法在大型项目中不常见,因为它增加了代码的复杂性,但它提供了一种在保持封装的同时测试私有方法的方式。 最后,我们不应忘记,测试的...

    Java方法反射调用demo

    由于私有方法在外部不可见,我们需要使用`getDeclaredMethod`而不是`getMethod`,并且可能需要设置访问权限: ```java Method privateMethod = MyClass.class.getDeclaredMethod("myPrivateMethod"); privateMethod...

    java 反射取得类的私有属性,通过私有属性取得属性值

    为了访问私有字段,我们需要调用`setAccessible(true)`方法,使得我们可以绕过Java的访问控制规则。 ```java for (Field field : fields) { if ("myPrivateField".equals(field.getName())) { field....

    反射高手巧妙实现强行私有成员源代码,java跨域范围

    以下是一个简单的例子,展示如何使用反射访问私有字段: ```java public class PrivateMemberExample { private String secret = "这是私有变量"; // ... } public class HackUtils { public static void main...

    利用java反射机制调用类的私有方法(推荐)

    然而,通过反射机制,我们可以打破这种限制,调用原本不可见的私有方法。下面我们将详细讨论如何利用Java反射机制来调用类的私有方法。 首先,我们需要导入相关的Java反射包,包括`java.lang.reflect.Method`和`...

    Java反射机制修改私有成员变量的实现_Reflection

    在Java中,反射机制主要用于以下几种情况:动态加载类、访问私有成员、运行时检查类型以及调用私有方法等。 标题“Java反射机制修改私有成员变量的实现_Reflection”着重讲述了如何利用反射来修改私有成员变量的值...

Global site tag (gtag.js) - Google Analytics