php偽協議

PHP 偽協議(PHP Stream Wrapper)

PHP 的偽協議(Protocol Wrapper)是一種機制,允許開發者通過統一的文件訪問函數(如 file_get_contentsfopeninclude 等)訪問不同類型的數據源,包括本地文件、遠程資源、內存數據、壓縮包等。


原理說明

PHP 偽協議本質上是對路徑的一種特殊格式擴展,它將以特定協議開頭的路徑重定向到不同的數據處理器。例如:

file_get_contents("php://input");

上述代碼讀取的不是文件,而是 HTTP 請求體的原始內容。


常見偽協議分類及功能

偽協議功能說明
file://默認本地文件訪問,可省略 file:// 前綴
php://filter對文件內容進行過濾,如編碼轉換(如 base64)
php://input讀取原始 POST 請求體數據
php://memory / php://temp使用內存/臨時文件作為讀寫流
data://讀取內聯數據,適用于直接包含字符串內容
zip://訪問 zip 壓縮包中的文件
phar://訪問 Phar 存檔文件內容
glob://使用通配符進行文件匹配
http:// / https://遠程網頁數據讀取(依賴 allow_url_fopen
ftp://讀取遠程 FTP 文件
expect://執行 shell 命令(高危,默認禁用)

常見利用場景及用法

1. php://filter 讀取源碼(常用于 CTF)

讀取 PHP 文件并進行 base64 編碼:

file_get_contents("php://filter/convert.base64-encode/resource=index.php");

可用于源碼查看或繞過 Web 服務對 .php 文件的訪問限制。


2. php://input 讀取原始 POST 數據

$raw = file_get_contents("php://input");

適用于接收非標準 Content-Type 的 POST 數據,比如上傳 Webshell 繞過限制。


3. data:// 內聯數據作為代碼包含

include("data://text/plain,<?php phpinfo(); ?>");

可以直接把一段字符串當作 PHP 文件執行,常用于代碼注入場景。


4. zip:// 讀取壓縮包內的文件

file_get_contents("zip://shell.zip#shell.php");

配合文件上傳漏洞使用,將 PHP 文件嵌入 zip 包中,繞過后綴檢測。


5. phar:// 配合反序列化漏洞使用

include("phar://shell.jpg");

Phar 文件在被解析時會自動觸發反序列化邏輯,可用于 POP 鏈觸發。


安全風險

PHP 偽協議可被濫用,尤其是在存在以下漏洞時:

  • 本地文件包含(LFI)

  • 遠程文件包含(RFI)

  • 反序列化(Phar 利用)

  • 文件上傳(zip 包繞過)

  • 任意文件讀取(結合 filter)

攻擊者可以利用偽協議讀取敏感信息、執行任意代碼、泄露源碼等。


示例:利用 LFI + php://filter 獲取源碼

<?php
include($_GET['file']);

訪問:

?file=php://filter/convert.base64-encode/resource=flag.php

結果為 flag.php 文件的 base64 編碼內容。


總結表

類型示例功能說明
本地文件file://index.php常規文件讀寫
網絡訪問http://example.com獲取遠程網頁數據
輸入流php://input獲取原始 POST 數據
編碼過濾php://filter/convert.base64-encode/resource=index.php獲取源碼并 base64 編碼輸出
內聯數據data://text/plain,<?php phpinfo(); ?>執行/包含內嵌內容
壓縮包zip://shell.zip#shell.php訪問 zip 包中的 PHP 文件
Phar 文件phar://shell.jpg使用 Phar 進行反序列化利用

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/901129.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/901129.shtml
英文地址,請注明出處:http://en.pswp.cn/news/901129.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

當DRAM邂逅SSD:新型“DRAM+”存儲技術來了!

在當今快速發展的科技領域&#xff0c;數據存儲的需求日益增長&#xff0c;對存儲設備的性能和可靠性提出了更高的要求。傳統DRAM以其高速度著稱&#xff0c;但其易失性限制了應用范圍&#xff1b;而固態硬盤SSD雖然提供非易失性存儲&#xff0c;但在速度上遠不及DRAM。 為了解…

