ホームページ > バックエンド開発 > PHPチュートリアル > PHP_PHP チュートリアルで実装された短縮 URL アルゴリズムの共有

PHP_PHP チュートリアルで実装された短縮 URL アルゴリズムの共有

WBOY
リリース: 2016-07-13 10:24:35
オリジナル
830 人が閲覧しました

各 URL を 6 文字 (6^32) に置き換えると、最大 1,073,741,824 個の短縮 URL を作成できます。
もちろん、アクセス記録や作成時刻など、より詳細な情報を記録することもできます。
本当に足りない場合は、長期間使用していないものを削除できます。

コードをコピーします コードは次のとおりです:

関数 shorturl($input) {
$base32 = 配列 (
'a'、'b'、'c'、'd'、'e'、'f'、'g'、'h'、
「i」、「j」、「k」、「l」、「m」、「n」、「o」、「p」、
「q」、「r」、「s」、「t」、「u」、「v」、「w」、「x」、
「y」、「z」、「0」、「1」、「2」、「3」、「4」、「5」
);

$hex = md5($input);
$hexLen = strlen($hex);
$subHexLen = $hexLen / 8;
$output = array();

for ($i = 0; $i $subHex = substr ($hex, $i * 8, 8);
$int = 0x3FFFFFFF & (1 * ('0x'.$subHex));
$out = '';

for ($j = 0; $j $val = 0x0000001F & $int;
$out .= $base32[$val];
$int = $int >>
; }

$output[] = $out;
}

$output を返します;
}

テストコード:

コードをコピーします コードは次のとおりです:

$input = 'http://www.jb51.net/1';
$output = shorturl($input);

echo "入力: $inputn";
echo "出力: {$output[0]}n";
echo " {$output[1]}n";
echo " {$output[2]}n";
echo " {$output[3]}n";
エコー「n」;

$input = 'http://www.jb51.net/2';
$output = shorturl($input);

echo "入力: $inputn";
echo "出力: {$output[0]}n";
echo " {$output[1]}n";
echo " {$output[2]}n";
echo " {$output[3]}n";
エコー「n」;

出力:

コードをコピーします コードは次のとおりです:

入力: http://www.jb51.net/1
出力: h0xg4r
bdr3tw
osk2d3
4azfqa

入力: http://www.jb51.net/2
出力: tm5kxb
しおじ2s
ゆわ3dvl

http://www.bkjia.com/PHPjc/825414.htmlwww.bkjia.comtru​​ehttp://www.bkjia.com/PHPjc/825414.html技術記事各 URL は 6 文字 (6^32) に置き換えられ、最大 1,073,741,824 個の短縮 URL を作成できます。 もちろん、アクセス記録や作成時刻など、より詳細な情報を記録することもできます。 本当なら…
🎜
関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート