您可以使用以下功能(代码改编自我的个人框架):
function Base($input, $output, $number = 1, $charset = 'abcdefghijklmnopqrstuvwxyz0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ')
{
if (strlen($charset) >= 2)
{
$input = max(2, min(intval($input), strlen($charset)));
$output = max(2, min(intval($output), strlen($charset)));
$number = ltrim(preg_replace('~[^' . preg_quote(substr($charset, 0, max($input, $output)), '~') . ']+~', '', $number), $charset[0]);
if (strlen($number) > 0)
{
if ($input != 10)
{
$result = 0;
foreach (str_split(strrev($number)) as $key => $value)
{
$result += pow($input, $key) * intval(strpos($charset, $value));
}
$number = $result;
}
if ($output != 10)
{
$result = $charset[$number % $output];
while (($number = intval($number / $output)) > 0)
{
$result = $charset[$number % $output] . $result;
}
$number = $result;
}
return $number;
}
return $charset[0];
}
return false;
}
基本上你只需要从你的表中获取新生成的自动递增 ID(这也确保你不会产生任何冲突)并将其传递给这个函数,如下所示:
$short_id = Base(10, 62, $auto_increment_id);
请注意,第一个和第二个参数分别定义输入和输出基数。
此外,我已从“默认”重新排序字符集0-9a-zA-Z
以符合您的示例。
base_convert()
如果您可以不使用混合字母大小写(以 36 为基数),您也可以使用。