{"id":190,"date":"2016-08-09T18:06:46","date_gmt":"2016-08-09T10:06:46","guid":{"rendered":"http:\/\/www.shenmdyw.com\/?p=190"},"modified":"2016-10-18T17:40:07","modified_gmt":"2016-10-18T09:40:07","slug":"%e4%bd%bf%e7%94%a8c%e8%af%ad%e8%a8%80%e6%9d%a5%e6%89%a9%e5%b1%95php%ef%bc%8c%e5%86%99php%e6%89%a9%e5%b1%95dll","status":"publish","type":"post","link":"http:\/\/www.shenmdyw.com\/index.php\/2016\/08\/09\/%e4%bd%bf%e7%94%a8c%e8%af%ad%e8%a8%80%e6%9d%a5%e6%89%a9%e5%b1%95php%ef%bc%8c%e5%86%99php%e6%89%a9%e5%b1%95dll\/","title":{"rendered":"\u4f7f\u7528C\u8bed\u8a00\u6765\u6269\u5c55PHP\uff0c\u5199PHP\u6269\u5c55dll"},"content":{"rendered":"<p>\u4ee5\u524d\u5199\u8fc7\u4e00\u6b21PHP\u6269\u5c55DLL\uff0c\u90a3\u4e2a\u662f\u5229\u7528\u8c03\u7528\u7cfb\u7edf\u7684COM\u53e3\u5b9e\u73b0\u7684\u6269\u5c55\uff0c\u4e0ePHP\u4e0d\u80fd\u771f\u6b63\u878d\u5408\u3002\u5fc3\u8840\u6765\u6f6e\uff0c\u7814\u7a76\u4e86\u4e00\u4e0bPHP\u7684\u6e90\u7801\uff0c\u7f51\u4e0a\u627e\u4e86\u4e00\u4e9b\u8d44\u6599\uff0c\u81ea\u5df1\u5c1d\u8bd5\u5199\u4e86\u4e00\u4e2a\u6269\u5c55DLL\uff0c\u6d4b\u8bd5\u6ca1\u95ee\u9898\u3002\u4e0b\u9762\u8bb0\u5f55\u4e00\u4e0b\u5177\u4f53\u6269\u5c55\u65b9\u6cd5\uff1a<\/p>\n<p>1\u3001\u9996\u5148\u4ecewww.php.net\u7f51\u7ad9\u4e0a\u4e0b\u8f7dphp\u6e90\u7801\uff0c\u6b64\u5904\u4ee5php-5.2.17\u7248\u672c\u4e3a\u4f8b\uff0c\u4e0b\u8f7d\u540e\u89e3\u538b\u81f3E\uff1a\u76d8\u6839\u76ee\u5f55\u4e0b\uff08\u76ee\u5f55\u53ef\u4ee5\u81ea\u5df1\u968f\u610f\u5b9a\uff09\u3002<\/p>\n<p>2\u3001\u4e0b\u8f7d\u5b89\u88c5VC++ 6.0\uff0c\u56e0\u4e3aPHP\u6e90\u7801\u662f\u5229\u75286.0\u7248\u672c\u5199\u7684\uff0c\u6240\u4ee5\u4f7f\u7528\u8fd9\u4e2a\u7248\u672c\u7f16\u8bd1\u4e0d\u4f1a\u51fa\u73b0\u610f\u5916\uff0c\u522b\u7684\u7248\u672c\u672a\u6d4b\u8bd5\u3002<\/p>\n<p>3\u3001\u628aVC++ 6.0\u5b89\u88c5\u76ee\u5f55\u4e2d\u7684\u00a0Microsoft Visual Studio\\Common\\MSDev98\\Bin \u7edd\u5bf9\u8def\u5f84\u6dfb\u52a0\u5230\u7cfb\u7edf\u73af\u5883\u53d8\u91cf\u4e2d\u3002<\/p>\n<p>4\u3001\u8fdb\u5165E\uff1a\\php-5.2.17\\ext\u76ee\u5f55\uff0c\u590d\u5236skeleton\u6587\u4ef6\u5939\uff0c\u5e76\u91cd\u547d\u540d\u4e3a\u8981\u5f00\u53d1\u6269\u5c55\u7684\u540d\u5b57\uff0c\u672c\u4f8b\u4e3a\u201cmyfun\u201d\u3002<\/p>\n<p>5\u3001\u91cd\u547d\u540dskeleton.c\u4e3amyfun.c\uff0cskeleton.dsp\u4e3amyfun.dsp<\/p>\n<p>6\u3001\u7f16\u8f91myfun\u76ee\u5f55\u4e2d\u7684php_skeleton.h\u3001myfun.c\u3001myfun.dsp\u8fd9\u4e09\u4e2a\u6587\u4ef6\uff0c\u66ff\u6362\u5185\u5bb9\u4e2d\u6240\u6709extname\u4e3amyfun\uff0cEXTNAME\u4e3aMYFUN\u3002\uff08\u4e00\u5b9a\u8981\u4e25\u683c\u533a\u5206\u5927\u5c0f\u5199\uff09<\/p>\n<p><!--more--><\/p>\n<p>\u4e0b\u9762\u5c31\u8fdb\u5165\u5230\u7f16\u7801\u9636\u6bb5\uff1a<\/p>\n<p>7\u3001\u6253\u5f00php_skeleton.h\u6587\u4ef6\uff08\u5934\u6587\u4ef6\uff09\uff0c\u627e\u5230PHP_FUNCTION(confirm_myfun_compiled);\uff0c\u5728 PHP_FUNCTION(confirm_myfun_compiled);\uff0c\u4e0b\u9762\u7f16\u5199PHP_FUNCTION(mb_MessageBox);\uff0c\u58f0 \u660e\u4e00\u4e2amb_MessageBox\u51fd\u6570\uff0c\u6b64\u51fd\u6570\u7684\u4f5c\u7528\u4ec5\u662f\u8f93\u51fajs\u5f39\u51fa\u4e00\u4e2aalert\u6d88\u606f\u6846\uff0c\u7528\u4e8e\u6d4b\u8bd5\u3002<\/p>\n<p>8\u3001\u4e0b\u9762\u5b9a\u4e49\u51fd\u6570\u5165\u53e3\uff0c\u6253\u5f00myfun.c\u6587\u4ef6\uff0c\u627e\u5230PHP_FE(confirm_myfun_compiled,NULL) ;,\u5728\u4e0b\u9762\u7f16\u5199 PHP_FE(mb_MessageBox,NULL),\u6b64\u5904\u6ce8\u610f\u4e00\u4e0b\uff0cPHP_FE\u662f\u5b9a\u4e49\u7684\u4e00\u4e2a\u5b8f\uff0c\u6240\u4ee5\u540e\u9762\u4e0d\u7528\u52a0\u5f15\u53f7\u3002<\/p>\n<p>9\u3001\u5728myfun.c\u6700\u540e\u9762\u7f16\u5199\u51fd\u6570\u7684\u5b9e\u4f53\u90e8\u5206\uff1a<\/p>\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"c\">\u00a0PHP_FUNCTION(mb_MessageBox)\r\n{\r\n\u00a0\u00a0\u00a0\u00a0char\u00a0*arg\u00a0=\u00a0NULL;\r\n\u00a0\u00a0\u00a0\u00a0int\u00a0arg_len,\u00a0len;\r\n\u00a0\u00a0\u00a0\u00a0char\u00a0*strg;\r\n\r\n\u00a0\u00a0\u00a0\u00a0if\u00a0(zend_parse_parameters(ZEND_NUM_ARGS()\u00a0TSRMLS_CC,\u00a0\"s\",\u00a0&amp;arg,\u00a0&amp;arg_len)\u00a0==\u00a0FAILURE)\u00a0{\r\n\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0return;\r\n\u00a0\u00a0\u00a0\u00a0}\r\n\r\n\u00a0\u00a0\u00a0\u00a0len\u00a0=\u00a0spprintf(&amp;strg,\u00a00,\u00a0\"&lt;script&gt;alert('%s')&lt;\/script&gt;\",arg);\u00a0\/\/\u6b64\u5904\u6b63\u662f\u8f93\u5165\u7684js\u4ee3\u7801\r\n\u00a0\u00a0\u00a0\u00a0RETURN_STRINGL(strg,\u00a0len,\u00a00);\r\n}<\/pre>\n<p>\u5230\u8fd9\u4ee3\u7801\u4e66\u5199\u5c31\u5b8c\u6210\u4e86\uff0c\u4e0b\u9762\u5f00\u59cb\u7f16\u8bd1:<\/p>\n<p>10\u3001\u5f00\u59cb-&gt;\u8fd0\u884c\uff0c\u8f93\u5165CMD\uff0c\u6253\u5f00\u547d\u4ee4\u884c\u7a97\u53e3\u3002<\/p>\n<p>11\u3001\u8fdb\u5165myfun\u7684\u76ee\u5f55\uff0c\u8f93\u5165 msdev myfun.dsp \/MAKE &#8220;myfun &#8211; Win32 Release_TS&#8221;\uff0c\u56de\u8f66\u7f16\u8bd1\u3002<\/p>\n<p>12\u3001\u5982\u679c\u6ca1\u6709\u9519\u8bef\uff0c\u5728E:\\php-5.2.17\u4e0b\u4f1a\u751f\u6210\u4e00\u4e2aRelease_TS\u6587\u4ef6\u5939\uff0c\u5728\u91cc\u9762\u5c31\u53ef\u4ee5\u627e\u5230php_myfun.dll\u6587\u4ef6\u3002<\/p>\n<p>\u81f3\u6b64\u6269\u5c55dll\u5f00\u53d1\u5b8c\u6210\uff0c\u4e0b\u9762\u5728php\u4e2d\u8fdb\u884c\u6d4b\u8bd5\uff1a<\/p>\n<p>13\u3001\u628aphp_myfun.dll\u590d\u5236\u5230\u539fphp\u76ee\u5f55\u4e2d\u7684ext\u6587\u4ef6\u5939\u5185\u3002<\/p>\n<p>14\u3001\u6253\u5f00php.ini\u6587\u4ef6\uff0c\u6dfb\u52a0\u5f53\u524ddll\u7684\u6269\u5c55 extension=php_myfun.dll<\/p>\n<p>15\u3001\u91cd\u542fIIS\u6216apache\uff0c\u5728\u7f51\u7ad9\u76ee\u5f55\u4e0b\u65b0\u5efa\u4e00\u6587\u4ef6\uff0c\u8f93\u5165\u4ee5\u4e0b\u5185\u5bb9\uff1a<\/p>\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"php\">\u00a0&lt;?php\r\necho mb_MessageBox(\"\u6d4b\u8bd5PHP\u6269\u5c55DLL by 123123\");\r\n?&gt;<\/pre>\n<p>\u6d4f\u89c8\u5373\u53ef\u770b\u5230\u6548\u679c\uff0c\u4e0b\u9762\u9644\u56fe\u56db\u5f20\uff1a<br \/>\n\u6dfb\u52a0\u6269\u5c55\uff1a<img loading=\"lazy\" decoding=\"async\" class=\"alignnone size-medium wp-image-192\" src=\"http:\/\/www.shenmdyw.com\/wp-content\/uploads\/2016\/08\/2011112818340045.jpg\" alt=\"2011112818340045\" width=\"248\" height=\"61\" \/><\/p>\n<p>php\u4ee3\u7801\uff1a<img loading=\"lazy\" decoding=\"async\" class=\"alignnone size-medium wp-image-193\" src=\"http:\/\/www.shenmdyw.com\/wp-content\/uploads\/2016\/08\/2011112818344035-300x85.jpg\" alt=\"2011112818344035\" width=\"300\" height=\"85\" srcset=\"http:\/\/www.shenmdyw.com\/wp-content\/uploads\/2016\/08\/2011112818344035-300x85.jpg 300w, http:\/\/www.shenmdyw.com\/wp-content\/uploads\/2016\/08\/2011112818344035.jpg 484w\" sizes=\"auto, (max-width: 300px) 100vw, 300px\" \/><\/p>\n<p>\u6700\u7ec8\u6548\u679c\uff1a<img loading=\"lazy\" decoding=\"async\" class=\"alignnone size-full wp-image-191\" src=\"http:\/\/www.shenmdyw.com\/wp-content\/uploads\/2016\/08\/2011112818345914.jpg\" alt=\"2011112818345914\" width=\"248\" height=\"175\" \/><\/p>\n<p>\u8f6c\u81eahttp:\/\/www.cnblogs.com\/myths\/archive\/2011\/11\/28\/2266593.html<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u4ee5\u524d\u5199\u8fc7\u4e00\u6b21PHP\u6269\u5c55DLL\uff0c\u90a3\u4e2a\u662f\u5229\u7528\u8c03\u7528\u7cfb\u7edf\u7684COM\u53e3\u5b9e\u73b0\u7684\u6269\u5c55\uff0c\u4e0ePHP\u4e0d\u80fd\u771f\u6b63\u878d\u5408\u3002\u5fc3\u8840\u6765\u6f6e\uff0c\u7814\u7a76\u4e86\u4e00 [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[93,94],"class_list":["post-190","post","type-post","status-publish","format-standard","hentry","category-php","tag-cphp","tag-phpdll","clear"],"_links":{"self":[{"href":"http:\/\/www.shenmdyw.com\/index.php\/wp-json\/wp\/v2\/posts\/190","targetHints":{"allow":["GET"]}}],"collection":[{"href":"http:\/\/www.shenmdyw.com\/index.php\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"http:\/\/www.shenmdyw.com\/index.php\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"http:\/\/www.shenmdyw.com\/index.php\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"http:\/\/www.shenmdyw.com\/index.php\/wp-json\/wp\/v2\/comments?post=190"}],"version-history":[{"count":6,"href":"http:\/\/www.shenmdyw.com\/index.php\/wp-json\/wp\/v2\/posts\/190\/revisions"}],"predecessor-version":[{"id":243,"href":"http:\/\/www.shenmdyw.com\/index.php\/wp-json\/wp\/v2\/posts\/190\/revisions\/243"}],"wp:attachment":[{"href":"http:\/\/www.shenmdyw.com\/index.php\/wp-json\/wp\/v2\/media?parent=190"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"http:\/\/www.shenmdyw.com\/index.php\/wp-json\/wp\/v2\/categories?post=190"},{"taxonomy":"post_tag","embeddable":true,"href":"http:\/\/www.shenmdyw.com\/index.php\/wp-json\/wp\/v2\/tags?post=190"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}