MongoDB
 sql >> Base de données >  >> NoSQL >> MongoDB

Compresser (raccourcir) la chaîne PHP de 24 caractères à 20

D'après ce que je vois sur votre page référencée, les 24 caractères sont hexadécimaux. Si l'ID client peut être alphanumérique, vous pouvez utiliser base_convert pour raccourcir le nombre. Malheureusement, le nombre complet est> 32 bits, vous devez donc le dissimuler en plusieurs parties pour le faire fonctionner :

// Pad with 0's to make sure you have 24 chars
$padded = str_repeat('0', 24 - strlen($mongoId)) . $mongoId;
$leastSignificant = base_convert(substr($padded, 14, 10), 16, 32); // will be 8 chars most
$middleSignificant = base_convert(substr($padded, 4, 10), 16, 32); // will be 8 chars most
$highSignificant = base_convert(substr($padded, 0, 4), 16, 32); // will be 4 chars most

// Concatenate, and make sure everything is correctly padded
$result = str_repeat('0', 4 - strlen($highSignificant)) . $highSignificant .
          str_repeat('0', 8 - strlen($middleSignificant )) . $middleSignificant .
          str_repeat('0', 8 - strlen($leastSignificant )) . $leastSignificant;
echo strlen($result); // Will echo 20

// Reverse the algoritm to retrieve the mongoId for a given customerId