我正在做一个项目,他们在 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 中的解析器,并且为编码命名肯定会对我的搜索有所帮助。