ホームページ バックエンド開発 PHPチュートリアル PHP でアップロードされた画像の名前を変更するための 6 つのソリューションの調査と概要

PHP でアップロードされた画像の名前を変更するための 6 つのソリューションの調査と概要

Jun 23, 2016 pm 02:38 PM

1. 該当するシナリオ: データベースから返される自己増加する番号を使用して、アップロードされた画像の名前を変更することはできません。

これは、画像またはファイルをアップロードするプロセスによって決まります。
一般的な画像アップロード プロセスでは、まず画像をサーバーにアップロードし、名前を変更してからデータベースに挿入します。
つまり、データベース内で非常に簡単に取得できる自己増加IDは、ファイル名の重複を避けるためにアップロードされた写真の名前を変更するのに使用できません
データベースから最大のIDを取得して1を加算する方法が使用されます。データベースを増やす 接続数は、同時実行性が高くデータ量が膨大な状況には適していません。

2 番目の従来の解決策:

1、guid: 32 文字の 16 進数。
形式: GUID の形式は「xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx」です。各 x は、0 ~ 9 または a ~ f の範囲の 32 桁の 16 進数です。たとえば、6F9619FF-8B86-D011-B42D-00C04FC964FF は有効な GUID 値です。

利点: 繰り返しがほとんどありません。
欠点: アップロードされた写真の名前を変更するにはまだ時間がかかります。
使用法:

