我使用以下代码:
PHP:
// Generate Guid
function NewGuid() {
$s = strtoupper(uniqid(rand(),true));
$guidText =
substr($s,0,8) . '-' .
substr($s,8,4) . '-' .
substr($s,12,4). '-' .
substr($s,16,4). '-' .
substr($s,20);
return $guidText;
}
// End Generate Guid
$Guid = NewGuid();
$alphabet = '123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ';
function base_encode($num, $alphabet) {
$base_count = strlen($alphabet);
$encoded = '';
while ($num >= $base_count) {
$div = $num/$base_count;
$mod = ($num-($base_count*intval($div)));
$encoded = $alphabet[$mod] . $encoded;
$num = intval($div);
}
if ($num) $encoded = $alphabet[$num] . $encoded;
return $encoded;
}
function base_decode($num, $alphabet) {
$decoded = 0;
$multi = 1;
while (strlen($num) > 0) {
$digit = $num[strlen($num)-1];
$decoded += $multi * strpos($alphabet, $digit);
$multi = $multi * strlen($alphabet);
$num = substr($num, 0, -1);
}
return $decoded;
}
// Ob start
ob_start();
echo base_encode($Guid, $alphabet); //should output: bUKpk
$theid = ob_get_contents();
ob_get_clean();
问题:
当我echo $theid
时,它显示完整的条目,但是当它被插入到数据库中时,只插入序列中的第一个条目,例如对于条目buKPK
,仅' b'正在插入而不是其余部分。
答案 0 :(得分:4)
检查数据库中的字符长度(即,如果它是varchar(10),请确保在该字段中不存储超过10个字符)
答案 1 :(得分:2)
尝试使用ob_end_clean()
而不是ob_get_clean()
。连续调用ob_start()创建“嵌套”缓冲上下文; ob_get_clean()
获取并清除当前上下文,但不终止它,因此第二次调用ob_start()
会创建第二个嵌套缓冲上下文。在这种情况下,您只想捕获输出缓冲区,然后终止捕获上下文。