ID:               46882
 User updated by:  max at phoenixweb dot it
 Reported By:      max at phoenixweb dot it
 Status:           Open
 Bug Type:         Variables related
 Operating System: Centos 5.2 x86 64bit
 PHP Version:      5.2.8
 New Comment:

But this is a problem.

Serialize is needed to store PHP object as a string. Is this correct?
There are a lot of possibility of needed an object as a string, like
complex data storage, and pass data from a server to another server.

If the data is not unserializable from a different server, it's
completely useless.

When i'll upgrade my server to 12Gb of RAM (needing a 64bit OS), i'll
have to trash all the data stored with SERIALIZE on my MySqls?

I don't think that the correct way is just to add a comment to the
current documentation.

I think this should be consider a bug, cause SERIALIZE / UNSERIALIZE is
used to storage data and pass it across servers, so must be compliant
with the problems of differents OS system behaviours.


Previous Comments:
------------------------------------------------------------------------

[2008-12-16 15:13:54] crrodriguez at opensuse dot org

This behavior is expected, but the documentation of serialize() does
not mention it, this is a documentation problem.

------------------------------------------------------------------------

[2008-12-16 15:03:19] max at phoenixweb dot it

As I can see from the Function Manual, JSON is not a possible
alternative due to his limitation in nested elements.

So... i have to wait that somebody fix this one.

:(

------------------------------------------------------------------------

[2008-12-16 14:54:16] max at phoenixweb dot it

Description:
------------
The problem is easy.

I use SERIALIZE - UNSERIALIZE to pass complex PHP objects between
server e store it on remote.

However the SERIALIZE - UNSERIALIZE process fail while this happens
between a 64bit OS and a 32bit OS, due to a missbehaviour in the number
rappresentation (int).

For the 64bit the (INT) is the correct data type for the number:
4139868160 while for a 32bit system that numbero can handled only by a
(DOUBLE)
 

s:3:"mem";a:2:{s:6:"memory";a:5:{s:5:"total";i:4139868160;s:4:"free";i:1306845184;s:7:"buffers";i:74797056;s:6:"cached";i:2103566336;s:4:"used";i:2833022976;}s:4:"swap";a:3:{s:5:"total";i:8389742592;s:4:"free";i:8389742592;s:4:"used";i:0;}}

During the UNSERIALIZE function on the 32bit system the bitcode is lost
and the number became negative.

Reproduce code:
---------------
serialize this object on different OS:


    [mem] => Array
        (
            [memory] => Array
                (
                    [total] => 4139868160
                    [free] => 1331732480
                    [buffers] => 68988928
                    [cached] => 2102939648
                    [used] => 2808135680
                )

            [swap] => Array
                (
                    [total] => 8389742592
                    [free] => 8389742592
                    [used] => 0
                )

        )

you'll get different SERIALIZED string that are not OS indipendent.

Expected result:
----------------
I expected that the object could be pass throug PHP servers
indipendently from the OS bit system.

Actual result:
--------------
The actual result is a serialized string not indipendent from OS, i
think i'll use JSON functions instead of serialize / unserialize.





------------------------------------------------------------------------


-- 
Edit this bug report at http://bugs.php.net/?id=46882&edit=1

Reply via email to