pack('H*', dechex(12345678900)) /* on 32bit */ != pack('H*', dechex(12345678900)) /* on 64bit */
why ?
Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.
Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.
Lost your password? Please enter your email address. You will receive a link and will create a new password via email.
Please briefly explain why you feel this question should be reported.
Please briefly explain why you feel this answer should be reported.
Please briefly explain why you feel this user should be reported.
I don’t know how to fix it, but I think I know why this is happening. No bug here – straigt out from the manual http://php.net/manual/en/function.dechex.php
I do not know what exactly is happening “inside” php, but you probably are causing 32 bit unsigned integer to overflow (12,345,678,900 > 4,294,967,295). Since on 64 bit this limit should be 18,446,744,073,709,551,615, dechex is returning “correct” values (32 vs 64 bit diffirence doesn’t seem to be documented and I might be wrong since I don’t have 64 bit system for testing).
//Edit:
As a last resort you could use GMP extesion to make your own hecdex function for 32 bit system, but that is going to produce lots and lots of overhead. Probably going to be one of the slowest implementations known to the modern programming.
//Edit2:
Wrote a function using BCMath, I’m on a Windows at the moment and was struggling finding correct dll for GMP.
Didn’t test thoroughly but seems to work. Use as a last resort – rough benchmarking with 100,000 iterations did show, that it’s ~40 times slower than native implemetation.