久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

PHP偽協(xié)議基本原理介紹

瀏覽:102日期:2022-06-05 18:16:13
目錄
  • 前言
  • 常見(jiàn)的php偽協(xié)議
    • php://input
    • php://filter
    • zip://與bzip2://與zlib://協(xié)議
    • data://
    • phar://

前言

引用一張比較清晰易懂的圖

php偽協(xié)議是php自己支持的一種協(xié)議與封裝協(xié)議,簡(jiǎn)單來(lái)說(shuō)就是php定義的一種特殊訪問(wèn)資源的方法。

常見(jiàn)的php偽協(xié)議

php://input

php://input 是個(gè)可以訪問(wèn)請(qǐng)求的原始數(shù)據(jù)的只讀流,獲取POST請(qǐng)求數(shù)據(jù)的協(xié)議

當(dāng)enctype=”multipart/form-data” 的時(shí)候 php://input 是無(wú)效的。

要使php://input 成功使用還需要配置php.ini 中的 allow_url_include設(shè)置為On

案例代碼

php<?php@include($_GET["file"]);?>

構(gòu)造執(zhí)行的代碼,輸出結(jié)果

php://filter

php://filter 是一種元封裝器, 設(shè)計(jì)用于數(shù)據(jù)流打開(kāi)時(shí)的篩選過(guò)濾應(yīng)用。 這對(duì)于一體式(all-in-one)的文件函數(shù)非常有用,類似 readfile()、 file() 和 file_get_contents(), 在數(shù)據(jù)流內(nèi)容讀取之前沒(méi)有機(jī)會(huì)應(yīng)用其他過(guò)濾器。

在利用上很多都是與包含函數(shù)結(jié)合使用,讀入或者輸出獲取文件源碼然后編碼讓其不執(zhí)行從而輸出

php://filter 的使用:如
php://filter/read=convert.base64-encode/resource=index.php
php://filter/resource=index.php

php://filter 偽協(xié)議組成:
read=<讀鏈的篩選列表>
resource=<要過(guò)濾的數(shù)據(jù)流>
write=<寫鏈的篩選列表>

php://filter/read=處理方式(base64編碼,rot13等等)/resource=要讀取的文件

read 對(duì)應(yīng)要設(shè)置的過(guò)濾器:
常見(jiàn)的過(guò)濾器分字符串過(guò)濾器、轉(zhuǎn)換過(guò)濾器、壓縮過(guò)濾器、加密過(guò)濾器
其中convert.base64-encode ,convert.base64-decode都屬于 轉(zhuǎn)換過(guò)濾器

<?php$a=($_GET["file"]);echo(file_get_contents($a));//獲取文件內(nèi)容?>

訪問(wèn)輸出base64編碼后的內(nèi)容

zip://與bzip2://與zlib://協(xié)議

zip:// 等屬于壓縮流的協(xié)議,通過(guò)直接壓縮普通文件為zip文件,再通過(guò)zip:// 協(xié)議讀取,可以直接執(zhí)行php代碼。壓縮后的zip文件可以隨意修改后綴也不影響zip://協(xié)議讀取。(注意是如phpinfo.txt直接壓縮為zip,而不是文件夾壓縮zip)

例:

<?php$a=($_GET["file"]);include($a);?>

壓縮及協(xié)議訪問(wèn)格式:

壓縮文件為.zip后綴
zip://絕對(duì)路徑/phpinfo.zip%23phpinfo.php
壓縮文件為.bz2后綴
compress.bzip2://絕對(duì)路徑/phpinfo.zip/phpinfo.php
壓縮文件為.gz后綴
compress.zlib://絕對(duì)路徑/phpinfo.zip/phpinfo.php

zip://訪問(wèn)

data://

data://協(xié)議與php://input 有很點(diǎn)相似的地方。他們都可以通過(guò)請(qǐng)求提交的php代碼數(shù)據(jù)配合文件包含函數(shù)可以達(dá)到代碼執(zhí)行效果,data:// 的成功執(zhí)行需要php.ini設(shè)置allow_url_include 與allow_url_open都為On。

data://協(xié)議的格式是: data://數(shù)據(jù)流封裝器,相應(yīng)格式數(shù)據(jù)

常見(jiàn)的用法為
data://,<?php%20phpinfo();?>
data://text/plain,<?php%20phpinfo();?>
data://text/plain;base64,PD9waHAgcGhwaW5mbygpOz8%2b

例:

<?php$a=($_GET["file"]);include($a);?>

構(gòu)造data:// 訪問(wèn)

phar://

phar://偽協(xié)議在前面phar反序列化的時(shí)候?qū)W習(xí)過(guò),phar也可以對(duì)zip格式壓縮包進(jìn)行訪問(wèn)解析。

格式為:phar://絕對(duì)路徑\phpinfo.zip\phpinfo.php

到此這篇關(guān)于PHP偽協(xié)議基本原理介紹的文章就介紹到這了,更多相關(guān)PHP偽協(xié)議內(nèi)容請(qǐng)搜索以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持!

標(biāo)簽: PHP
主站蜘蛛池模板: 91国偷自产一区二区三区亲奶 | 久久男人 | 国产色在线 | 久久精品国产免费 | 午夜在线| 在线国产一区二区 | 精品久久久久久久久久久久久 | 午夜网址| 久久久99精品免费观看 | 国产精品99视频 | 久久久国产精品入口麻豆 | 久久午夜影院 | 日韩精品www | 免费一区二区三区 | 久久精品国产91精品亚洲高清 | 99热精品在线| 啪啪免费网站 | 一区二区三区国产 | 亚洲一区在线视频 | 久久久久综合狠狠综合日本高清 | 国产精品毛片一区二区在线看 | 九九九九九九精品任你躁 | 欧美成人精品在线 | 免费看的毛片 | 国产精品久久久久久久久久久小说 | 日韩一区二区成人 | 不卡欧美| 男人久久天堂 | 美女超碰 | 又黄又爽的网站 | 日韩一级二级三级 | 岛国伊人 | av中文在线 | 欧美性猛片aaaaaaa做受 | 中文字幕日韩久久 | 亚洲在线播放 | 日批免费在线观看 | 欧美在线观看免费观看视频 | 中文字幕91 | 亚洲国产精品一区二区第一页 | 欧美一区二区视频 |