* 对象的复制与克隆
* 1.默认情况下,对象是引用传递(实际上是对象标识符的复制,后面会详细说)
* 2.也就是说二个对象变量实际上是引用的是同一个对象
* 3.如果要创建一个新的对象,必须使用clone关键字来克隆当前对象
* 4.当使用clone关键字时,如果类中有__clone()会自动调用
* 5.__clone()方法运行在新创建的对象上面
* 6.__clone()方法能控制我们复制什么,以及克隆时要完成的基本操作
class Member { //声明三个私有属性 private $name; //会员名 private $email; //会员邮箱 private $score; //会员积分 //构造方法 public function __construct($name='',$email='',$score=0) { $this->name = $name; $this->email = $email; $this->score = $score; } //查询器(暂时省略访问控制) public function __get($name) { return $this->$name; } //设置器(暂时省略访问控制) public function __set($name,$value) { $this->$name = $value; } //克隆魔术方法在对象克隆时自动调用,针对新对象进行初始化操作 public function __clone() { $this->score = 0; } }
//实例化会员类Member,创建会员对象$member
$member = new Member('peter','peter@php.cn',1000);
//访问测试
echo $member->score;
//复制会员对象
$member1 = $member;
//使用新变量名$member1来更新对象信息
$member1->score = 2000;
//用新对象变量名$member1访问
echo $member1->score; echo '<hr>';
//用原对象对象名$member访问
echo $member->score;
* 结论:
* 1.新变量修改的结果反映到了原对象变量中
* 2.说明这二个变量,实际上指向的是同一个对象
* 3.也就是对象默认是引用传递
* 4.或者说,第二个变量名$member1只是原变量的别名,并没创建新对象
* 5.可以理解为仅仅是将原对象的标识符,重新起了一个新名称罢了
var_dump($member1); //对象id=1 var_dump($member); //对象id=1
//说明$member1和$member是二个完全一样的对象,仅仅是名称不同罢了
//如果想完全创建一个全新的对象应该如何做呢?需要使用关键字:clone
$member2 = clone $member;
//我们先查看一下对象变量$member2的score属性值
echo $member2->score; //目前是原始值2000
//修改score值
$member2->score = 5000; echo '<hr>';
//再次查看$member2中的score
echo $member2->score; //新值5000 echo '<hr>';
//大家想一下,我的这种修改,会不会影响到原$member变量的score属性值呢?
echo $member->score; //发现原对象的score属性值仍为2000,未发生变化
//这是为什么呢?因为我们使用了克隆技术,创建了二个完全不同的对象变量
//下面进行验证
var_dump($member); //变量id是1 var_dump($member2); //变量id是2
//这二个对象变量的id是不同的,说明是二个完全不同的对象
//下面完成这样的一个任务:创建新的会员对象的时候,将该会员的积分清零?应该怎么做?
//在Memeber类中创建一个__clone()克隆魔术方法,对克隆出的新对象进行预处理
//再演示一遍
//查看当前会积分
echo $member->score;
//克隆创建一个全新的对象$member3
$member3 = clone $member;
//查看新对象$member3的score值,以验证类中的__clone()是否生效?
echo '<hr>'; echo $member3->score; //0,说明克隆魔术方法已经生效
以上是php中对象的复制与克隆的详细内容。更多信息请关注PHP中文网其他相关文章!

要保护应用免受与会话相关的XSS攻击,需采取以下措施:1.设置HttpOnly和Secure标志保护会话cookie。2.对所有用户输入进行输出编码。3.实施内容安全策略(CSP)限制脚本来源。通过这些策略,可以有效防护会话相关的XSS攻击,确保用户数据安全。

优化PHP会话性能的方法包括:1.延迟会话启动,2.使用数据库存储会话,3.压缩会话数据,4.管理会话生命周期,5.实现会话共享。这些策略能显着提升应用在高并发环境下的效率。

thesession.gc_maxlifetimesettinginphpdeterminesthelifespanofsessiondata,setInSeconds.1)它'sconfiguredinphp.iniorviaini_set().2)abalanceIsiseededeedeedeedeedeedeedto to to avoidperformance andununununununexpectedLogOgouts.3)

在PHP中,可以使用session_name()函数配置会话名称。具体步骤如下:1.使用session_name()函数设置会话名称,例如session_name("my_session")。2.在设置会话名称后,调用session_start()启动会话。配置会话名称可以避免多应用间的会话数据冲突,并增强安全性,但需注意会话名称的唯一性、安全性、长度和设置时机。

会话ID应在登录时、敏感操作前和每30分钟定期重新生成。1.登录时重新生成会话ID可防会话固定攻击。2.敏感操作前重新生成提高安全性。3.定期重新生成降低长期利用风险,但需权衡用户体验。

在PHP中设置会话cookie参数可以通过session_set_cookie_params()函数实现。1)使用该函数设置参数,如过期时间、路径、域名、安全标志等;2)调用session_start()使参数生效;3)根据需求动态调整参数,如用户登录状态;4)注意设置secure和httponly标志以提升安全性。

在PHP中使用会话的主要目的是维护用户在不同页面之间的状态。1)会话通过session_start()函数启动,创建唯一会话ID并存储在用户cookie中。2)会话数据保存在服务器上,允许在不同请求间传递数据,如登录状态和购物车内容。

如何在子域名间共享会话?通过设置通用域名的会话cookie实现。1.在服务器端设置会话cookie的域为.example.com。2.选择合适的会话存储方式,如内存、数据库或分布式缓存。3.通过cookie传递会话ID,服务器根据ID检索和更新会话数据。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

安全考试浏览器
Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

Atom编辑器mac版下载
最流行的的开源编辑器

EditPlus 中文破解版
体积小,语法高亮,不支持代码提示功能

SecLists
SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。