検索
ホームページバックエンド開発PHPの問題PHPで写真をアップロードして名前を変更する方法

PHP で画像をアップロードして名前を変更する方法: 1. GUID メソッドを使用してアップロードした画像の名前を変更する; 2. MD5 メソッドを使用する; 3. uniqid メソッドを使用する; 4. fast_uuid メソッドを使用するなど。

PHPで写真をアップロードして名前を変更する方法

この記事の動作環境: Windows 7 システム、PHP バージョン 7.1、Dell G3 コンピューター

写真とアップロード方法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);
?>

出力

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 ビット文字列が出力されます。

コードは次のとおりです:

<?php
var_dump(uniqid());
var_dump(uniqid("a"));
?>

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

string(13) "51734aa562254" string(14) "a51734aa562257"

利点: 13 桁の文字列長が許容されるファイル名の長さです。 ; OK プレフィックスを追加すると、結果にデータの難読化が含まれ、元のデータの逆参照を回避できます。
欠点: 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(&#39;2013-3-21&#39;);
    $time = explode(&#39; &#39;, microtime());
    $id = ($time[1] - $being_timestamp) . sprintf(&#39;%06u&#39;, substr($time[0], 2, 6));
    if ($suffix_len > 0)
    {
        $id .= substr(sprintf(&#39;%010u&#39;, mt_rand()), 0, $suffix_len);
    }
    return $id;
}

出力、

29832412631099013

2、time() 乱数:
乱数はすでに出現しています上記の例では、1 秒間に発生する複数のリクエストを解決するために使用されます。

コードは次のとおりです:

<?php
function random($length) {
    $hash = &#39;&#39;;
    $chars = &#39;ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789abcdefghijklmnopqrstuvwxyz&#39;;
    $max = strlen($chars) - 1;
    PHP_VERSION < &#39;4.2.0&#39; && 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 < &#39;4.2.0&#39; ? mt_srand((double)microtime() * 1000000) : mt_srand();
    $seed = base_convert(md5(print_r($_SERVER, 1).microtime()), 16, $numeric ? 10 : 35);
    $seed = $numeric ? (str_replace(&#39;0&#39;, &#39;&#39;, $seed).&#39;012340567890&#39;) : ($seed.&#39;zZ&#39;.strtoupper($seed));
    $hash = &#39;&#39;;
    $max = strlen($seed) - 1;
    for($i = 0; $i < $length; $i++) {
        $hash .= $seed[mt_rand(0, $max)];
    }
    return $hash;
}
?>

4. 最終的な解決策:
アイデア: userid 秒の乱数。このうち、「userid 秒」は 10 進数から 64 に変換され、桁数が減ります。
説明:
userid: 64 の「ZZZZ」の最大値が 10 進数に変換され、「16777215」となります。 「ZZZ」の最大値は 10 進数に変換されます。値は「262143」と等しくなります。
秒: 独自の時間の開始点を設定します。
$less=time()-strtotime('2012-4-21'); 16進数「1SpRe」、5桁に変換
$less=time()-strtotime('2013-3-21') ; 16 進数の "_jHY" に変換します; 4 桁の乱数
: random(3) を使用して 3 桁の乱数を生成します;
最終結果:
4 桁のユーザー ID 4 桁の秒 3-桁の乱数 = 11 桁の文字列。結果は uniqid() と似ていますが、堅牢性が向上しています。
5. 10 進数を 16 進数に変換するためのアルゴリズム:
アルゴリズム 1:

コードは次のとおりです:

const KeyCode = &#39;0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ_$&#39;;
    /**
     * 将64进制的数字字符串转为10进制的数字字符串
     * @param $m string 64进制的数字字符串
     * @param $len integer 返回字符串长度,如果长度不够用0填充,0为不填充
     * @return string
     * @author 野马
     */
    function hex64to10($m, $len = 0) {
        $m = (string)$m;
        $hex2 = &#39;&#39;;
        $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, &#39;0&#39;, STR_PAD_LEFT);
        }
        $return = bindec($hex2);
        if($len) {
            $clen = strlen($return);
            if($clen >= $len) {
                return $return;
            }
            else {
                return str_pad($return, $len, &#39;0&#39;, 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(&#39;/^0*/&#39;, &#39;&#39;, implode(&#39;&#39;, $hex64));
        if($len) {
            $clen = strlen($return);
            if($clen >= $len) {
                return $return;
            }
            else {
                return str_pad($return, $len, &#39;0&#39;, 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, &#39;0&#39;, STR_PAD_LEFT);
        }
        $hex2 = implode(&#39;&#39;, $hex2);
        $hex2 = str_rsplit($hex2, 6);
        foreach($hex2 as $one) {
            $hex64[] = $KeyCode[bindec($one)];
        }
        $return = preg_replace(&#39;/^0*/&#39;, &#39;&#39;, implode(&#39;&#39;, $hex64));
        if($len) {
            $clen = strlen($return);
            if($clen >= $len) {
                return $return;
            }
            else {
                return str_pad($return, $len, &#39;0&#39;, 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 == &#39;&#39;) 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:

コードは次のとおりです:

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

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

コードは次のとおりです:

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

测试结果
算法1:0.1687250137329
算法2:0.044965028762817
结论:算法1虽然效率上差一些,但是可以把md5生成的16进制转化为64进制,能够使用在必须使用md5的环境下缩短字符串。
六、总结
本文涉及了上传图片重命名可以能使用的几种方法,其中关键点是使用10进制转换为64进制来进行字符串的缩减。
例如,使用fast_uuid生成的17位数字,转换为64进制仅有7位字符;
具体使用,可以根据自身情况灵活使用,希望对大家有所帮助。

推荐学习:《PHP视频教程

以上がPHPで写真をアップロードして名前を変更する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
酸とベースデータベース:違いとそれぞれを使用するタイミング。酸とベースデータベース:違いとそれぞれを使用するタイミング。Mar 26, 2025 pm 04:19 PM

この記事では、酸とベースのデータベースモデルを比較し、その特性と適切なユースケースを詳述しています。酸は、財務およびeコマースアプリケーションに適したデータの整合性と一貫性を優先し、ベースは可用性に焦点を当て、

PHPセキュアファイルアップロード:ファイル関連の脆弱性の防止。PHPセキュアファイルアップロード:ファイル関連の脆弱性の防止。Mar 26, 2025 pm 04:18 PM

この記事では、コードインジェクションのような脆弱性を防ぐために、PHPファイルのアップロードを確保することについて説明します。ファイルタイプの検証、セキュアストレージ、およびアプリケーションセキュリティを強化するエラー処理に焦点を当てています。

PHP入力検証:ベストプラクティス。PHP入力検証:ベストプラクティス。Mar 26, 2025 pm 04:17 PM

記事では、組み込み関数、ホワイトリストアプローチ、サーバー側の検証などの手法に焦点を当てたセキュリティを強化するためのPHP入力検証のベストプラクティスについて説明します。

PHP APIレート制限:実装戦略。PHP APIレート制限:実装戦略。Mar 26, 2025 pm 04:16 PM

この記事では、Token BucketやLeaky BucketなどのアルゴリズムやSymfony/Rate-Limiterなどのライブラリを使用するなど、PHPでAPIレート制限を実装するための戦略について説明します。また、監視、動的に調整されたレートの制限、および手をカバーします

PHPパスワードハッシュ:password_hashおよびpassword_verify。PHPパスワードハッシュ:password_hashおよびpassword_verify。Mar 26, 2025 pm 04:15 PM

この記事では、パスワードを保護するためにPHPでpassword_hashとpassword_verifyを使用することの利点について説明します。主な議論は、これらの関数が自動塩の生成、強力なハッシュアルゴリズム、およびSecurを通じてパスワード保護を強化するということです

OWASPトップ10 PHP:共通の脆弱性を説明し、軽減します。OWASPトップ10 PHP:共通の脆弱性を説明し、軽減します。Mar 26, 2025 pm 04:13 PM

この記事では、PHPおよび緩和戦略におけるOWASPトップ10の脆弱性について説明します。重要な問題には、PHPアプリケーションを監視および保護するための推奨ツールを備えたインジェクション、認証の壊れ、XSSが含まれます。

PHP XSS予防:XSSから保護する方法。PHP XSS予防:XSSから保護する方法。Mar 26, 2025 pm 04:12 PM

この記事では、PHPでのXSS攻撃を防ぐための戦略について説明し、入力の消毒、出力エンコード、セキュリティを向上させるライブラリとフレームワークの使用に焦点を当てています。

PHPインターフェイスvs抽象クラス:それぞれを使用する時期。PHPインターフェイスvs抽象クラス:それぞれを使用する時期。Mar 26, 2025 pm 04:11 PM

この記事では、PHPでのインターフェイスと抽象クラスの使用について説明し、それぞれをいつ使用するかに焦点を当てています。インターフェイスは、無関係なクラスや複数の継承に適した、実装なしで契約を定義します。抽象クラスは共通の機能を提供します

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

ホットツール

SublimeText3 Linux 新バージョン

SublimeText3 Linux 新バージョン

SublimeText3 Linux 最新バージョン

Dreamweaver Mac版

Dreamweaver Mac版

ビジュアル Web 開発ツール

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

mPDF

mPDF

mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

VSCode Windows 64 ビットのダウンロード

VSCode Windows 64 ビットのダウンロード

Microsoft によって発売された無料で強力な IDE エディター