org.apache.spark.SparkException: Kryo serialization failed: Buffer overflow...

Spark異常&#xff1a;Kryo serialization failed: Buffer overflow. 1、問題描述 SparkSQL任務報錯如下&#xff1a; org.apache.spark.SparkException: Kryo serialization failed: Buffer overflow. Available: 0, required: xxx. To avoid this, increase spark.kryoseri…

編譯原理 實驗二 詞法分析程序自動生成工具實驗

文章目錄 實驗環境的準備實驗實驗預備知識分析案例所要做的任務實戰 實驗環境的準備 安裝flex 安裝MinGW MinGW Installation Manager頁面 apply changes 下載比較耗時 只看到了一個文件&#xff0c;復制過去 配置環境變量 使用gcc -v檢驗是否安裝完成 實驗 實驗預備知識…

BERT - 直接調用transformers.BertModel, BertTokenizerAPI不進行任何微調

本節代碼將使用 transformers 庫加載預訓練的BERT模型和分詞器&#xff08;Tokenizer&#xff09;&#xff0c;并處理文本輸入。 1. 加載預訓練模型和分詞器 from transformers import BertTokenizer, BertModelmodel_path "/Users/azen/Desktop/llm/models/bert-base-…

Python 質數篩選:從入門到優化的 5 種方法

質數&#xff08;Prime Number&#xff09;是指只能被 1 和自身整除的自然數&#xff0c;如 2、3、5、7 等。在算法題、密碼學或數學計算中&#xff0c;高效生成質數至關重要。 Python 提供了多種方法來實現質數篩選&#xff0c;但不同方法的效率差異巨大。本文從 最基礎的方法…

C#MQTT協議服務器與客戶端通訊實現(客戶端包含斷開重連模塊)

C#MQTT協議服務器與客戶端通訊實現 1 DLL版本2 服務器3 客戶端 1 DLL版本 MQTTnet.DLL版本-2.7.5.0 基于比較老的項目中應用的DLL&#xff0c;其他更高版本變化可能較大&#xff0c;謹慎參考。 2 服務器 開啟服務器 關閉服務器 綁定事件【客戶端連接服務器事件】 綁定事件【客戶…

【連載3】基礎智能體的進展與挑戰綜述

基礎智能體的進展與挑戰綜述 從類腦智能到具備可進化性、協作性和安全性的系統 【翻譯團隊】劉軍(liujunbupt.edu.cn) 錢雨欣玥 馮梓哲 李正博 李冠諭 朱宇晗 張霄天 孫大壯 黃若溪 2. 認知 人類認知是一種復雜的信息處理系統&#xff0c;它通過多個專門的神經回路協調運行…

Python語言介紹

Python 是一種高級、通用、解釋型的編程語言&#xff0c;由 Guido van Rossum 于 1991 年首次發布。其設計哲學強調代碼的可讀性和簡潔性。 Python通過簡潔的語法和強大的生態系統&#xff0c;成為當今最受歡迎的編程語言之一。 一、核心特點 Python 是一種解釋型、面向對象、…

什么是回表?哪些數據庫存在回表?

目錄 一、什么是回表1. 回表的核心流程2. 示例說明3. 回表的性能問題4. 總結 二、哪些數據庫會有回表1. MySQL&#xff08;InnoDB&#xff09;2. Oracle3. 其他數據庫&#xff08;如 SQL Server、PostgreSQL&#xff09;4. 總結 三、非聚集索引與聚集索引的區別及產生原因1. 聚…

ssh 免密登錄服務器(vscode +ssh 免密登錄)

每次打開vscode連接服務器都需要輸入密碼&#xff0c;特別繁瑣。 然后自己在網上翻閱了一下教程&#xff0c;發現說的內容比較啰嗦&#xff0c;而且個人感覺非常有誤導性傾向。 因此自己直接干脆寫一個簡便易懂的教程算了。 &#xff08;以經過本人親測&#xff0c;真實可靠&am…

基于低空經濟的無人機操控與維護實訓室解決方案

