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

网站导航设计原则食品包装设计说明书

网站导航设计原则,食品包装设计说明书,网站到期怎么办,用asp做的网站运行完之后怎么生成一个可以打开的网站图标代理模式 为什么要学习代理模式?因为这是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/917291/

相关文章:

  • 广东 网站备案西安网站开发公司排名
  • 门户网站建设标准个人网站备案号被注销了
  • 福彩网网站建设方案一级消防工程师考试难度
  • 长春网站建设58同城误入网站退不了怎么做
  • 厦门网站建设团队四会市住房和城乡建设局网站
  • 专业商城网站建设公司新云自助建站
  • 为什么需要建设网站网站链接分享做推广
  • 摄影图片素材网站wordpress插件清单 很多很全
  • 章丘区当地网站建设哪家好临沂做网站的公司有哪些
  • 网上做设计兼职哪个网站好点高端网站建设推广
  • 南京网站设计培训价格上海公司电话
  • 旅游电子商务网站的建设方案wordpress支持
  • 建设垂直网站需要哪些流程网推公司怎么收费
  • 进入江苏省住房和城乡建设厅网站首页wordpress-5.0升级未被安装
  • 在线做家装设计的网站怎么知道网站是什么开源做的
  • 漳州做网站匹配博大钱少a网站设计制作的服务商
  • 在线考试网站开发报价无锡做网站公司在哪里
  • div网站模板门户网站首页设计
  • 电商网站开发教材免费空间 个人网站 google广告联盟
  • 企业更新网站的好处自媒体135app下载
  • 网站建设过程总结报告大气简洁网站
  • 如何弄一个网站建立一个网站赚钱了
  • 平湖公司网站建设ui设计稿
  • 购物网站建设 成都软件开发交付流程
  • asp.net+mvc+网站开发电气营销型网站方案
  • 用动易建设网站教程可以在线观看的免费资源
  • 网站推广软件app许昌网络推广公司
  • 网站推广公司水果茶优化设计六年级下册语文答案
  • 河北省住房和城乡建设厅网站首页网站建设网站及上传
  • 提供手机网站开发创新网站建设工作室