查看PHP opcode扩展模块及Web服务

开发 后端
之所以重新实现一个这样的模块,主要是因为vld不支持PHP_FUNCTION API,也就是说vld只能用于CLI形式,而Opdumer同时拥有CLI API和PHP_FUNCTION API,另外,也想借助编写这个模块的机会学习Zend Engine中opcode的编译和执行机制。

最近花了大约一星期的时间写了一个PHP扩展模块Opdumer,并封装成了Web服务(点击这里访问)。这个模块的主要内容是输出PHP代码对应的opcode。其实之前已经有一些用于查看opcode的扩展模块,如比较有名的vld。之所以重新实现一个这样的模块,主要是因为vld不支持PHP_FUNCTION API,也就是说vld只能用于CLI形式,而Opdumer同时拥有CLI API和PHP_FUNCTION API,另外,也想借助编写这个模块的机会学习Zend Engine中opcode的编译和执行机制。个人打算后面专门针对opcode的编译执行机制写一篇文章,而本文主要描述Opcode的使用方法及对应Web服务的使用。

Opdumper

安装

Opdumper的源码已经托管在github上,其地址为:https://github.com/ericzhang-cn/opdumper。可以通过以下命令克隆源代码:

  1. git clone https://github.com/ericzhang-cn/opdumper.git   

Opdumper是一个标准的PHP Extension,安装方法如下:

首先将Opdumper源码放到PHP源码包的ext/opdumper目录下,进入此目录执行如下命令:

  1. phpize   
  2. ./configure  
  3. make  
  4. make install  

然后在php.ini中添加一行配置:

  1. extension=opdumper.so  

目前opdumper支持PHP>=5.3,在Linux和MacOS下测试通过,Windows下未做测试。

CLI API

Opdumper支持类似vld的命令行方式输出opcode,只需在执行php命令时通过-d参数将opdumper.active=1传入。例如我们有一个foo.php:

  1. <?php   
  2. $a = 'hello';   
  3. echo $a;   
  4. ?> 

执行如下命令:

  1. php -d opdumper.active=1 foo.php  

结果如下:


Snip20120516 4

PHP_FUNCTION API

Opdumper还支持vld不支持的PHP_FUNCTION API,Opdumper提供了两个PHP函数:od_dump_opcodes_string和od_dump_opcodes_file。前者接受一个字符串作为产生,字符串是一段PHP代码;后者接受一个PHP文件作为参数,返回值均是一个存有opcode结果的PHP数组。以od_dump_opcodes_file为例,我们在foo.php同一目录下再写一个bar.php:

  1. <?php  
  2. $opcodes = od_dump_opcodes_file('./foo.php');   
  3. var_dump($opcodes);   
  4. ?>   
  5.  

执行结果如下:

  1. array(3) {   
  2.   [0]=>   
  3.   array(8) {   
  4.     ["lineno"]=>   
  5.     int(2)   
  6.     ["opcode"]=>   
  7.     string(11) "ZEND_ASSIGN" 
  8.     ["op1_type"]=>   
  9.     string(2) "CV" 
  10.     ["op2_type"]=>   
  11.     string(5) "CONST" 
  12.     ["result_type"]=>   
  13.     string(0) "" 
  14.     ["op1"]=>   
  15.     string(2) "~0" 
  16.     ["op2"]=>   
  17.     string(5) "hello" 
  18.     ["result"]=>   
  19.     string(0) "" 
  20.   }   
  21.   [1]=>   
  22.   array(8) {   
  23.     ["lineno"]=>   
  24.     int(3)   
  25.     ["opcode"]=>   
  26.     string(9) "ZEND_ECHO" 
  27.     ["op1_type"]=>   
  28.     string(2) "CV" 
  29.     ["op2_type"]=>   
  30.     string(6) "UNUSED" 
  31.     ["result_type"]=>   
  32.     string(6) "UNUSED" 
  33.     ["op1"]=>   
  34.     string(2) "~0" 
  35.     ["op2"]=>   
  36.     string(6) "UNUSED" 
  37.     ["result"]=>   
  38.     string(6) "UNUSED" 
  39.   }   
  40.   [2]=>   
  41.   array(8) {   
  42.     ["lineno"]=>   
  43.     int(5)   
  44.     ["opcode"]=>   
  45.     string(11) "ZEND_RETURN" 
  46.     ["op1_type"]=>   
  47.     string(5) "CONST" 
  48.     ["op2_type"]=>   
  49.     string(6) "UNUSED" 
  50.     ["result_type"]=>   
  51.     string(6) "UNUSED" 
  52.     ["op1"]=>   
  53.     string(1) "1" 
  54.     ["op2"]=>   
  55.     string(6) "UNUSED" 
  56.     ["result"]=>   
  57.     string(6) "UNUSED" 
  58.   }   
  59. }  

Opdumper的Web服务:Opcode Dumper

坦白说,安装PHP模块还是挺麻烦的。所以为了方便朋友们查看opcode,我为Opdumper搭建了一个在线Web服务:http://supercompiler.com/app/opcode_dumper

Web页面访问

只要访问这个页面,在编辑框中输入或粘贴进PHP代码,就可以快速看到相应的opcode:

Snip20120516 5

同时,也可以将结果下载到本地(CSV文件格式)。

HTTP API方式访问

您可以通过访问如下API获取PHP代码的opcode:

URI: http://supercompiler.com/api/dump_opcodes

Method: POST

Params: php_script=[您的PHP代码]

返回值为JSON格式,成功时success字段为”true”,data字段存储opcodes;失败时success字段为”false”,msg字段存放失败原因。

由于跨越的关系,目前只能使用Curl而不能使用Ajax方式调用这个API,后续会为其增加JSONP接口。

结语

目前这个模块还比较初级,有很多需要完善的地方。也欢迎有兴趣的朋友通过github贡献代码。

原文链接:http://www.codinglabs.org/html/opdumper-and-web-opcode-dumper.html

【编辑推荐】

  1. 简化PHP开发的10个工具
  2. PHP经常容易记乱的知识
  3. 提高PHP代码质量36计
  4. 十个超级有用的PHP代码片段
  5. 看PHP如何实现多关键字加亮
责任编辑:张伟 来源: 青藤园
相关推荐

2010-02-04 13:19:41

Linux Nginx

2009-10-16 09:42:06

2010-05-31 15:57:36

Cacti使用手册

2012-09-19 09:47:58

PHPWeb服务器

2009-12-08 13:18:17

2009-11-18 11:10:16

PHP WEB服务器

2010-05-13 18:32:52

2015-04-23 13:29:02

Flume分布式服务HDFS

2015-04-20 10:06:37

PHP Rust 创建PHP 扩展

2010-12-15 15:19:24

2012-07-16 09:33:04

2012-06-13 00:00:00

云计算NoSQLPHP

2009-12-25 15:02:01

php扩展cURL

2010-02-22 15:33:23

Python扩展模块

2010-05-17 11:03:56

2014-05-19 15:59:35

2010-11-19 12:53:53

梭子鱼负载均衡

2011-01-10 09:32:39

2009-11-27 10:32:35

2009-12-04 15:43:03

PHP JSON扩展
点赞
收藏

51CTO技术栈公众号