当前位置:  编程技术>php

php使用pack处理二进制文件的方法

    来源: 互联网  发布时间:2014-08-26

    本文导语:  php读写二进制文件可以使用pack和unpack函数。 今天要处理一个二进制文件的问题,所以需要用一下,特意了解一下pack的用法,unpack用法与此类似。 简单来说,pack函数就是给一个目标格式,和相应的参数,就可以返回二进制数...

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.") ,就是这个意思,很简单

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通过pack和unpack函数实现对二进制数据封装及解析
  • php实现十进制转二进制
  • PHP接收二进制流并生成文件(实例)
  • PHP取二进制文件头判断文件类型
  • php实现与erlang的二进制通讯实例解析
  • 二进制交叉权限微型php类分享
  • PHP严重致命错误处理:php Fatal error: Cannot redeclare class or function
  • PHP图像处理库 ImageWorkshop
  • PHP图像处理库 Imagine
  • php 下载文件名带空格怎么处理
  • PHP支付处理库 Omnipay
  • PHP的Zip压缩包处理类 TbsZip
  • PHP图像处理模块 MagickWand
  • PHP图像处理库 Zebra_Image
  • windows下配置apache+php+mysql时出现问题的处理方法
  • PHP配置文件处理类代码
  • nginx:413 Request Entity Too Large的处理办法--修改 PHP上传文件大小
  • php事务处理实例详解
  • php异常处理使用示例
  • PHP开发框架kohana中处理ajax请求的例子
  • php5.2 Json不能正确处理中文、GB编码的解决方法
  • PHP中模拟处理HTTP PUT请求的例子
  • PHP按行读取、处理较大CSV文件的代码实例
  • PHP中使用asort进行中文排序失效的问题处理
  • PHP按行读取、处理较大CSV文件的例子
  • php中json_encode处理gbk与gb2312中文乱码问题的解决方法
  • PHP处理SQL脚本文件导入到MySQL的代码实例
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • 修改配置真正解决php文件上传大小限制问题(nginx+php)
  • php是什么文件 php文件怎么打开
  • 修改配置真正解决php文件上传大小限制问题(apache+php)
  • PHP源文件加密工具 PHP Screw
  • PHP 'ext/soap/php_xml.c'不完整修复存在多个任意文件泄露漏洞
  • Linux下重编译PHP后Apache竟然不能解析.php文件?
  • 图解找出PHP配置文件php.ini的路径的方法
  • php解压文件代码实现php在线解压
  • PHP大文件上传问题解析 php大文件上传配置参考
  • 查找php配置文件php.ini所在路径的二种方法
  • linux下的php文件放在哪个文件夹下才能访问
  • php导入excel php使用phpexcel导入excel文件
  • php读取文件内容并清空文件
  • 在linux下配的apache的服务,但是读documeroot下的html文件可以,但是.php文件就不行,为什么呢?
  • PHP配置文件设置上传大文件
  • 请教一个linux下命令运行php文件的问题
  • 如何修改PHP+Apache上传文件大小限制
  • PHP读取文件内容后清空文件示例代码
  • 单文件PHP框架 SinglePHP
  • PHP include任意文件或URL介绍
  • mod_php.so文件被删除还有得救吗
  • PHP 5.4.19 和 PHP 5.5.3 发布及下载地址
  • IIS7配置PHP图解(IIS7+PHP_5.2.17/PHP_5.3.5)
  • PHP去除html标签,php标记及css样式代码参考
  • php输入流php://input使用示例(php发送图片流到服务器)
  • php通过socket_bind()设置IP地址代码示例
  • PHP转换器 HipHop for PHP
  • php安装完成后如何添加mysql扩展
  • PHP 框架 Pop php
  • PHP的substr() 函数用法
  • PHP的JavaScript框架 PHP.JS




  • 特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3