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

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 までご連絡ください。
PHPの現在のステータス:Web開発動向を見てくださいPHPの現在のステータス:Web開発動向を見てくださいApr 13, 2025 am 12:20 AM

PHPは、現代のWeb開発、特にコンテンツ管理とeコマースプラットフォームで依然として重要です。 1)PHPには、LaravelやSymfonyなどの豊富なエコシステムと強力なフレームワークサポートがあります。 2)パフォーマンスの最適化は、Opcacheとnginxを通じて達成できます。 3)PHP8.0は、パフォーマンスを改善するためにJITコンパイラを導入します。 4)クラウドネイティブアプリケーションは、DockerおよびKubernetesを介して展開され、柔軟性とスケーラビリティを向上させます。

PHP対その他の言語:比較PHP対その他の言語:比較Apr 13, 2025 am 12:19 AM

PHPは、特に迅速な開発や動的なコンテンツの処理に適していますが、データサイエンスとエンタープライズレベルのアプリケーションには良くありません。 Pythonと比較して、PHPはWeb開発においてより多くの利点がありますが、データサイエンスの分野ではPythonほど良くありません。 Javaと比較して、PHPはエンタープライズレベルのアプリケーションでより悪化しますが、Web開発により柔軟性があります。 JavaScriptと比較して、PHPはバックエンド開発により簡潔ですが、フロントエンド開発のJavaScriptほど良くありません。

PHP対Python:コア機能と機能PHP対Python:コア機能と機能Apr 13, 2025 am 12:16 AM

PHPとPythonにはそれぞれ独自の利点があり、さまざまなシナリオに適しています。 1.PHPはWeb開発に適しており、組み込みのWebサーバーとRich Functionライブラリを提供します。 2。Pythonは、簡潔な構文と強力な標準ライブラリを備えたデータサイエンスと機械学習に適しています。選択するときは、プロジェクトの要件に基づいて決定する必要があります。

PHP:Web開発の重要な言語PHP:Web開発の重要な言語Apr 13, 2025 am 12:08 AM

PHPは、サーバー側で広く使用されているスクリプト言語で、特にWeb開発に適しています。 1.PHPは、HTMLを埋め込み、HTTP要求と応答を処理し、さまざまなデータベースをサポートできます。 2.PHPは、ダイナミックWebコンテンツ、プロセスフォームデータ、アクセスデータベースなどを生成するために使用され、強力なコミュニティサポートとオープンソースリソースを備えています。 3。PHPは解釈された言語であり、実行プロセスには語彙分析、文法分析、編集、実行が含まれます。 4.PHPは、ユーザー登録システムなどの高度なアプリケーションについてMySQLと組み合わせることができます。 5。PHPをデバッグするときは、error_reporting()やvar_dump()などの関数を使用できます。 6. PHPコードを最適化して、キャッシュメカニズムを使用し、データベースクエリを最適化し、組み込み関数を使用します。 7

PHP:多くのウェブサイトの基礎PHP:多くのウェブサイトの基礎Apr 13, 2025 am 12:07 AM

PHPが多くのWebサイトよりも優先テクノロジースタックである理由には、その使いやすさ、強力なコミュニティサポート、広範な使用が含まれます。 1)初心者に適した学習と使用が簡単です。 2)巨大な開発者コミュニティと豊富なリソースを持っています。 3)WordPress、Drupal、その他のプラットフォームで広く使用されています。 4)Webサーバーとしっかりと統合して、開発の展開を簡素化します。

誇大広告を超えて:今日のPHPの役割の評価誇大広告を超えて:今日のPHPの役割の評価Apr 12, 2025 am 12:17 AM

PHPは、特にWeb開発の分野で、最新のプログラミングで強力で広く使用されているツールのままです。 1)PHPは使いやすく、データベースとシームレスに統合されており、多くの開発者にとって最初の選択肢です。 2)動的コンテンツ生成とオブジェクト指向プログラミングをサポートし、Webサイトを迅速に作成および保守するのに適しています。 3)PHPのパフォーマンスは、データベースクエリをキャッシュおよび最適化することで改善でき、その広範なコミュニティと豊富なエコシステムにより、今日のテクノロジースタックでは依然として重要になります。

PHPの弱い参照は何ですか、そしていつ有用ですか?PHPの弱い参照は何ですか、そしていつ有用ですか?Apr 12, 2025 am 12:13 AM

PHPでは、弱い参照クラスを通じて弱い参照が実装され、ガベージコレクターがオブジェクトの回収を妨げません。弱い参照は、キャッシュシステムやイベントリスナーなどのシナリオに適しています。オブジェクトの生存を保証することはできず、ごみ収集が遅れる可能性があることに注意する必要があります。

PHPで__invoke Magicメソッドを説明してください。PHPで__invoke Magicメソッドを説明してください。Apr 12, 2025 am 12:07 AM

\ _ \ _ Invokeメソッドを使用すると、オブジェクトを関数のように呼び出すことができます。 1。オブジェクトを呼び出すことができるように\ _ \ _呼び出しメソッドを定義します。 2。$ obj(...)構文を使用すると、PHPは\ _ \ _ Invokeメソッドを実行します。 3。ロギングや計算機、コードの柔軟性の向上、読みやすさなどのシナリオに適しています。

See all articles

ホット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ヘンタイを無料で生成します。

ホットツール

WebStorm Mac版

WebStorm Mac版

便利なJavaScript開発ツール

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

DVWA

DVWA

Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

AtomエディタMac版ダウンロード

AtomエディタMac版ダウンロード

最も人気のあるオープンソースエディター

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール