Javascript:
function serialize( mixed_val ) { // Generates a storable representation of a value
//
// + original by: Ates Goral (http://magnetiq.com)
// + adapted for IE: Ilia Kantor (http://javascript.ru)
switch (typeof(mixed_val)){
case "number":
if (isNaN(mixed_val) || !isFinite(mixed_val)){
return false;
} else{
return (Math.floor(mixed_val) == mixed_val ? "i" : "d") + ":" + mixed_val + ";";
}
case "string":
return "s:" + mixed_val.length + ":\"" + mixed_val + "\";";
case "boolean":
return "b:" + (mixed_val ? "1" : "0") + ";";
case "object":
if (mixed_val == null) {
return "N;";
} else if (mixed_val instanceof Array) {
var idxobj = { idx: -1 };
var map = []
for(var i=0; i<mixed_val.length;i++) {
idxobj.idx++;
var ser = serialize(mixed_val[i]);
if (ser) {
map.push(serialize(idxobj.idx) + ser)
}
}
return "a:" + mixed_val.length + ":{" + map.join("") + "}"
}
else {
var class_name = get_class(mixed_val);
if (class_name == undefined){
return false;
}
var props = new Array();
for (var prop in mixed_val) {
var ser = serialize(mixed_val[prop]);
if (ser) {
props.push(serialize(prop) + ser);
}
}
return "O:" + class_name.length + ":\"" + class_name + "\":" + props.length + ":{" + props.join("") + "}";
}
case "undefined":
return "N;";
}
return false;
}
Примеры:
serialize(['Kevin', 'van', 'Zonneveld']);
'a:3:{i:0;s:5:"Kevin";i:1;s:3:"van";i:2;s:9:"Zonneveld";}'
serialize(3.14);
'd:3.14;'
serialize("foo");
's:3:"foo";'
serialize(new Object());
'O:6:"Object":0:{}'
serialize(new (function MyClass() {}));
'O:7:"MyClass":0:{}'
serialize(new (function MyClass() { this.prop = 42 }));
'O:7:"MyClass":1:{s:4:"prop";i:42;}'
serialize(new Array());
'a:0:{}'
serialize([1, 3]);
'a:2:{i:0;i:1;i:1;i:3;}'
serialize(undefined);
'N;'
serialize(Infinity);
false;
serialize(function doit() {});
false;
|
|
|
|
Поиск по сайту
|
|
Содержание
|
|
Последние темы на форуме
|
Forum |
|
У меня на сервере PHP, почему то не разбирает, то, что выдаёт эта функция. Я разобрался в чём проблема. Строка сериализованная через PHP с русскими символами выглядит так: s:12:"Вопрос", то есть на каждый символ уходит по 2 байта, а на каждый латинский по одному ( s:13:"ВопросD" ). Данный скрипт считает количество символов не разбирая кодировку. Я написал простую функцию:
и поместил её вызов вот сюда:
Всё заработало. Возможно конечно, что это проблема наблюдается только у меня из-за специфики системы.
( Windows7+ZendServer+apache2 )
У меня была такая же проблема, когда переводил сайт с Win-1251 на UTF-8. В первой кодировке каждому символу выделяется один байт, во второй — от одного до шести, по мере необходимости. Опытным путём выяснилось, что русские символы определяются двумя байтами. Пришлось вручную править файлы с сериализованными данными...