ThinkChat🤖让你学习和工作更高效,注册即送10W Token,即刻开启你的AI之旅 广告
## 第13章 代理模式 ### 什么是代理模式 1. 在客户端与实体之间建立一个代理对象(proxy),客户端对实体进行操作全部委派给代理对象,隐藏实体的具体实现细节 2. Proxy还可以与业务代码分离,部署到另外的服务器。业务代码中通过RPC来委派任务 ### 第一步:传统的客户端请求数据库的操作 *D:\wamp\www\demo\oop\framework\index.php* ~~~ // 从库 $db = Think\Factory::getDatabase('slave'); $info = $db->query("SELECT * FROM user WHERE id = 1 limit 1"); // 主库 $db1 = Think\Factory::getDatabase('master'); $db1->query("UPDATE user SET name = 'lili' WHERE id = 1 limit 1"); ~~~ ### 第二步:创建1个代理接口作为约束 *D:\wamp\www\demo\oop\framework\Think\IUserProxy.php* ~~~ <?php namespace Think; interface IUserProxy { function getUserName($id); function setUserName($id, $name); } ~~~ ### 第三步:声明1个代理类 *D:\wamp\www\demo\oop\framework\Think\Proxy.php* ~~~ <?php namespace Think; class Proxy implements IUserProxy { function getUserName($id) { $db = Think\Factory::getDatabase('slave'); $info = $db->query("SELECT * FROM user WHERE id = {$id} limit 1"); } function setUserName($id, $name) { $db1 = Think\Factory::getDatabase('master'); $db1->query("UPDATE user SET name = '{$name}' WHERE id = {$id} limit 1"); } } ~~~ ### 第四步:使用代理模式 *D:\wamp\www\demo\oop\framework\index.php* ~~~ $proxy = new Think\Proxy(); $proxy->getUserName($id); $proxy->setUserName($id, $name); ~~~ 这样做的好处就是隐藏了数据库的操作。