4

我正在做一个项目,他们在 mysql 数据库的 BLOB 类型列中存储了以下类型的编码数据。我四处询问并被告知这是Bencode,但是,从我在网上看到的情况来看,它似乎不是标准的Bencode。

Wiki for Bencode

http://en.wikipedia.org/wiki/Bencode

编码数据示例

a:11:{i:0;a:3:{s:11:"question_id";s:2:"46";s:6:"answer";s:1:"2";s:7:"correct";b:1;}i:1;a:3:{s:11:"question_id";s:2:"45";s:6:"answer";s:1:"2";s:7:"correct";b:0;}i:2;a:3:{s:11:"question_id";s:2:"44";s:6:"answer";s:1:"2";s:7:"correct";b:0;}i:3;a:3:{s:11:"question_id";s:2:"43";s:6:"answer";s:1:"1";s:7:"correct";b:0;}i:4;a:3:{s:11:"question_id";s:2:"42";s:6:"answer";s:1:"3";s:7:"correct";b:0;}i:5;a:3:{s:11:"question_id";s:2:"41";s:6:"answer";s:1:"2";s:7:"correct";b:0;}i:6;a:3:{s:11:"question_id";s:2:"40";s:6:"answer";s:1:"0";s:7:"correct";b:1;}i:7;a:3:{s:11:"question_id";s:2:"39";s:6:"answer";s:1:"0";s:7:"correct";b:0;}i:8;a:3:{s:11:"question_id";s:2:"38";s:6:"answer";s:1:"1";s:7:"correct";b:1;}i:9;a:3:{s:11:"question_id";s:2:"37";s:6:"answer";s:1:"3";s:7:"correct";b:0;}i:10;a:3:{s:11:"question_id";s:2:"36";s:6:"answer";s:1:"2";s:7:"correct";b:1;}}

到目前为止我注意到的

我注意到编码使用类似于 Bencode 的字母和整数来描述不同类型的数据。

例子: s:11:"question_id";

我假设s代表“字符串”,即11定义字符串的长度question_id。此外,数据 ( ) 的开头似乎a:11:描述了一个长度为 11 的数组。虽然这类似于标准 Bencode,但它似乎没有使用 Bencode 使用的标准语法。

有谁知道这是什么类型的编码?这是非标准的 Bencode 格式,还是完全不同的格式?我正在寻找 PHP 或 Python 中的解析器,并且为编码命名肯定会对我的搜索有所帮助。

4

1 回答 1

6

它是 PHP 序列化格式,使用unserialize.
请参阅http://codepad.org/l7Z9cITo

于 2012-09-07T16:02:13.380 回答