0

次のコードを使用しています。

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();

問題:

Iecho $theidの場合、完全なエントリが表示されますが、データベースに挿入されると、シーケンスの最初のエントリのみが挿入されます。たとえば、エントリのbuKPK場合、「b」のみが挿入され、残りは挿入されません。

4

2 に答える 2

4

データベース内の文字の長さを確認してください (つまり、varchar(10) の場合は、そのフィールドに 10 文字を超えて保存していないことを確認してください)。

于 2010-12-28T17:58:08.310 に答える
2

ob_end_clean()ではなく使ってみてくださいob_get_clean()。ob_start() を連続して呼び出すと、「ネストされた」バッファリング コンテキストが作成されます。ob_get_clean()は現在のコンテキストをフェッチしてクリアしますが、終了はしません。そのため、2 回目の呼び出しob_start()により、ネストされた 2 つ目のバッファリング コンテキストが作成されます。この場合、出力バッファをキャプチャしてから、キャプチャ コンテキストを終了するだけです。

于 2010-12-28T17:58:20.810 に答える