php使用pack处理二进制文件的方法_PHP教程
php读写二进制文件可以使用pack和unpack函数。
今天要处理一个二进制文件的问题,所以需要用一下,特意了解一下pack的用法,unpack用法与此类似。
简单来说,pack函数就是给一个目标格式,和相应的参数,就可以返回二进制数据了。
下面举例加以说明,对于四个整数:
pack("L4", 0,1,2,3) pack("LLLL", 0,1,2,3) pack("L", 0).pack("L", 1).pack("L", 2).pack("L", 3)
上面的处理结果是一样的,也就是说,format是描述后面的数据的格式。
至于具体format可以用什么,看看format characters就知道了。
比如一个30字符的 pack("a30", "http://www.jb51.net") ,就是这个意思,很简单
pack函数的官方声明如下:
引用 pack (PHP 3, PHP 4, PHP 5) pack -- Pack data into binary string Description string pack ( string format [, mixed args [, mixed ...]] ) Pack given arguments into binary string according to format. Returns binary string containing data. The idea to this function was taken from Perl and all formatting codes work the same as there, however, there are some formatting codes that are missing such as Perl's "u" format code. The format string consists of format codes followed by an optional repeater argument. The repeater argument can be either an integer value or * for repeating to the end of the input data. For a, A, h, H the repeat count specifies how many characters of one data argument are taken, for @ it is the absolute position where to put the next data, for everything else the repeat count specifies how many data arguments are consumed and packed into the resulting binary string. Currently implemented are 表格 1. pack() format characters Code Description a NUL-padded string A SPACE-padded string h Hex string, low nibble first H Hex string, high nibble first c signed char C unsigned char s signed short (always 16 bit, machine byte order) S unsigned short (always 16 bit, machine byte order) n unsigned short (always 16 bit, big endian byte order) v unsigned short (always 16 bit, little endian byte order) i signed integer (machine dependent size and byte order) I unsigned integer (machine dependent size and byte order) l signed long (always 32 bit, machine byte order) L unsigned long (always 32 bit, machine byte order) N unsigned long (always 32 bit, big endian byte order) V unsigned long (always 32 bit, little endian byte order) f float (machine dependent size and representation) d double (machine dependent size and representation) x NUL byte X Back up one byte @ NUL-fill to absolute position
看累了英文,下面来看看对应的中文解释:
引用 pack()函数的作用是:将数据压缩成一个二进制字符串。 a - NUL-padded string a - NUL- 字符串填满[padded string] A - SPACE-padded string A - SPACE- 字符串填满[padded string] h - Hex string, low nibble first h – 十六进制字符串,低“四位元”[low nibble first] H - Hex string, high nibble first H - 十六进制字符串,高“四位元”[high nibble first] c - signed char c – 带有符号的字符 C - unsigned char C – 不带有符号的字符 s - signed short (always 16 bit, machine byte order) s – 带有符号的短模式[short](通常是16位,按机器字节顺序) S - unsigned short (always 16 bit, machine byte order) S – 不带有符号的短模式[short](通常是16位,按机器字节排序) n - unsigned short (always 16 bit, big endian byte order) n -不带有符号的短模式[short](通常是16位,按大endian字节排序) v - unsigned short (always 16 bit, little endian byte order) v -不带有符号的短模式[short](通常是16位,按小endian字节排序) i - signed integer (machine dependent size and byte order) i – 带有符号的整数(由大小和字节顺序决定) I - unsigned integer (machine dependent size and byte order) I – 不带有符号的整数(由大小和字节顺序决定) l - signed long (always 32 bit, machine byte order) l– 带有符号的长模式[long](通常是32位,按机器字节顺序) L - unsigned long (always 32 bit, machine byte order) L – 不带有符号的长模式[long](通常是32位,按机器字节顺序) N - unsigned long (always 32 bit, big endian byte order) N – 不带有符号的长模式[long](通常是32位,按大edian字节顺序) V - unsigned long (always 32 bit, little endian byte order) V– 不带有符号的长模式[long](通常是32位,按小edian字节顺序) f - float (machine dependent size and representation) f –浮点(由大小和字节顺序决定) d - double (machine dependent size and representation) d – 双精度(由大小和字节顺序决定) x - NUL byte x – 空字节[NUL byte] X - Back up one byte X- 后面一个字节[Back up one byte] @ - NUL-fill to absolute position @ - NUL- 添加到一个绝对位置[absolute position]
示例代码如下:
<?php $code=array( "username"=>array("A7","张三adfb12"), "pass"=>array("A10","asdf*#1"), "age"=>array("C","23"), "birthday"=>array("I","19900101"), "email"=>array("A50","www.jb51.net")); $stream=join("\0",parkByArr($code)); echo $stream,strlen($stream); file_put_contents("1.txt",$stream);//将流保存起来便于下面读取 function parkByArr($arr) { $atArr=array(); foreach ($arr as $k=>$v) { $atArr[]=pack($v[0],$v[1]); } return $atArr; } function getAscill($str) { $arr=str_split($str); foreach ($arr as $v) { echo $v,"=",ord($v),"\n"; } } $code=array( "username"=>array("A20"), "pass"=>array("A10"), "age"=>array("C"), "birthday"=>array("I"), "email"=>array("A50")); $stream=file_get_contents("1.txt"); var_dump(parkByArr($stream,$code)); function parkByArr($str,$code) { $Arr=explode("\0",$str); $atArr=array(); $i=0; foreach ($code as $k=>$v) { $atArr[$k]=unpack($v[0],$Arr[$i]); $i++; } return $atArr; }

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

