~~~
<?php
echo '<pre>';
//定義一個測試反射的類
class CQH
{
public $name = 'cqh';
private $country= 'china';
const gender = 'man';
public function say()
{
echo 'hello,world';
}
private function eat()
{
echo 'eat';
}
public static function drink()
{
echo 'drink';
}
}
/* //打印所有的反射接口
Reflection::export(new ReflectionExtension('reflection')); */
/* //反射創建所有的PHP類的導出結果,get_declared_classes可以獲取所有已聲明的類
foreach(get_declared_classes() as $class)
{
Reflection::export(new ReflectionClass($class));
} */
/* //只反射用戶自己定義的類
foreach(get_declared_classes() as $class)
{
$reflectionClass = new ReflectionClass($class);
if($reflectionClass->isUserDefined())
{
Reflection::export($reflectionClass);
}
} */
/********************************使用反射查找插件********************************/
//定義一個接口
interface IPlugin
{
public static function getName();
}
//查到所有實現了IPlugin接口的類
function findPlugins()
{
$plugins = array();
foreach(get_declared_classes() as $class)
{
$reflectionClass = new ReflectionClass($class);
if($reflectionClass->implementsInterface('IPlugin'))
{
$plugins[] = $reflectionClass;
}
}
return $plugins;
}
//確定用于菜單的類的成員
function computeMenu()
{
$menu = array();
foreach(findPlugins() as $plugins)
{
$reflectionMethod = $plugins->getMethod('getMenuItems');
if($reflectionMethod->isStatic())
{
$items = $reflectionMethod->invoke(null);
}
else
{
//如果這個方法不是靜態的,我們需要一個實例
$pluginsInstance = $plugins->newInstance();
$items = $reflectionMethod->invoke($pluginsInstance);
}
$menu = array_merge($menu,$items);
}
return $menu;
}
//確定用于文章的側邊欄的類的成員
function computeArticles()
{
$articles = array();
foreach(findPlugins() as $plugin)
{
if($plugin->hasMethod('getArticles'))
{
$reflectionMethod = $plugin->getMethod('getArticles');
if($reflectionMethod->isStatic())
{
$items = $reflectionMethod->invoke(null);
}
else
{
$pluginInstance = $plugin->newInstance();
$items = $reflectionMethod->invoke($pluginInstance);
}
$articles = array_merge($articles,$items);
}
}
return $articles;
}
//確定側邊欄的的類的成員
function computeSidebars()
{
$sidebars = array();
foreach(findPlugins() as $plugin)
{
if($plugin->hasMethod('getSidebars'))
{
$reflectionMethod = $plugin->getMethod('getSidebars');
if($reflectionMethod->isStatic())
{
$items = $reflectionMethod->invoke(null);
}
else
{
$pluginInstance = $plugin->newInstance();
$items = $reflectionMethod->invoke($pluginInstance);
}
$sidebars = array_merge($sidebars,$items);
}
}
return $sidebars;
}
//創建一個實現了Iplugin接口的類
class MyCoolPlugin implements IPlugin
{
public static function getName()
{
return 'MyCoolPlugin';
}
public static function getMenuItems()
{
//菜單項的數字索引數組
return array(array(
'description' => 'MyCoolPlugin',
'link' => '/MyCoolPlugin'
));
}
public static function getArticles()
{
//文章的數字索引數組
return array(array(
'path' => './MyCoolPlugin',
'title' => 'This is a really cool article',
'text' => 'This article is cool because...'
));
}
}
$menu = computeMenu();
$sidebars = computeSidebars();
$articles = computeArticles();
print_r($menu);
print_r($sidebars);
print_r($articles);
echo '</pre>';
?>
~~~
- OAuth
- 簡介
- 步驟
- 單點登錄
- .user.ini
- 時間轉換為今天昨天前天幾天前
- 獲取ip接口
- 協程
- 概念
- yield-from && return-values
- 協程與阻塞的思考
- 中間件
- mysqli異步與php的協程
- 代碼片段
- pdo 執行的sql語句
- 二進制安全
- 捕捉異常中斷
- global
- 利用cookie模擬登陸
- 解析非正常json
- 簡單的對稱加密算法
- RSA 加密
- 過濾掉emoji表情
- 判斷遠程圖片是否存在
- 一分鐘限制請求100次
- 文件處理
- 多文件上傳
- 顯示所有文件
- 文件下載和上面顯示所有文件配合
- 文件的刪除,統計,存數組等
- 圖片處理
- 簡介
- 驗證碼
- 圖片等比縮放
- 批量添加水印
- beanstalkd
- 安裝
- 使用
- RabbitMQ
- 簡介
- debain安裝
- centos安裝
- 常用方法
- 入門
- 工作隊列
- 訂閱,發布
- 路由
- 主題
- 遠程調用RPC
- 消息中間件的選型
- .htaccess
- isset、empty、if區別以及0、‘’、null
- php各版本
- php7.2 不向后兼容的改動
- php中的各種坑
- php7改變
- php慢日志
- 郵件
- PHPMailer實現發郵件
- 驗證郵件地址真實性
- 文件下載
- FastCgi 與 PHP-fpm 之間的關系
- openssl 加解密
- 反射
- 鉤子方法
- 查找插件
- opcode
- opcache使用
- opcache優化
- 分布式一致性hash算法
- 概念
- 哈希算法好壞的四個定義
- php實現
- java實現
- 數組
- jwt
- jwt簡介
- 單點登錄
- phpize
- GeoIP擴展
- php無法獲得https網頁內容的解決方案
- homestead運行的腳本
- Unicode和Utf-8轉換
- php優化
- kafka
- fpm配置
- configure配置詳解