栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

恶意代码漏洞-可能通过合并对可变对象的引用来暴露内部表示

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

恶意代码漏洞-可能通过合并对可变对象的引用来暴露内部表示

Date
易变

使用该setter,某人可以 无意中* 从外部修改日期实例 *

考虑一下

class MyClass {   private Date billDate;   public void setBillDate(Date billDate) {      this.billDate = billDate;   }}

现在有人可以设置它

MyClass m = new MyClass();Date dateToBeSet = new Date();m.setBillDate(dateToBeSet); //The actual dateToBeSet is set to mdateToBeSet.setYear(...); //^^^^^^^^ Un-intentional modification to dateToBeSet, will also modify the m's billDate

为避免这种情况,您可能需要在设置之前进行 深度复制

public void setBillDate(Date billDate) {    this.billDate = new Date(billDate.getTime());}


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/485784.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号