一、低空經濟時代下的無人機人才需求 1.1 低空經濟發展趨勢與政策機遇 在當前經濟與科技飛速發展的大背景下&#xff0c;低空經濟作為國家戰略性新興產業&#xff0c;正以迅猛之勢崛起&#xff0c;展現出無限的潛力與活力。其應用場景極為廣泛&#xff0c;涵蓋了物流、安防、…

PyTorch實現二維卷積與邊緣檢測:從原理到實戰

本文通過PyTorch實現二維互相關運算、自定義卷積層&#xff0c;并演示如何通過卷積核檢測圖像邊緣。同時&#xff0c;我們將訓練一個卷積核參數&#xff0c;使其能夠從數據中學習邊緣特征。 1. 二維互相關運算的實現 互相關運算&#xff08;Cross-Correlation&#xff09;是卷…

數字政府網絡架構建設方案

數字政府網絡架構建設方案 一、引言 隨著信息技術的快速發展&#xff0c;數字政府建設已成為提升政府治理能力和服務水平的關鍵。網絡架構作為數字政府的核心基礎設施&#xff0c;對于保障數據安全、提高服務效率、促進信息共享具有重要意義。本方案旨在為數字政府網絡架構建…

Python map函數介紹

在 Python 里&#xff0c;map() 是一個內置函數&#xff0c;其用途是將指定的函數應用于可迭代對象&#xff08;像列表、元組等&#xff09;的每個元素&#xff0c;最終返回一個新的迭代器。此迭代器所包含的元素是原可迭代對象中每個元素經過指定函數處理后的結果。map() 函數…

【服務器端表單字符驗證】

文章目錄 一、實驗目的二、核心代碼實現三、調試關鍵問題四、總結 一、實驗目的 掌握JSP表單驗證在服務器端的實現技術&#xff0c;實現對用戶輸入字符的非空及長度為5的驗證&#xff0c;返回對應提示信息并優化用戶交互。 二、核心代碼實現 前端表單 <form action"…

dify windos,linux下載安裝部署,提供百度云盤地址

dify下載安裝 dify1.0.1 windos安裝包百度云盤地址 通過網盤分享的文件&#xff1a;dify-1.0.1.zip 鏈接: 百度網盤 請輸入提取碼 提取碼: 1234 dify安裝包 linux安裝包百度云盤地址 通過網盤分享的文件&#xff1a;dify-1.0.1.tar.gz 鏈接: 百度網盤 請輸入提取碼 提取碼…

C++ Primer 5e 習題2.5: 指出如下字面量常量的類型

Exercise 2.5: Determine the type of each of the following literals. Explain the differences among the literals in each of the four examples: (a) ‘a’, L’a’, “a”, L"a" (b) 10, 10u, 10L, 10uL, 012, 0xC © 3.14, 3.14f, 3.14L (d) 10, 10u, 10…

CFS 調度器兩種調度類型普通調度 和 組調度

在 Linux 的 CFS&#xff08;Completely Fair Scheduler&#xff09; 調度器中&#xff0c;確實存在兩種調度類型&#xff1a;普通調度 和 組調度。這兩種調度類型分別適用于不同的場景&#xff0c;并通過三個關鍵維度&#xff08;權重、搶占優先級、最大配額&#xff09;來影響…

AF3 ProteinDataset類的_get_masked_sequence方法解讀

AlphaFold3 protein_dataset模塊 ProteinDataset 類 _get_masked_sequence 方法屬于作用是為需要預測的殘基生成掩碼。該掩碼以二進制張量形式呈現,其中 1 代表需要預測的部分,0 代表其他部分。此方法會依據多個參數來選定要掩碼的殘基,這些參數包含 mask_whole_chains、mas…

【音視頻】SDL渲染YUV格式像素

SDL視頻顯示的流程 實現流程 準備視頻文件 準備一個格式為yuv420p&#xff0c;分辨率為320x240的yuv數據&#xff0c;并且將視頻文件放入項目構建的目錄下&#xff1a; 初始化SDL 初始化SDL的視頻模塊 //初始化 SDL if(SDL_Init(SDL_INIT_VIDEO)) {fprintf( stderr, "…