6種類のphpアップロード画像の名前変更方法の例

13621 ワード

一、適用シーン:データベースから返された自己成長数を使用して、アップロード画像の名前を変更することはできません.
これは画像やファイルのアップロードの流れによって決まります.
一般的な画像アップロード処理は,まず画像をサーバにアップロードし,名前を変更した後,データベースに挿入する.
つまり、データベースで非常に入手しやすい自己成長idは、アップロードされた画像の名前を変更するために使用できず、ファイル名の重複を避けるために、
データベースから最大idプラス1を取得する方式を採用し、データベース接続の回数を増やし、高同時性とデータ量が大きい場合には適用されない.
二、一般案:1,guid:32文字16進数.
フォーマット:GUIDのフォーマットは「xxxxxx-xxxxxx-xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx例えば、6 F 9619 FF-8 B 86-D 011-B 42 D-00 C 04 FC 964 FFが有効な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はランダムに生成され、md 5は入力したデータに基づいて生成する必要があります.
例:
 
  
$str = "Hello";
echo md5($str);
?>

しゅつりょく
8b1a9953c4611296a827abf8c47804d7
利点:入力したシードデータに基づいて出力の数値を制御することができ、シードデータが規則的に重複しない場合、md 5によってデータを保護することができ、大きな混同作用を生じる.
欠点:32ビット文字が長すぎる;重複しないシードデータを提供する必要があります.
使用法:高同時、秒をシードデータとして、依然として重複現象が発生します.
 
  
/*
* time() , 1970 。
*/
$str=time();
echo md5($str);
?>

3,uniqid():13または23ビットの文字列を返します.
我々の目的では、uniqid()はmd 5()の改良版のように、特に文字列接頭辞として差異識別を採用することができ、重複ネーミングの出現確率を低減することができる.
非高同時性などの極端な場合は、この関数を推奨し、一般的なニーズを満たすことができます.
詳しく説明すると、
定義:uniqid()関数は、マイクロ秒で計算された現在の時間に基づいて、一意のIDを生成します.
使用法:uniqid(prefix,more_entropy)
説明:prefixは、出力された文字列に接頭辞を追加できます.例は、more_entropyパラメータがtrueの場合、23ビット文字列が出力されます.
 
  
var_dump(uniqid());
var_dump(uniqid("a"));
?>

出力結果:
string(13) "51734aa562254"string(14) "a51734aa562257"
利点:13ビット文字列の長さは、許容できるファイル名の長さです.接頭辞を追加できます.結果にはデータの混同が含まれ、元のデータを反転させることを避けることができます.
欠点:md 5と類似しており、高同時性であり、秒をシードデータとしても重複現象が発生する.
三、アップグレード版方案: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;
}

出力、
29832412631099013
2,time()+乱数:
上記の例では、1秒で発生する複数のリクエストを解決するために乱数の使用が行われています.次の2つの関数を提供します.
 
  
function 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;
}
?>

四、最終方案:
考え方:userid+秒+乱数.ここで「userid+秒」は10進数から64進数に転換し、桁数を縮小する.
説明:
userid:64進数最大値「ZZZZ」を10進数に変換すると「1677215」になり、「ZZZ」を10進数最大値に変換すると「262143」になります.
秒:自分の時間の開始点を設定します.
$less=time()-strtotime('2012-4-21′); 64進法「1 SpRe」に変換し、5ビット
$less=time()-strtotime('2013-3-21′); 64進数に変換_jHY";4ビット
乱数:random(3)を使用して3ビットの乱数を生成します.
最終結果:
4ビットuserid+4ビット秒+3ビット乱数=11ビット文字列.uniqid()の結果と似ているように見えますが、強さは向上しています.
五、十進法64進数アルゴリズム:アルゴリズム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

e:" . hex10to64($a);
echo "\r

e:" . hex64to10(hex10to64($a));

アルゴリズム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)));

アルゴリズム効率テスト:
 
  
$strarr = array();
$time1 = microtime(true);
for($i = 0; $i < 10000; ++$i) {
     $str = idate("U")+$i;
     $strarr[] = "{$i}->$str\r

";
 }
 $time2 = microtime(true);
 $time3 = $time2 - $time1;

 $time1 = microtime(true);
 for($i = 0; $i < 10000; ++$i) {
     $str = dec2s4(idate("U")+$i);
    $strarr[] = "{$i}->$str\r

";
}
$time2 = microtime(true);
echo "\r

10000 ( ):" . ($time2 - $time1 - $time3);

テスト結果
アルゴリズム1:0.1687250137329
アルゴリズム2:0.044965028762817
結論:アルゴリズム1は効率的には劣るが,md 5で生成された16進数を64進数に変換することができ,md 5を使用しなければならない環境で文字列を短縮することができる.
六、本文をまとめると、アップロード画像の名前変更に使用できるいくつかの方法について、キーポイントは10進数を64進数に変換して文字列の縮小を行うことである.
たとえばfast_を使用するuuidが生成した17ビットの数字は、64進数に変換して7ビットの文字しかありません.
具体的な使い方は、自分の状況に合わせて使い分けることができるので、皆さんの役に立つことを願っています.