当前位置: 首页 > news >正文

深圳专业网站建设产品运营之中的广度讲解app下载的视频为什么手机找不到

深圳专业网站建设产品运营之中的广度讲解,app下载的视频为什么手机找不到,长春建设网站公司吗,做与食品安全有关的网站代理模式 为什么要学习代理模式?因为这是SpringAOP的底层! 【SpringAOP和SpingMVC}】 代理模式的分类: 静态代理 动态代理 代理就像这里的中介,帮助你去做向房东租房,你不能直接解出房东,而房东和中介…

代理模式

为什么要学习代理模式?因为这是SpringAOP的底层! 【SpringAOP和SpingMVC}】

代理模式的分类:

  • 静态代理

  • 动态代理

代理就像这里的中介,帮助你去做向房东租房,你不能直接解出房东,而房东和中介是因为租房而联系在一起,所以租房是接口

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-6pVz2Ts2-1677422310317)(java静态代理.assets/image-20230226102101840.png)]

静态代理

角色分析:

  • 抽象角色(租房):一般使用接口和抽象类来解决
  • 真实角色(房东):被代理的角色
  • 代理角色(中介):代理真实角色,被代理真实角色后,我们一般会做一些附属工作
  • 客户:访问代理对象的人

代码步骤:

  1. 接口

    package com.hong;//租房
    public interface Rent {public void rent();
    }
  2. 真实角色

    package com.hong;public class Client {public static void main(String[] args) {//房东要租房子Host host = new Host();//代理,中介帮房东租房子,但是呢房东会加一些附属操作!
    //        host.rent();Proxy proxy = new Proxy(host);//你不用面对房东,直接找中介即可proxy.rent();}
    }
  3. 代理角色

    package com.hong;public class Proxy implements Rent{private Host host;public Proxy(Host host) {this.host = host;}public Proxy() {}@Overridepublic void rent() {host.rent();seeHost();fare();hetong();}//看房public void seeHost(){System.out.println("中介带你看房");}public void hetong(){System.out.println("签合同");}//收中介费public void fare(){System.out.println("收中介费");}
    }
  4. 客户端访问代理角色

    package com.hong;//房东
    public class Host implements Rent{@Overridepublic void rent() {System.out.println("房东要出租房子");}
    }

代理模式的好处:

  • 可以使真实角色的操作更加纯粹!不用去关注一些公共的业务
  • 公共也就就交给代理角色!实现了业务的分工!
  • 公共业务发生扩展的时候,方便集中管理!

缺点:

  • 一个真实角色就会产生一个代理角色;代码量会翻倍,开发效率会变低

AOP

用代理增加功能,不改动原有的代码,只改动代理类

package com.hong;//真实对象
public class UserServiceImpl implements UserService {@Overridepublic void add() {System.out.println("增加一个用户");}@Overridepublic void delete() {System.out.println("删除一个用户");}@Overridepublic void update() {System.out.println("修改了一个用户");}@Overridepublic void query() {System.out.println("查询了一个用户");}
}
package com.hong;public class UserServiceProxy implements UserService{private UserServiceImpl userservice;public void setUserservice(UserServiceImpl userservice) {this.userservice = userservice;}@Overridepublic void add() {log("add");userservice.add();}@Overridepublic void delete() {log("delete");userservice.delete();}@Overridepublic void update() {}@Overridepublic void query() {}public void log(String msg){System.out.println("调用"+msg+"方法");}
}
package com.hong;public interface UserService {public void add();public void delete();public void update();public void query();
}
package com.hong;public class Client {public static void main(String[] args) {UserServiceImpl userService = new UserServiceImpl();UserServiceProxy proxy = new UserServiceProxy();proxy.setUserservice(userService);proxy.add();}
}

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-FhQMtFQi-1677422310319)(java静态代理.assets/image-20230226202716742.png)]

动态代理

  • 动态代理和静态代理角色一样
  • 动态代理类是动态生成的,不是我们直接写好的
  • 动态代理分为两大类:基于接口的动态代理,基于类的动态代理
    • 基于接口—JDK动态代理
    • 基于类:cglib
    • java字节码实现:javasist

需要了解两个类:proxy:代理,lnvocationHandler:调用处理程序

静态代理的好处:

  • 可以使真实角色的操作更加纯粹!不用去关注一些公共的业务
  • 公共也就就交给代理角色!实现了业务的分工!
  • 公共业务发生扩展的时候,方便集中管理!
  • 一个动态代理类代理的是一个接口,一般就是对应的一类业务
  • 一个动态代理,修改的成本极低