/*    com_create_guid()是php5版本支持的功能,对于不支持的版本,可以自己进行定义;*/function guid(){   if (function_exists('com_create_guid')){       return com_create_guid();   }else{       mt_srand((double)microtime()*10000);//optional for php 4.2.0 and up.       echo(mt_rand());       $charid = strtoupper(md5(uniqid(rand(), true)));       $hyphen = chr(45);// "-"       $uuid = chr(123)// "{"               .substr($charid, 0, 8).$hyphen               .substr($charid, 8, 4).$hyphen               .substr($charid,12, 4).$hyphen               .substr($charid,16, 4).$hyphen               .substr($charid,20,12)               .chr(125);// "}"       return $uuid;   }}
ログイン後にコピー

2、MD5:
は guid と同じ 32 文字の 16 進数を出力します。違いは、guid がランダムに生成され、md5 は入力データに基づいて生成される必要があることです。
例、

<?php$str = "Hello";echo md5($str);?>
ログイン後にコピー

Output、

8b1a9953c4611296a827abf8c47804d7
ログイン後にコピー

利点: シード データが規則的で繰り返されない場合、出力値は md5 を通じて保護できます。多くの問題を引き起こします。
欠点: 32 ビット文字は長すぎます。重複しないシード データを提供する必要があります。
使用法: シード データとして秒を使用すると、依然として重複が発生します。

<?php/**结合time()函数使用,以1970年到当前时间的秒数作为种子数。*/$str=time();echo md5($str);?>
ログイン後にコピー

3, uniqid(): 13 桁または 23 桁の文字列を返します。
特に、名前が重複する可能性を減らすために文字列プレフィックスとして差分識別子を使用できるため、uniqid() は md5() の改良版のようなものです。
同時実行性が高くないなどの極端な状況では、すでに一般的なニーズを満たすことができるこの関数を使用することをお勧めします。
詳細、
定義: uniqid() 関数は、マイクロ秒単位の現在時刻に基づいて一意の ID を生成します。
使用法: uniqid(prefix,more_entropy)
説明: prefix は出力文字列にプレフィックスを追加できます。 more_entropy パラメーターが true の場合、23 ビットの文字列が出力されます。

<?phpvar_dump(uniqid());var_dump(uniqid("a"));?>
ログイン後にコピー

出力結果は次のとおりです:

string(13) "51734aa562254" string(14) "a51734aa562257"
ログイン後にコピー

利点: 13 ビットの文字列長は許容可能なファイル名プレフィックスを追加でき、結果にはデータの混乱が含まれるため、元のデータの逆参照を回避できます。 。
欠点: md5 と同様、同時実行性が高く、シード データとして秒を使用するため、やはり重複が発生します。

3. アップグレードされたバージョンのソリューション:

1、fast_uuid: 17 桁を返します。
これは、uniqid() の不完全なカスタマイズ版に似ています。この関数に登場する「シード番号開始時間」の概念は非常に分かりやすいです。
time() と uniqid() で使用されるデフォルトの時刻は 1970 年から計算され、長さは 10 桁 (1366512439) です。「シード番号開始時刻」を使用すると、実際には必要なため、この値を減らすことができます。これは単なる値です。自動的に成長する可能性があります。
開始時間をカスタマイズすると、長さが短縮されるだけでなく、混乱を招く可能性もあります。

/** 参数 suffix_len指定 生成的 ID 值附加多少位随机数,默认值为 3。* 感谢“Ivan Tan|谭俊青 DrinChing (at) Gmail.com”提供的算法。* @param int suffix_len* @return string*/function fast_uuid($suffix_len=3){        //! 计算种子数的开始时间        $being_timestamp = strtotime('2013-3-21');               $time = explode(' ', microtime());        $id = ($time[1] - $being_timestamp) . sprintf('%06u', substr($time[0], 2, 6));        if ($suffix_len > 0)        {            $id .= substr(sprintf('%010u', mt_rand()), 0, $suffix_len);        }        return $id;    }
ログイン後にコピー

Output,

29832412631099013
ログイン後にコピー

2, time()+乱数:

1 秒間に発生する複数のリクエストを解決するために、乱数の使用は上記の例ですでに登場しています。次の 2 つの関数が提供されます:

<?phpfunction random($length) {    $hash = '';    $chars = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789abcdefghijklmnopqrstuvwxyz';    $max = strlen($chars) - 1;    PHP_VERSION < '4.2.0' && mt_srand((double)microtime() * 1000000);    for($i = 0; $i < $length; $i++) {        $hash .= $chars[mt_rand(0, $max)];    }    return $hash;}function random2($length, $numeric = 0) {    PHP_VERSION < '4.2.0' ? mt_srand((double)microtime() * 1000000) : mt_srand();    $seed = base_convert(md5(print_r($_SERVER, 1).microtime()), 16, $numeric ? 10 : 35);    $seed = $numeric ? (str_replace('0', '', $seed).'012340567890') : ($seed.'zZ'.strtoupper($seed));    $hash = '';    $max = strlen($seed) - 1;    for($i = 0; $i < $length; $i++) {        $hash .= $seed[mt_rand(0, $max)];    }    return $hash;}?>
ログイン後にコピー

4 番目の最終ソリューション:

アイデア: userid+秒+乱数。このうち、「userid+秒」は 10 進数から 64 に変換され、桁数が減ります。

説明:
1、userid: 最大値 64 の「ZZZZ」は 10 進数に変換され、「16777215」となります。 ZZZ" は最大 10 進数値に変換され、"262143" に相当します。
2、秒: 独自の時間の開始点を設定します。
$less=time()-strtotime('2012-4-21'); 16進数の「1SpRe」、5桁に変換します
$less=time()-strtotime('2013-3-21'); 16 進数の "_jHY"; 4 桁
3、乱数: random(3) を使用して 3 桁の乱数を生成します。

最終結果: 4 桁のユーザー ID + 4 桁の 2 桁 + 3 桁の乱数 = 11 桁の文字列。結果は uniqid() と似ていますが、堅牢性が向上しています。

5、10進数から16進数への変換アルゴリズム:

1、アルゴリズム 1:


コードの表示

const KeyCode = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ_$';       /**     * 将64进制的数字字符串转为10进制的数字字符串     * @param $m string 64进制的数字字符串     * @param $len integer 返回字符串长度,如果长度不够用0填充,0为不填充     * @return string     * @author 野马     */    function hex64to10($m, $len = 0) {        $m = (string)$m;        $hex2 = '';        $Code = KeyCode;        for($i = 0, $l = strlen($Code); $i < $l; $i++) {            $KeyCode[] = $Code[$i];        }        $KeyCode = array_flip($KeyCode);               for($i = 0, $l = strlen($m); $i < $l; $i++) {            $one = $m[$i];            $hex2 .= str_pad(decbin($KeyCode[$one]), 6, '0', STR_PAD_LEFT);        }        $return = bindec($hex2);               if($len) {            $clen = strlen($return);            if($clen >= $len) {                return $return;            }            else {                return str_pad($return, $len, '0', STR_PAD_LEFT);            }        }        return $return;    }       /**     * 将10进制的数字字符串转为64进制的数字字符串     * @param $m string 10进制的数字字符串     * @param $len integer 返回字符串长度,如果长度不够用0填充,0为不填充     * @return string     * @author 野马     */    function hex10to64($m, $len = 0) {        $KeyCode = KeyCode;        $hex2 = decbin($m);        $hex2 = str_rsplit($hex2, 6);        $hex64 = array();        foreach($hex2 as $one) {            $t = bindec($one);            $hex64[] = $KeyCode[$t];        }        $return = preg_replace('/^0*/', '', implode('', $hex64));        if($len) {            $clen = strlen($return);            if($clen >= $len) {                return $return;            }            else {                return str_pad($return, $len, '0', STR_PAD_LEFT);            }        }        return $return;    }       /**     * 将16进制的数字字符串转为64进制的数字字符串     * @param $m string 16进制的数字字符串     * @param $len integer 返回字符串长度,如果长度不够用0填充,0为不填充     * @return string     * @author 野马     */    function hex16to64($m, $len = 0) {        $KeyCode = KeyCode;        $hex2 = array();        for($i = 0, $j = strlen($m); $i < $j; ++$i) {            $hex2[] = str_pad(base_convert($m[$i], 16, 2), 4, '0', STR_PAD_LEFT);        }        $hex2 = implode('', $hex2);        $hex2 = str_rsplit($hex2, 6);        foreach($hex2 as $one) {            $hex64[] = $KeyCode[bindec($one)];        }        $return = preg_replace('/^0*/', '', implode('', $hex64));        if($len) {            $clen = strlen($return);            if($clen >= $len) {                return $return;            }            else {                return str_pad($return, $len, '0', STR_PAD_LEFT);            }        }        return $return;    }       /**     * 功能和PHP原生函数str_split接近,只是从尾部开始计数切割     * @param $str string 需要切割的字符串     * @param $len integer 每段字符串的长度     * @return array     * @author 野马     */    function str_rsplit($str, $len = 1) {        if($str == null || $str == false || $str == '') return false;        $strlen = strlen($str);        if($strlen <= $len) return array($str);        $headlen = $strlen % $len;        if($headlen == 0) {            return str_split($str, $len);        }        $return = array(substr($str, 0, $headlen));        return array_merge($return, str_split(substr($str, $headlen), $len));    }$a=idate("U");echo "\r\n<br />e:" . hex10to64($a);echo "\r\n<br />e:" . hex64to10(hex10to64($a));
ログイン後にコピー

2、アルゴリズム 2:

コードの表示

function dec2s4($dec) {      $base = '0123456789_$abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';      $result = '';        do {          $result = $base[$dec % 64] . $result;          $dec = intval($dec / 64);      } while ($dec != 0);        return $result;  }    function  s42dec($sixty_four) {      $base_map = array ( '0' => 0,    '1' => 1,    '2' => 2,    '3' => 3,    '4' => 4,    '5' => 5,    '6' => 6,    '7' => 7,    '8' => 8,    '9' => 9,    '_' => 10,    '$' => 11,    'a' => 12,    'b' => 13,    'c' => 14,    'd' => 15,    'e' => 16,    'f' => 17,    'g' => 18,    'h' => 19,    'i' => 20,    'j' => 21,    'k' => 22,    'l' => 23,    'm' => 24,    'n' => 25,    'o' => 26,    'p' => 27,    'q' => 28,    'r' => 29,    's' => 30,    't' => 31,    'u' => 32,    'v' => 33,    'w' => 34,    'x' => 35,    'y' => 36,    'z' => 37,    'A' => 38,    'B' => 39,    'C' => 40,    'D' => 41,    'E' => 42,    'F' => 43,    'G' => 44,    'H' => 45,    'I' => 46,    'J' => 47,    'K' => 48,    'L' => 49,    'M' => 50,    'N' => 51,    'O' => 52,    'P' => 53,    'Q' => 54,    'R' => 55,    'S' => 56,    'T' => 57,    'U' => 58,    'V' => 59,    'W' => 60,    'X' => 61,    'Y' => 62,    'Z' => 63,  );      $result = 0;      $len = strlen($sixty_four);        for ($n = 0; $n < $len; $n++) {          $result *= 64;          $result += $base_map[$sixty_four{$n}];      }        return $result;  }    $a=idate("U");var_dump(dec2s4($a));  var_dump(s42dec(dec2s4($a)));
ログイン後にコピー

3、アルゴリズム効率テスト:

表示コード

$strarr = array();$time1 = microtime(true);for($i = 0; $i < 10000; ++$i) {     $str = idate("U")+$i;     $strarr[] = "{$i}->$str\r\n<br>"; } $time2 = microtime(true); $time3 = $time2 - $time1; $time1 = microtime(true); for($i = 0; $i < 10000; ++$i) {     $str = dec2s4(idate("U")+$i);    $strarr[] = "{$i}->$str\r\n<br>";}$time2 = microtime(true);echo "\r\n<br />运行10000次用时(秒):" . ($time2 - $time1 - $time3);
ログイン後にコピー

4、テスト結果

アルゴリズム 1: 0.1687250137329
アルゴリズム 2: 0.044965028762817
5、結論: アルゴリズム 1 は効率は低いですが、md5 で生成された 16 進数を変換できます16 進数に変換し、文字列を短縮するために使用できます。 md5 を使用する必要がある環境。

6 番目、要約、
この記事では、アップロードされた画像の名前を変更するために使用できるいくつかの方法について説明します。重要な点は、文字列を減らすために 10 進数を 16 進数に変更することです。
例えば、fast_uuid で生成された 17 桁の数値は、たった 7 文字の 16 進数に変換されます。
具体的な使い方は、状況に応じて柔軟に使用できます。

参考文献:

1、GUID Baidu 百科事典: http://baike.baidu.com/view/185358.htm
2、com_create_guid() 公式ガイド: http://www.php.net/manual / zh/function.com-create-guid.php
3、MD5() 関数の説明: http://www.w3school.com.cn/php/func_string_md5.asp
4、time() 関数の説明: http://www.w3school.com.cn/php/func_string_md5.asp
4 www.w3school.com.cn/php/func_date_time.asp

5、uniqid() 関数の説明: http://www.w3school.com.cn/php/func_misc_uniqid.asp

🎜
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

PHPのカール:REST APIでPHPカール拡張機能を使用する方法 PHPのカール:REST APIでPHPカール拡張機能を使用する方法 Mar 14, 2025 am 11:42 AM

PHPクライアントURL(CURL)拡張機能は、開発者にとって強力なツールであり、リモートサーバーやREST APIとのシームレスな対話を可能にします。尊敬されるマルチプロトコルファイル転送ライブラリであるLibcurlを活用することにより、PHP Curlは効率的なexecuを促進します

PHPにおける後期静的結合の概念を説明します。 PHPにおける後期静的結合の概念を説明します。 Mar 21, 2025 pm 01:33 PM

記事では、PHP 5.3で導入されたPHPの後期静的結合(LSB)について説明し、より柔軟な継承を求める静的メソッドコールのランタイム解像度を可能にします。 LSBの実用的なアプリケーションと潜在的なパフォーマ

JSON Web Tokens(JWT)とPHP APIでのユースケースを説明してください。 JSON Web Tokens(JWT)とPHP APIでのユースケースを説明してください。 Apr 05, 2025 am 12:04 AM

JWTは、JSONに基づくオープン標準であり、主にアイデンティティ認証と情報交換のために、当事者間で情報を安全に送信するために使用されます。 1。JWTは、ヘッダー、ペイロード、署名の3つの部分で構成されています。 2。JWTの実用的な原則には、JWTの生成、JWTの検証、ペイロードの解析という3つのステップが含まれます。 3. PHPでの認証にJWTを使用する場合、JWTを生成および検証でき、ユーザーの役割と許可情報を高度な使用に含めることができます。 4.一般的なエラーには、署名検証障害、トークンの有効期限、およびペイロードが大きくなります。デバッグスキルには、デバッグツールの使用とロギングが含まれます。 5.パフォーマンスの最適化とベストプラクティスには、適切な署名アルゴリズムの使用、有効期間を合理的に設定することが含まれます。

フレームワークセキュリティ機能:脆弱性から保護します。 フレームワークセキュリティ機能:脆弱性から保護します。 Mar 28, 2025 pm 05:11 PM

記事では、入力検証、認証、定期的な更新など、脆弱性から保護するためのフレームワークの重要なセキュリティ機能について説明します。

PHPのCurlライブラリを使用してJSONデータを含むPOSTリクエストを送信する方法は? PHPのCurlライブラリを使用してJSONデータを含むPOSTリクエストを送信する方法は? Apr 01, 2025 pm 03:12 PM

PHP開発でPHPのCurlライブラリを使用してJSONデータを送信すると、外部APIと対話する必要があることがよくあります。一般的な方法の1つは、Curlライブラリを使用して投稿を送信することです。

フレームワークのカスタマイズ/拡張:カスタム機能を追加する方法。 フレームワークのカスタマイズ/拡張:カスタム機能を追加する方法。 Mar 28, 2025 pm 05:12 PM

この記事では、フレームワークにカスタム機能を追加し、アーキテクチャの理解、拡張ポイントの識別、統合とデバッグのベストプラクティスに焦点を当てています。

ReactPhpの非ブロッキング機能は何ですか?ブロッキングI/O操作を処理する方法は? ReactPhpの非ブロッキング機能は何ですか?ブロッキングI/O操作を処理する方法は? Apr 01, 2025 pm 03:09 PM

ReactPhpの詳細な解釈の非ブロッキング機能の公式紹介は、多くの開発者の質問を呼び起こしました。

See all articles