Java의 동적 프록시 및 정적 프록시 분석 예
0. 에이전트 모드
에이전트 모드를 배워야 하는 이유는 무엇인가요? 이것은 SpringAOP의 하위 레이어입니다. [SpringAOP 및 SpringMVC]
프록시 모드 분류:
정적 프록시
동적 프록시
1정적 프록시에서는 대상으로 삼습니다. 대상 개체 각 메서드의 향상은 수동으로 수행됩니다(코드는 나중에 자세히 설명합니다). 이는 매우 융통성이 없습니다(예를 들어 새 메서드가 인터페이스에 추가되면 대상 개체와 프록시 개체를 수정해야 합니다). 그리고 번거롭습니다(각 대상을 수정해야 함 각 클래스는 별도의 프록시 클래스를 작성합니다
). 실제 애플리케이션 시나리오는 거의 없으며 일상적인 개발에 정적 프록시가 사용되는 시나리오도 거의 없습니다.역할 분석:
추상 역할: 일반적으로 문제를 해결하기 위해 인터페이스 또는 추상 클래스가 사용됩니다.
- 실제 역할: 프록시되는 역할
- 에이전트 역할: 이후 실제 역할을 프록시합니다. 실제 역할을 대리하여 우리는 일반적으로 일부 보조 작업을 수행합니다
- 고객: 프록시 개체에 액세스하는 사람!
- 코드 단계:
1. 인터페이스
public interface Rent { public void rent(); }
//房东 public class Host implements Rent { public void rent() { System.out.println("房东要租房子"); } }
public class Proxy implements Rent{ private Host host; public Proxy() { } public Proxy(Host host) { this.host = host; } public void rent(){ seeHouse(); host.rent(); fare(); } //看房 public void seeHouse(){ System.out.println("中介带你看房"); } //收中介费 public void fare(){ System.out.println("中介收费"); } }
실제 캐릭터의 조작을 더욱 순수하게 만들 수 있습니다! 공무는 신경쓰지 않아도 됩니다
- 공무는 대리인 역할에 맡기겠습니다! 업무분업을 실현하라!
- 공공부문이 확대되면 중앙관리가 편리해집니다!
- 단점: 실제 역할은 JVM 관점에서 프록시 역할을 생성하며 정적 프록시는 컴파일 중에 인터페이스, 구현 클래스 및 프록시 클래스를 실제 클래스 파일로 전환합니다.
2. 기본 프록시 모델인 AOP에 대한 이해를 심화합니다.
3. 동적 프록시동적 프록시와 정적 프록시의 역할은 동일합니다
- 동적 프록시의 프록시 클래스 우리가 직접 작성한 것이 아닌 동적으로 생성됩니다!
- 동적 프록시는 두 가지 범주로 나뉩니다: 인터페이스 기반 동적 프록시, 클래스 기반 동적 프록시
- 인터페이스 기반 ——JDK 동적 프록시
- java 바이트코드 구현: javasist
- 두 가지 클래스를 이해해야 합니다. 프록시: 프록시 클래스, InvocationHandler: 호출 핸들러 JVM 관점에서 동적 프록시는 런타임에 클래스 바이트코드를 동적으로 생성하고 JVM.
- 클래스 기반: cglib 동적 프록시
public class Client { public static void main(String[] args) { Host host = new Host(); //代理,代理角色一般会有附属操作! Proxy proxy = new Proxy(host); proxy.rent(); } }
실제 문자의 작업을 더욱 순수하게 만들 수 있습니다! 일부 공무는 처리할 필요가 없습니다
- 공무는 대리인 역할에 맡기겠습니다! 구현
//Proxy是生成动态代理类,提供了创建动态代理类和实例的静态方法,它也是由这些方法创建的所有动态代理类的超类。 //InvocationHandler-- invoke 调用处理程序并返回接口, 是由代理实例的调用处理程序实现的接口 。
로그인 후 복사- 1.
loader
: 클래스 로더, 프록시 객체를 로드하는 데 사용됩니다.
2.인터페이스
: 프록시 클래스에 의해 구현된 일부 인터페이스 loader
:类加载器,用于加载代理对象。
2.interfaces
: 被代理类实现的一些接口;
3.h
: 实现了 InvocationHandler
接口的对象;
要实现动态代理的话,还必须需要实现InvocationHandler
来自定义处理逻辑。 当我们的动态代理对象调用一个方法时,这个方法的调用就会被转发到实现InvocationHandler
接口类的 invoke
方法来调用。
public static Object newProxyInstance(ClassLoader loader, Class<?>[] interfaces, InvocationHandler h){ }
1.proxy :动态生成的代理类
2.method : 与代理类对象调用的方法相对应
3.args : 当前 method 方法的参数
动态代理的例子
1、定义接口
public interface InvocationHandler { Object invoke(Object proxy, Method method, Object[] args) throws Throwable; }
2、实现租房的接口
public interface Rent { public void rent(); }
3、定义一个JDK动态代理类
public class Host implements Rent { @Override public void rent() { System.out.println("房东要租房"); } }
invoke()
方法: 当我们的动态代理对象调用原生方法的时候,最终实际上调用到的是 invoke()
方法,然后 invoke()
方法代替我们去调用了被代理对象的原生方法。
4、获取代理对象的工厂类
public class DebugInvocationHandler implements InvocationHandler { /** * 代理类中的真实对象 */ private final Object target; public DebugInvocationHandler(Object target){ this.target = target; } /** * 当你使用代理对象调用方法的时候实际会调用到这个方法 */ @Override public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { //调用方法前 System.out.println("before method" + method.getName()); Object res = method.invoke(target, args); //调用方法后 System.out.println("after method" + method.getName()); return res; } }
getProxy()
:主要通过Proxy.newProxyInstance()
3.
h
: InvocationHandler
인터페이스 개체를 구현했습니다. 동적 프록시를 구현하려면 InvocationHandler
도 구현하여 처리 논리를 사용자 정의해야 합니다. 동적 프록시 객체가 메소드를 호출하면 이 메소드에 대한 호출은 InvocationHandler
인터페이스를 구현하는 클래스의 invoke
메소드로 전달됩니다.
public class JdkProxyFactory { public static Object getProxy(Object target){ return Proxy.newProxyInstance( target.getClass().getClassLoader(), target.getClass().getInterfaces(), new DebugInvocationHandler(target) ); } }
1.method: 프록시 클래스 객체가 호출한 메소드에 해당🎜🎜🎜3.🎜args: 현재 메소드 method의 매개변수🎜proxy: 동적으로 생성된 프록시 클래스
2.
Dynamic 프록시 예
🎜1. 인터페이스 정의🎜public static void main(String[] args) { //Rent rent = new Host(); //Rent rentProxy= (Rent) Proxy.newProxyInstance(rent.getClass().getClassLoader(), rent.getClass().getInterfaces(),new DebugInvocationHandler(rent)); Rent rentProxy = (Rent)JdkProxyFactory.getProxy(new Host()); rentProxy.rent(); }
invoke()
방법: 동적 프록시 개체가 기본 메서드를 호출할 때 실제로 호출되는 것은 invoke()
메서드이고, 그런 다음 invoke()
메서드는 프록시 개체의 기본 메서드를 호출합니다. 우리를 대신해. 🎜🎜4. 프록시 객체의 팩토리 클래스 얻기🎜rrreee🎜getProxy()
: 주로 Proxy.newProxyInstance()
메서드를 통해 특정 클래스의 프록시 객체를 얻습니다. 🎜🎜5. 🎜rrreee🎜🎜🎜🎜🎜🎜before methodrent🎜집주인이 집을 임대하고 싶어🎜after methodrent🎜🎜를 사용하여 실제로 위 에이전트를 실행한 결과위 내용은 Java의 동적 프록시 및 정적 프록시 분석 예의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











Java의 Weka 가이드. 여기에서는 소개, weka java 사용 방법, 플랫폼 유형 및 장점을 예제와 함께 설명합니다.

Java의 Smith Number 가이드. 여기서는 정의, Java에서 스미스 번호를 확인하는 방법에 대해 논의합니다. 코드 구현의 예.

이 기사에서는 가장 많이 묻는 Java Spring 면접 질문과 자세한 답변을 보관했습니다. 그래야 면접에 합격할 수 있습니다.

Java 8은 스트림 API를 소개하여 데이터 컬렉션을 처리하는 강력하고 표현적인 방법을 제공합니다. 그러나 스트림을 사용할 때 일반적인 질문은 다음과 같은 것입니다. 기존 루프는 조기 중단 또는 반환을 허용하지만 스트림의 Foreach 메소드는이 방법을 직접 지원하지 않습니다. 이 기사는 이유를 설명하고 스트림 처리 시스템에서 조기 종료를 구현하기위한 대체 방법을 탐색합니다. 추가 읽기 : Java Stream API 개선 스트림 foreach를 이해하십시오 Foreach 메소드는 스트림의 각 요소에서 하나의 작업을 수행하는 터미널 작동입니다. 디자인 의도입니다

Java의 TimeStamp to Date 안내. 여기서는 소개와 예제와 함께 Java에서 타임스탬프를 날짜로 변환하는 방법에 대해서도 설명합니다.

캡슐은 3 차원 기하학적 그림이며, 양쪽 끝에 실린더와 반구로 구성됩니다. 캡슐의 부피는 실린더의 부피와 양쪽 끝에 반구의 부피를 첨가하여 계산할 수 있습니다. 이 튜토리얼은 다른 방법을 사용하여 Java에서 주어진 캡슐의 부피를 계산하는 방법에 대해 논의합니다. 캡슐 볼륨 공식 캡슐 볼륨에 대한 공식은 다음과 같습니다. 캡슐 부피 = 원통형 볼륨 2 반구 볼륨 안에, R : 반구의 반경. H : 실린더의 높이 (반구 제외). 예 1 입력하다 반경 = 5 단위 높이 = 10 단위 산출 볼륨 = 1570.8 입방 단위 설명하다 공식을 사용하여 볼륨 계산 : 부피 = π × r2 × h (4

Spring Boot는 강력하고 확장 가능하며 생산 가능한 Java 응용 프로그램의 생성을 단순화하여 Java 개발에 혁명을 일으킨다. Spring Ecosystem에 내재 된 "구성에 대한 협약"접근 방식은 수동 설정, Allo를 최소화합니다.
