I need a PHP version of the following C# code:
string dateSince = "2010-02-01";
string siteID = "bash.org";
string sharedSecret = "12345"; // the same combination on my luggage!
using System.Security.Cryptography;
MD5CryptoServiceProvider x = new MD5CryptoServiceProvider();
byte[] dataBytes = System.Text.Encoding.ASCII.GetBytes(string.Format("{0}{1}{2}", dateSince, siteID, sharedSecret));
string result = BitConverter.ToString(x.ComputeHash(dataBytes));
… this code snippet appears to be incomplete. But here’s what I think is going on:
-
concatenating dateSince, siteID, and sharedSecret. Stealing underpants.
-
???
-
converting that string into a ascii encoded byte array.
-
taking the MD5 hash of that array.
This mysterious BitConverter object appears to be converting that MD5 hashed array, into a string of hexadecimal numbers. According to the aforementioned doc, the value of result should look something like: “6D-E9-9A-B6-73-D8-10-79-BC-4F-EE-51-A4-84-15-D8”
Any help is greatly appreciated!!
Forgot to include this earlier. Here’s the PHP version of what I’ve written so far:
$date_since = "2010-02-01";
$site_id = "bash.org";
$shared_secret = "12345";
$initial_token = $date_since.$site_id.$shared_secret;
$ascii_version = array();
foreach($i=0; $i < strlen($initial_token); $i++) {
$ascii_version[] = ord(substr($initial_token,$i,1));
}
$md5_version = md5(join("", $ascii_version));
$hexadecimal_bits = array();
foreach($i=0; $i < strlen($md5_version); $i++) {
// @todo convert to hexadecimal here?
$hexadecimal_bits[] = bin2hex(substr($md5_version,$i,1));
}
$result = join("-", $hexadecimal_bits);
I think this will work for you. It looks like the MD5CryptoServiceProvider::ComputeHash method returns an array of 16 bytes, not a string of 32 characters like the normal PHP
md5()function. However, PHP’smd5()has a second optional parameter that forces “raw output”, which does correspond to the output ofComputeHash().