Мне нужно кодировать / зашифровать идентификаторы базы данных и добавлять их к своим URL-адресам. Я не пытаюсь заниматься безопасностью, но я ищу что-нибудь с умеренной безопасностью. Основная цель - иметь короткие идентификаторы, которые являются уникальными и безопасными для URL.
Следующий фрагмент, похоже, будет делать то, что мне нужно (из http://programanddesign.com/php/base62-encode/ )
function encode($val, $base=62, $chars='0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ') {
// can't handle numbers larger than 2^31-1 = 2147483647
$str = '';
do {
$i = $val % $base;
$str = $chars[$i] . $str;
$val = ($val - $i) / $base;
} while($val > 0);
return $str;
}
function decode($str, $base=62, $chars='0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ') {
$len = strlen($str);
$val = 0;
$arr = array_flip(str_split($chars));
for($i = 0; $i < $len; ++$i) {
$val += $arr[$str[$i]] * pow($base, $len-$i-1);
}
return $val;
}
echo encode(2147483647); // outputs 2lkCB1
Возможно, я немного изменю функции:
Как мне изменить сценарий, чтобы я также мог использовать с ним соль? И было бы это мудрой идеей? Могу ли я непреднамеренно увеличить вероятность столкновения и т. Д.?