导航:首页 > 编程语言 > phphook钩子

phphook钩子

发布时间:2022-08-11 14:22:00

A. 插件钩子如何自定义,要些什么特别设置吗

OneThink以其便捷的建站、丰富的扩展、灵活的二次开发,以及云服务的支持,为广大个人和企业建站带来新的契机和机遇,即将成为互联网新的弄潮儿。 OneThink特性介绍: 1. 基于Thinkphp最新版本Thinkphp3.2。 2. 模块化:全新的架构和模块化的开发机制,便于灵活扩展和二次开发。 3. 文档模型/分类体系:通过和文档模型绑定,以及不同的文档类型,不同分类可以实现差异化的功能,轻松实现诸如资讯、下载、讨论和图片等功能。 4. 开源免费:OneThink遵循Apache2开源协议,免费提供使用。 5. 用户行为:支持自定义用户行为,可以对单个用户或者群体用户的行为进行记录及分享,为您的运营决策提供有效参考数据。 6. 云端部署:通过驱动的方式可以轻松支持平台的部署,让您的网站无缝迁移,内置已经支持SAE。 7. 云服务支持:即将启动支持云存储、云安全、云过滤和云统计等服务,更多贴心的服务让您的网站更安心。 8. 安全稳健:提供稳健的安全策略,包括备份恢复、容错、防止恶意攻击登录,网页防篡改等多项安全管理功能,保证系统安全,可靠、稳定的运行。 9. 应用仓库:官方应用仓库拥有大量来自第三方插件和应用模块、模板主题,有众多来自开源社区的贡献,让您的网站“One”美无缺。 oneThink后台添加插件步骤: 版本:V1.1.141212 (注:v1.1也有很多版本,一不小心就下到V1.1.140202 去了,还有其他版本,建议去代码托管平台下载最新版本) 我也不偷懒,把每一步步骤都记录下来。 一、进入后台,创建插件 这里的钩子我新建了一个indexFooter,因为我只需在前台首页底部显示友情链接即可。我们把上面所有要勾的地方都勾上,至于有什么区别,大家可以自己建几个例子区分一下,生成的文件是否一样。OK!到这里 我们的友情链接插件就创建好了!点击“确定”。(这里的自定义模板什么的,通通不填,我会在下篇文章演示添加自定义模板的效果) 二、点击“安装” 即可,找到我们刚安装好的Links插件,点击“设置”,你会看到它有个默认的“是否开启随机”的选项,这里我们不管它,因为我们用不上,等下要删掉的。安装后,我们可以在左侧导航“已安装插件后台”看到我们新建的“友情链接” 三、当我们点击左侧导航的“友情链接”,你会发现报错,大概就是说的某个表不存在。是的,我们刚才只是建了插件,如果涉及到数据存储到数据库, 还需要建表。这里不直接去数据库里建,因为这样做,是很不人性化的。那我们就找到安装插件的函数,在安装插件的时候建立数据库,这样就好了。首先系统的插件全部存放在 根目录/Addons/ 文件夹下面,打开此文件夹,我们看到有个Links文件夹,这就是我们刚创建的插件,一个插件对应一个文件夹。打开Links文件夹,里面有2个文件和2个文件夹。 四、其实现在oneThink做的越来越简洁了,不懂PHP的人照样创建插件,之后你就会发现。当然,如果你有自己的想法,不想局限于官方的限制,那还是要把php学好的。 五、打开插件入口文件:LinksAddon.class.php 里面有个类LinksAddon,先来分析一下这个文件吧 我这里把$admin_list 数组的model 值改成links了,为了与插件对应。接下来我们在install方法里添加新建数据库的语句,这样我们在安装插件的时候,就会新建数据库了,我的代码如下: public function install(){//安装插件的方法 //1、添加数据表 $model = D(); $db_prefix = C('DB_PREFIX'); $table_name = "{$db_prefix}links"; $sql=<<<SQL CREATE TABLE IF NOT EXISTS `$table_name` ( `id` int(11) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键', `title` varchar(80) NOT NULL DEFAULT '' COMMENT '站点名称', `link` varchar(140) NOT NULL DEFAULT '' COMMENT '链接地址', `summary` varchar(255) NOT NULL DEFAULT '' COMMENT '站点描述', `mailto` varchar(100) NOT NULL DEFAULT '' COMMENT '站长联系方式', `sort` int(3) unsigned NOT NULL DEFAULT 0 COMMENT '优先级', `nofollow` tinyint(1) unsigned NOT NULL DEFAULT 0 COMMENT '是否追踪', `type` tinyint(3) unsigned NOT NULL DEFAULT 1 COMMENT '类型分组', `cover_id` int(11) unsigned NOT NULL DEFAULT 0 COMMENT '封面图片', `status` tinyint(2) NOT NULL DEFAULT 1 COMMENT '状态(0:禁用,1:正常)', `create_time` int(11) unsigned NOT NULL DEFAULT 0 COMMENT '添加时间', PRIMARY KEY (`id`) ) ENGINE=MyISAM AUTO_INCREMENT=4 DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC COMMENT='友情连接表'; SQL; $model -> execute($sql);//执行sql语句 //2、返回true,表示插件安装成功 return true; } 我这里省略了很多细节判断,大家自己完善。 六、既然在安装插件的时候,新建了表,我们在卸载的插件的时候就要把表给删除,不然下次安装该插件的时候就会出问题。所以我们uninstall 方法代码如下: public function uninstall(){ //卸载插件的方法 $model = D(); $db_prefix = C('DB_PREFIX'); $table_name = "{$db_prefix}links"; $sql="DROP TABLE IF EXISTS `".$table_name."`;"; $model -> execute($sql);//执行sql语句 return true; } 好了,到这里就差不多了,保存一下LinksAddon.class.php 文件,应该可以正常显示了,我们来看看。进入插件列表,先把Links插件卸载,然后重新安装。点击左侧菜单“友情链接”,可以看到 之所以能正常显示这个列表,是因为系统有默认的模板,在\Application\Admin\View\Addons 文件夹里,有兴趣的同学可以研究一下这几个模板文件,其中这个列表的模板就是adminlist.html,那么我们要把封面、书名、描述等等这些字眼改掉,要去模板里改吗?细心的同学估计注意到了,在LinksAddon.class.php 文件 的$admin_list 数组里配置的,其他的看后面的注释就明白,这里详细说一下list_grid 关联的数组。我们刚才新建的links数据表有id、title、link等字段,你想在这个列表显示什么字段,都可以添加。我这里代码如下: 'list_grid'=>array( //这里定义的是除了id序号外的表格里字段显示的表头名和模型一样支持函数和链接 'title:网站名称', 'link:链接', 'summary:描述', 'create_timetime_format:添加时间', //time_format 是一个函数,把时间格式化,其他地方想使用什么函数也可以按照这种格式书写 'id:操作:[EDIT]编辑,[DELETE]删除' ), 保存,刷新后台友情链接列表 我们点击“新增” 来增加一个友情链接吧,你会发现,只有一个书名字段。我们打开Model/LinksModel.class.php 文件,我这里分别解释一下这两个自带的数组,具体看下面代码里的注释 class LinksModel extends Model{ public $model = array( 'title'=>'',//新增[title]、编辑[title]、删除[title]的提示 'template_add'=>'',//自定义新增模板自定义html edit.html 会读取插件根目录的模板 'template_edit'=>'',//自定义编辑模板html 'search_key'=>'',// 搜索的字段名,默认是title 'extend'=>1, //在后台列表是否显示 “增加”、“删除” 按钮,0-不显示 1-显示 ); public $_fields = array( 'id'=>array( 'name'=>'id',//字段名,与数据库的字段对应 'title'=>'ID',//显示标题 'type'=>'num',//字段类型:num、string、textarea、datetime、bool、select、radio、checkbox、editor、picture(封面)、file(附件)、 'remark'=>'',// 备注,相当于配置里的tip 'is_show'=>3,// 1-始终显示 2-新增显示 3-编辑显示 0-不显示 'value'=>0,//默认值 ), //下面演示一下 select字段怎么显示 radio、checkbox同理 'type'=>array( 'name'=>'type', 'title'=>'类型', 'type'=>'select', 'remark'=>'请选择所属类型', 'is_show'=>1, 'extra'=>'0:友情链接,1:合作站点', 'value'=>0, 'is_must'=>1, ), ); } ok,我最后的效果是这样的: 添加一条数据看看吧: 这里要显示具体类型、显示图片等,需要自定义adminlist.html模板了。关于自定义模板,我们下一篇文章再说。关于钩子,其实就是写一个函数从数据库读取数据,然后在前台需要的地方调用钩子就行。如果需要模板,则在钩子函数里解析模板。钩子调用格式一般: {:hook("钩子名称"),"[参数]"} 没参数就不写。直接写成这样{:hook("钩子名称")} 到此为止就是用系统默认的模板,一步一步的建立自己的插件,是不是很简单,就像填空题一样,只要按照它的规则填空,就ok了。 以上就是本文的全部内容,希望对大家学习PHP程序设计有所帮助。

B. 如何在AKCMS中HOOK(钩子)执行自己的代码求解

本功能为二次开发者设计,站长看不懂不影响正常使用,绕行即可。
不需要修改AKCMS的代码即可实现这样的功能,不修改AKCMS代码的好处是保持以后升级的时候不需要把修改过的文件,修改过的代码merge到新的版本中,始终保持独立。
AKCMS 2.7以上版本在动态执行时会检查(/plugins/runtime/)中是否有_before.php结尾的文件,如果有就在页面打开之前执行他们。页面打开完毕后检查(/plugins/runtime/)中是否有_after.php结尾的文件,如果有就执行他们。
例如这个需求:把所有动态执行的每一次访问的访问地址都记下日志以便分析。
拷贝以下代码:<?php
error_log($_SERVER['REQUEST_URI'].\n, 3, AK_ROOT.'./logs/log.txt');?保存为/plugins/runtime/log_after.php即可。
注意:生成静态页之后,直接就是HTML文件的显示,当然不能执行任何代码,所以本文所说的功能都是针对AKCMS动态执行时而言。
3.8新增功能:采集功能的hook
hook程序的以函数的形式统一写在configs/hook.php中,函数命名规则:
1 采集列表页的hook,命名为hook_spidelist_123(123代表采集规则ID,下同)
2 采集内容页的hook,命名为hook_spiderurl_123
以数组的形式向hook函数传入已经采集到的全部数据。举一个例子:要把采集内容页(假设内容页采集规则的ID是1)采集到的title中的字母全部大写就在/configs/hook.php中增加这样一个函数:
function hook_spiderurl_1($value) {
$value['title'] = strtoupper($value['title']);
return $value;}保存后就立即生效了,下次采集完ID1的采集规则后,会自动调用这个函数,实现你想要的功能。
3.8.4新增功能:保存内容的hook
hook程序的以函数的形式统一写在configs/hook.php中,函数命名规则:
1 修改内容正文的hook,命名为hook_saveitemdata_123(123代表所属模块ID,下同)
函数会传入两个参数,第一个是正文内容,第二个是除正文外其他字段的一个数组。返回值是处理后的正文内容。
2 修改内容其他字段的hook,命名为hook_saveitem_123
函数会传入两个参数,第一个是除正文外其他字段的一个数组,第二个是正文内容。返回值是处理后的数组。

C. thinkphp hook 怎么写

ThinkPHP3.2 扩展--钩子,HOOK
之前写到TP3.1的行为扩展是tag();在TP3.2中引入了另一种说法—:钩子。

我们来看一下TP3.2中的钩子这个东西:

一:文件流程:

1:/index.php ->require './ThinkPHP/ThinkPHP.php';

2:/ThinkPHP/ThinkPHP.php—->require CORE_PATH.'Think'.EXT; Think\Think::start();

3:/ThinkPHP/Library/Think/Think.class.php—–>App::run();

4:/ThinkPHP/Library/Think/App.class.php 。到这里基本流程就走完了,(这里不说细节);

二:代码:

1:看一下 App::run()方法:

// 应用初始化标签
Hook::listen('app_init');
App::init();
// 应用开始标签
Hook::listen('app_begin');
// Session初始化
if(!IS_CLI){
session(C('SESSION_OPTIONS'));
}
// 记录应用初始化时间
G('initTime');
App::exec();
// 应用结束标签
Hook::listen('app_end');
return ;

其中的Hook::listen(”)就是用来执行钩子的,我们可以在app_init这个安插的位置用来获取应用中安装的插件。

看一下Hook::listen();

/**
* 监听标签的插件
* @param string $tag 标签名称
* @param mixed $params 传入参数
* @return void
*/
static public function listen($tag, &$params=NULL) {
if(isset(self::$tags[$tag])) {
if(APP_DEBUG) {
G($tag.'Start');
trace('[ '.$tag.' ] --START--','','INFO');
}
foreach (self::$tags[$tag] as $name) {
APP_DEBUG && G($name.'_start');
$result = self::exec($name, $tag,$params);
if(APP_DEBUG){
G($name.'_end');
trace('Run '.$name.' [ RunTime:'.G($name.'_start',$name.'_end',6).'s ]','','INFO');
}
if(false === $result) {
// 如果返回false 则中断插件执行
return ;
}
}
if(APP_DEBUG) { // 记录行为的执行日志
trace('[ '.$tag.' ] --END-- [ RunTime:'.G($tag.'Start',$tag.'End',6).'s ]','','INFO');
}
}
return;
}

其中关键是:self::exec($name, $tag,$params); 看一下exec的代码:

/**
* 执行某个插件
* @param string $name 插件名称
* @param string $tag 方法名(标签名)
* @param Mixed $params 传入的参数
* @return void
*/
static public function exec($name, $tag,&$params=NULL) {
if(false === strpos($name,'\\')) {
// 插件(多个入口)
$class = "Addons\\{$name}\\{$name}Addon";
}else{
// 行为扩展(只有一个run入口方法)
$class = $name.'Behavior';
$tag = 'run';
}
$addon = new $class();
return $addon->$tag($params);
}

最后还不是 new $class();进而return $addon->$tag($params); 又转到了具体钩子的代码方法。其实就是我们原本的调用class的方法,只不过经过别人的高度封装了。

三:那么问题来了,这个钩子有什么用呢? 怎么用?

这里以OneThink 的{:hook('AdminIndex')}为例,看一些别人是怎么用的。

在系统初始化到 Hook::listen('app_init'); 时,

把app_init的标签位扩展了,在tags.php的配置文件中有这么个东西:用于初始化插件(或者说是获取系统中安装的插件)

<?php
return array(
'app_init'=>array('Common\Behavior\InitHook')
);

一看就明白,无非就是读取持久化的信息,放到缓存或是其他的方式

// 行为扩展的执行入口必须是run
public function run(&$content){
if(isset($_GET['m']) && $_GET['m'] === 'Install') return;

$data = S('hooks');
if(!$data){
$hooks = M('Hooks')->getField('name,addons');
foreach ($hooks as $key => $value) {
if($value){
$map['status'] = 1;
$names = explode(',',$value);
$map['name'] = array('IN',$names);
$data = M('Addons')->where($map)->getField('id,name');
if($data){
$addons = array_intersect($names, $data);
Hook::add($key,$addons);
}
}
}
S('hooks',Hook::get());
}else{
Hook::import($data,false);
}
}

当在程序执行到{:hook(‘AdminIndex’)}时—>调用的是Hook::listen(‘AdminIndex’);

AdminIndex这个挂载点包含了三个插件:分别是:SiteStat, SystemInfo,DevTeam。

用一个循环来分别按顺序执行.

总结:钩子其实就是起到一个挂载点的作用,这个钩子挂在哪里,就可以在哪里执行,内容或功能就是挂载插件或类库的具体实现。这样实现的代码就有很大的灵活性,挂载点不变,挂的东西变量,功能也就相应的变化,是不是很灵活强大呀。

D. PHP中如何实现Hook机制

给你推荐2个方法

  1. 类的__call 和__callstatic 。 这2个魔术方法是当调用类的内部方法不存在时执行。__call是实例化类之后调用方法不存在。__callstatic 是调用静态方法不存在,它里面的参数包含了方法名和传递的参数。这样就可以利用这2个方法去实现hook机制。根据方法名和参数去找指定位置的文件和方法执行。use_call_func和use_call_func_array 具体看文档

  2. 是反射机制。php已经很早就有反射机制了。利用类的反射机制。去实现hook。其实原理和1方法差不多。但是实现的方法比较高级而已。

E. PHP程序,如何监控内存情况

看到有人写透视宝做php监控的原理图,跟你分享下。我估计大家做的方式都是差不多。

PHP运行支撑的ZendEngine早在设计过程中已经预留了丰富的Hook,可以有效干涉处理过程中的几个关键步骤。利用了以下几个Hook,就能方便的获取数据:

1. zend_compile_file & zend_compile_string

加载分析文件或字符串,本身就会造成非常大的IO,如果过多地执行加载,无疑会造成内存和CPU的消耗.通过这两个hook,可以取得文件名、执行行数、使用内存和CPU占用时间。

2.zend_execute & zend_execute_internal

通过这两个hook的使用,我们可以准确地分析得出一个PHP应用中的类调用、方法调用、方法参数、内存占用和CPU占用,加以分析,便可以准确得出应用系统运行过程中的方法运行栈,API调用地址,SQL语句,CacheKey以及Cache命中等关键信息。

3.zend_throw_exception_hook

利用异常钩子,可以准确地得到应用系统运行过程中出现的异常信息,当然包括异常发生的类方法位置,参数,异常code和异常message。

4.zend_error_cb

错误钩子则更加直接,可以准确得到系统运行过程中出现的任何一个warning,代码错误或语法错误。

F. php中关于hook用途的问题

PHP 写插件 其中的HOOK 只是别人想的一个词语,术语而已
并无实际意义
在WINDOWS编程中 HOOK==钩子
是一种消息机制的一种
意思就是:蚊子叮了你一口,你的大脑神经接收到了,于是指挥肢体,去赶走还是拍死这个蚊子
这个大脑神经就是HOOK,系统接收用户操作,而HOOK则监视某一满足条件
用户输入A
,系统接收到A,而HOOK定义接收B,那么输入A,则不做操作
当输入B了,则激活HOOK,进行执行制定代码
PHP的插件HOOK,比如你添加一个插件,把这个插件信息提前告诉HOOK,然后HOOK去监视用户
当用户调用这个插件,HOOK就感知到了
于是就把插件功能实现出来

G. 谁能给个tp3.2.2 hook类的使用方法,我是要做动态插件

方法定义在function.PHP中
/**
* 处理插件钩子
* @param string $hook 钩子名称
* @param mixed $params 传入参数
* @return void
*/
function hook($hook,$params=array()){
\Think\Hook::listen($hook,$params);
}

H. 关于HOOK,如何通过钩子截获指定窗口的所有消息

这个参数应该是你调用SetWindowsHookEx的DLL的模块实例句柄,它可以经由DllMain入口的第一个参数得到。 HHOOK SetWindowsHookEx( int idHook, HOOKPROC lpfn, HINSTANCE hMod, DWORD dwThreadId);至于SetWindowsHookEx的第四个参数dwThreadId,才是你需要借由窗口句柄得到的窗口线程ID,你可以通过下面的代码获得: DWORD dwThreadID = GetWindowThreadProcessId(hwnd, NULL);选择相应的消息钩子,比如WH_CALLWNDPROC(用来监视窗口过程)、WH_GETMESSAGE(用来监视消息队列的消息)、WH_KEYBOARD(键盘消息)、WH_MOUSE(鼠标消息)等等。

阅读全文

与phphook钩子相关的资料

热点内容
做账为什么要用加密狗 浏览:583
考研群体怎么解压 浏览:156
linux修改命令提示符 浏览:224
圆圈里面k图标是什么app 浏览:59
pdf加空白页 浏览:945
linux服务器如何看网卡状态 浏览:316
解压新奇特视频 浏览:704
图书信息管理系统java 浏览:552
各种直线命令详解 浏览:862
程序员泪奔 浏览:146
素材怎么上传到服务器 浏览:515
android百度离线地图开发 浏览:189
web可视化编程软件 浏览:293
java笔试编程题 浏览:746
win11什么时候可以装安卓 浏览:564
java不写this 浏览:1001
云点播电影网php源码 浏览:97
pythonclass使用方法 浏览:226
移动加密软件去哪下载 浏览:294
php弹出alert 浏览:209