2023-06-25 07:22:07 來源 : 博客園
主要是對上一篇文章中php_again
這道題的補充。
(資料圖)
cd /usr/localwget https://www.php.net/distributions/php-8.2.2.tar.gztar -zxvf php-8.2.2.tar.gz && cd php-8.2.2
0x03編譯注意帶enable-debug
apt-get install build-essential autoconf automake libtool libsqlite3-dev pkg-config libjpeg-dev libpng-dev libxml2-dev libbz2-dev libcurl4-gnutls-dev libssl-dev libffi-dev libwebp-dev libonig-dev libzip-dev./configure --prefix=/usr/local/php --sysconfdir=/etc/php/8.2 --with-openssl --with-zlib --with-bz2 --with-curl --enable-bcmath --enable-gd --with-webp --with-jpeg --with-mhash --enable-mbstring --with-imap-ssl --with-mysqli --enable-exif --with-ffi --with-zip --enable-sockets --with-pcre-jit --enable-fpm --with-pdo-mysql --enable-pcntl --enable-debugmake && make installcd /usr/binln -s /usr/local/php/bin/php php8.2cp /usr/local/php-8.2.2/php.ini-development /usr/local/php/lib/php.ini cp /etc/php/8.2/php-fpm.conf.default /etc/php/8.2/php-fpm.confcp /etc/php/8.2/php-fpm.d/www.conf.default /etc/php/8.2/php-fpm.d/www.conf
0x04下載gdb工具apt-get updateapt install gdb
0x05調試樣例調試php中 生成 system_id的兩個函數(zend_startup_system_id,zend_finalize_system_id),分別在 mian.c文件的第2237行
和第2288
行
cd /usr/local/php/bin#即php可執(zhí)行文件目錄
先在這兩處打斷點
接下來執(zhí)行 run 一個php文件。
step 單步進入該函數。
n下一步
print var 打印變量
該函數運行完后,context
的值是。(因為enable-debug了,所以NTS后還有一個debug,正常情況下是沒有的)
跳出該函數后,輸入 c
進入下一個斷點。
同樣 step單步跳入。可以看到第二個 if語句是進去了,hooks的值為 "\x02"
接下來是個 for循環(huán),一個都沒進去,所以 context
的值沒有更新。最后 context
的值是。
把 debug去掉放 python跑一下。
這下跑的結果是正確的。
0x06一些細節(jié)zend_compile_file
和 compile_file
是不一樣的。讓我們看看發(fā)生了什么。
watch zend_compile_file
編譯時開啟 dtrace
并且,環(huán)境變量中有 USE_ZEND_DTRACE
時才會進入這個if 。 所以這個時候 zend_compile_file
是等于 compile_file
的。
在phar.c中還會改變一次。之后就會調用 zend_finalize_system_id
.
額,源碼看不懂,就跟著看了下變量信息,主要簡單了解下如何使用gdb調試。