php 업로드 이미지 이름 을 바 꾸 는 6 가지 해결 방법 에 대한 상세 한 소개

1.적용 장면:데이터베이스 에서 되 돌아 오 는 자체 증가 숫자 를 사용 하여 업로드 그림 의 이름 을 바 꿀 수 없습니다.
이것 은 그림 이나 파일 업로드 프로 세 스 가 결정 합 니 다.일반 사진 업로드 처리 과정 은 먼저 서버 에 사진 을 올 리 고 이름 을 바 꾼 후 데이터베이스 에 삽입 하 는 것 이다.즉,데이터 베이스 에서 쉽게 얻 을 수 있 는 자체 성장 id 는 올 린 그림 의 이름 을 바 꾸 는 데 사용 할 수 없 으 며,파일 이름 의 중복 을 피 할 수 있 으 며,데이터 베이스 에서 최대 id 와 1 을 가 져 오 는 방식 으로 데이터 베 이 스 를 연결 하 는 횟수 를 증가 시 켜 높 은 병행 과 데이터 양 이 많은 경우 에는 적용 되 지 않 는 다.
2.일반적인 방안:
1,guid:32 문자 16 진수.형식:GUID 의 형식 은"xxxxxxxx-xxxx-xxxx-xxxxxxxxxxxxxxxxx"이 며,그 중에서 각 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 비트 문자 가 너무 깁 니 다.중복 되 지 않 는 피 드 데 이 터 를 제공 해 야 합 니 다.용법:높 은 병발,초 를 피 드 데이터 로 하여 중복 현상 이 나타 날 수 있 습 니 다.4567913)3,유 니 키 드():13 또는 23 개의 문자열 을 되 돌려 줍 니 다.우리 의 목적 에 있어 서 유 니 키 드()는 md5()의 개선 판 과 같 습 니 다.특히 우 리 는 차이 점 표 지 를 문자열 접두사 로 사용 하여 중복 이름 이 나타 날 확률 을 낮 출 수 있 습 니 다.높 지 않 은 병발 등 극단 적 인 상황 에 대해 서 는 이 함 수 를 사용 하 는 것 을 추천 합 니 다.이미 일반적인 수 요 를 만족 시 킬 수 있 습 니 다.상세 설명,정의:uniqid()함 수 는 현재 시간 을 초 단위 로 계산 하여 유일한 ID 를 생 성 합 니 다.용법:uniqid(prefix,moreentropy)설명:prefix 는 출력 문자열 에 접 두 사 를 추가 할 수 있 습 니 다.예 를 들 어 다음 과 같 습 니 다.moreentropy 인자 가 true 일 때 23 비트 문자열 을 출력 합 니 다.

<?php
/*
* time() , 1970 。
*/
$str=time();
echo md5($str);
?>
출력 결 과 는 다음 과 같 습 니 다.

<?php
var_dump(uniqid());
var_dump(uniqid("a"));
?>
장점:13 비트 문자열 길이 로 받 아들 일 수 있 는 파일 이름 길이 입 니 다.접 두 사 를 추가 할 수 있 습 니 다.결 과 는 데이터 가 혼 란 스 러 워 서 원본 데 이 터 를 반추 하 는 것 을 피 할 수 있 습 니 다.단점:md5 와 비슷 하고 높 은 병발,초 를 피 드 데이터 로 하여 중복 현상 이 나타 날 수 있 습 니 다.
3.업그레이드 버 전 방안:
1,fast_uid:17 자리 숫자 를 되 돌려 줍 니 다.약간 유 니 키 드()의 불완전한 맞 춤 형 판 과 같 습 니 다.이 함수 에 나타 난'피 드 수 시작 시간'개념 은 시사 적 입 니 다.time()과 유 니 키 드()에서 기본적으로 사용 하 는 시간 은 1970 년 부터 계산 되 었 습 니 다.길 이 는 10 비트(1366512439)입 니 다.'피 드 수 시작 시간'을 사용 하면 이 수 치 를 줄 일 수 있 습 니 다.왜냐하면 우리 가 실제로 필요 로 하 는 것 은 자동 으로 증가 할 수 있 는 수치 일 뿐 입 니 다.시작 시간 사용자 정의 이후 길 이 를 줄 이 는 것 외 에 도 헷 갈 리 는 역할 을 할 수 있 습 니 다.

string(13) "51734aa562254" string(14) "a51734aa562257"
출력,

/*
* 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;
    }
2,time()+난수:
상례 에서 이미 랜 덤 수의 사용 이 발생 한 것 은 1 초 에 발생 하 는 여러 번 의 요청 을 해결 하기 위해 서 이다.두 개의 함 수 를 다음 과 같이 제공 합 니 다.

29832412631099013
4.최종 방안:
사고방식:userid+초+난수.그 중에서'userid+초'10 진법 은 64 진법 으로 바 꾸 고 자릿수 를 줄인다.
설명:1.userid:64 진법 의 최대 값 인'ZZZ'를 10 진법 으로 전환 하 는 것 은'167777215'와 같 고'ZZZ'를 10 진법 으로 전환 하 는 최대 치 는'262143'과 같다.2,초:자신의 시간 시작 점 을 설정 합 니 다.$less=time()-strtotime('2012-4-21'); 64 진수"1SPRE",5 비트$less=time()-startotime("2013-3-21")로 변환 합 니 다.64 진법 으로 변환"jHY“;4 위 3,난수:random(3)을 사용 하여 3 자리 난수 생 성;
최종 결과:4 비트 userid+4 비트 초+3 비트 랜 덤 수=11 비트 문자열.유 니 키 드()결과 와 비슷 해 보이 지만 강도 가 높 아 졌 다.
5,10 진 회전 64 진 알고리즘:
1.알고리즘 1:

<?php
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;
}
?>
2,알고리즘 2:

View Code

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
<br />e:" . hex10to64($a);
echo "\r
<br />e:" . hex64to10(hex10to64($a));

3,알고리즘 효율 테스트:

View Code

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

4,테스트 결과 알고리즘 1:0.1687250137329 알고리즘 2:0.0449650287628175,결론:알고리즘 1 은 효율 이 떨 어 지지 만 md5 가 생 성 한 16 진 을 64 진 으로 전환 시 켜 md5 를 사용 해 야 하 는 환경 에서 문자열 을 단축 시 킬 수 있 습 니 다.
6.본 고 는 사진 을 올 리 고 이름 을 바 꾸 는 데 사용 할 수 있 는 몇 가지 방법 과 관련 되 는데 그 중에서 관건 은 10 진법 을 64 진법 으로 바 꾸 어 문자열 을 줄 이 는 것 이다.예 를 들 어 fast 를 사용 합 니 다.uid 에서 생 성 된 17 자리 숫자 는 64 진수 로 7 자리 문자 만 변환 합 니 다.구체 적 으로 사용 하면 자신의 상황 에 따라 유연 하 게 사용 할 수 있 으 니 도움 이 되 기 를 바 랍 니 다.
참고 문헌:
1,GUID 바 이 두 백과:http://baike.baidu.com/view/185358.htm2,com_create_guid()공식 가이드:http://www.php.net/manual/zh/function.com-create-guid.php3,MD5()함수 설명:http://www.w3school.com.cn/php/func_string_md5.asp 4,time()함수 설명:http://www.w3school.com.cn/php/func_date_time.asp 5,uniqid()함수 설명:http://www.w3school.com.cn/php/func_misc_uniqid.asp

좋은 웹페이지 즐겨찾기