PHP 8.4 帶來了多項新功能、安全性改進和效能改進,同時棄用和刪除了大量功能。 本指南介紹如何在 Ubuntu、Debian 或其衍生版本上安裝 PHP 8.4 或升級到 PHP 8.4

CakePHP 是 PHP 的開源框架。它旨在使應用程式的開發、部署和維護變得更加容易。 CakePHP 基於類似 MVC 的架構,功能強大且易於掌握。模型、視圖和控制器 gu

Visual Studio Code,也稱為 VS Code,是一個免費的原始碼編輯器 - 或整合開發環境 (IDE) - 可用於所有主要作業系統。 VS Code 擁有大量針對多種程式語言的擴展,可以輕鬆編寫

CakePHP 是一個開源MVC 框架。它使應用程式的開發、部署和維護變得更加容易。 CakePHP 有許多函式庫可以減少大多數常見任務的過載。

本教程演示瞭如何使用PHP有效地處理XML文檔。 XML(可擴展的標記語言)是一種用於人類可讀性和機器解析的多功能文本標記語言。它通常用於數據存儲

JWT是一種基於JSON的開放標準,用於在各方之間安全地傳輸信息,主要用於身份驗證和信息交換。 1.JWT由Header、Payload和Signature三部分組成。 2.JWT的工作原理包括生成JWT、驗證JWT和解析Payload三個步驟。 3.在PHP中使用JWT進行身份驗證時,可以生成和驗證JWT,並在高級用法中包含用戶角色和權限信息。 4.常見錯誤包括簽名驗證失敗、令牌過期和Payload過大,調試技巧包括使用調試工具和日誌記錄。 5.性能優化和最佳實踐包括使用合適的簽名算法、合理設置有效期、

字符串是由字符組成的序列,包括字母、數字和符號。本教程將學習如何使用不同的方法在PHP中計算給定字符串中元音的數量。英語中的元音是a、e、i、o、u,它們可以是大寫或小寫。 什麼是元音? 元音是代表特定語音的字母字符。英語中共有五個元音,包括大寫和小寫: a, e, i, o, u 示例 1 輸入:字符串 = "Tutorialspoint" 輸出:6 解釋 字符串 "Tutorialspoint" 中的元音是 u、o、i、a、o、i。總共有 6 個元