实现代码

动态代理

package com.hong.demo02;import com.hong.xxh.Rent;import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;//自动生成代理
public class ProxyInvocationHandler implements InvocationHandler {//被代理的接口private Object taget;public void setTaget(Object taget) {this.taget = taget;}//生成得到代理对象public Object getProxy() {return Proxy.newProxyInstance(this.getClass().getClassLoader(),taget.getClass().getInterfaces(),this);}//处理代理实例并返回结果public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {Object result = method.invoke(taget, args);return result;}
}

接口

package com.hong.demo02;public interface UserService {public void add();public void delete();public void update();public void query();
}

真实对象

package com.hong.demo02;//真实对象
public class UserServiceImpl implements UserService {@Overridepublic void add() {System.out.println("增加一个用户");}@Overridepublic void delete() {System.out.println("删除一个用户");}@Overridepublic void update() {System.out.println("修改了一个用户");}@Overridepublic void query() {System.out.println("查询了一个用户");}
}

客户端访问

package com.hong.demo02;import com.hong.Proxy;
import com.hong.UserServiceImpl;public class ClenClient {public static void main(String[] args) {//真实角色UserServiceImpl userService = new UserServiceImpl();//代理角色ProxyInvocationHandler pih = new ProxyInvocationHandler();pih.setTaget(userService);  //设置要代理的对象//动态生成代理UserService proxy = (UserService) pih.getProxy();proxy.delete();}
}

反序列化中动态代理的利用

我们将入口类定义为A,我们最理想的情况是 A[O] -> O.f,那么我们将传进去的参数O替换为B即可。但是在实战的情况下这种情况是极少的。

回到实战情况,比如我们的入口类A存在O.abc这个方法,也就是 A[O] -> O.abc;而 O 呢,如果是一个动态代理类,Oinvoke方法里存在.f的方法,便可以漏洞利用了,我们还是展示一下。

A[O] -> O.abc O[O2] invoke -> O2.f // 此时将 B 去替换

O2 最后 ----> O[B] invoke -> B.f // 达到漏洞利用效果

就像readObject在反序列化中自动调用,invoke在动态代理的时候也自动调用,如果我们在invoke插入恶意代码,就可进行攻击例如

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-XAkzDHfq-1677422310320)(java静态代理.assets/image-20230226223422071.png)]
结果
在这里插入图片描述

http://www.yayakq.cn/news/718760/

相关文章:

  • 网站编程设计如何写备注音乐中文网站模板
  • flash网站制作工具海口网站建设加q.479185700
  • 建设网站的费用吗大学生做家教比较好的网站
  • 学校门户网站开发制作一个网页需要花钱吗
  • 怎么做二级网站域名重庆网站建设建站收费
  • 泉州网站建设网站建设为什么选用美食做网站主页
  • 杭州网站建设方案推广做外贸必应网站产品曝光
  • 网站建设江西有多少家聚名网站
  • 微商的自己做网站叫什么名字网页版梦幻西游火眼金睛
  • 网站建设合同法电脑上用手机app是什么软件
  • wordpress主题显示不了岳阳seo官网
  • c 网站开发教程重庆做网站公司有哪些
  • 做神马网站优化排名软做一个论坛网站需要多少钱
  • 国内做免费的视频网站微信小程序注册认证
  • 如何运行asp.net网站装企erp管理系统
  • 舟山做网站网络推广方式主要有
  • 金华网站建设建设设计网站杭州做网站公司排名
  • 做网站 违法嵌入式累还是程序员累
  • 简单的网站建设企业实用网站模板
  • wordpress搭建多个购物网站养殖场网站源码
  • 网站 做 app移动外包公司要不要去
  • wap网站seo温州 外贸网站制作
  • 企业网站建设的要求重庆建设工程信息网查询系统
  • 建设一个视频教学网站企业如何开展网络营销
  • 如何把自己做的网站发布到网上遂溪 网站
  • 网站搭建是什么专业学的设计自己的logo
  • wordpress调用网站域名wordpress电脑安装教程视频
  • 合肥论坛网站制作专业济南网站建设价格
  • 做房产买卖哪些网站可以获客内部网站可以做ipc备案
  • 网站可以免费做吗建设网站的傻瓜图文指南