是否有可能从规模到https://stackoverflow.com/a/9848014/2704706编码采取了以下功能/解码的号码变成11字符串?生成的YouTube式的标识与PHP
function lfsr($x) {
return ($x >> 1)^(($x&1) ? 0xe10000 : 0);
}
function to_4($x) {
for($i=0;$i<24;$i++)
$x = lfsr($x);
$str = pack("CCC", $x >> 16, ($x >> 8) & 0xff, $x & 0xff);
return base64_encode($str);
}
function rev_lfsr($x) {
$bit = $x & 0x800000;
$x = $x^($bit ? 0xe10000 : 0);
return ($x << 1) + ($bit ? 1 : 0);
}
function from_4($str) {
$str = base64_decode($str);
$x = unpack("C*", $str);
$x = $x[1]*65536 + $x[2] * 256 + $x[3];
for($i=0;$i<24;$i++)
$x = rev_lfsr($x);
return $x;
}
for($i=0; $i<256; $i++) {
$enc = to_4($i);
echo $enc . " " . from_4($enc) . "\n";
}
我的最终目标是使用这些方法,形成具有编码ID的网址,以类似的方式向包括在YouTube的URL中的V $ _ GET变量,即RArlg6HeZZM在http://www.youtube.com/watch?v=RArlg6HeZZM视频的ID。
提前致谢。
使用散列算法有利于“减少”的字符串的东西小;但是你会想用查找来“走另一条路”。 – Floris
我实际上喜欢使用类似于我上面包含的编码算法而不是哈希算法,这样我就可以将ID解码回原始数字表示。 –
您可以使用PHP中的任何加密函数,首先将序列号转换为适当长的字符串。 base-64的11个字符大概是64位,或八个字节,这是一个方便的加密块。 – rici