php 업로드 이미지 이름 을 바 꾸 는 6 가지 해결 방법 에 대한 상세 한 소개
이것 은 그림 이나 파일 업로드 프로 세 스 가 결정 합 니 다.일반 사진 업로드 처리 과정 은 먼저 서버 에 사진 을 올 리 고 이름 을 바 꾼 후 데이터베이스 에 삽입 하 는 것 이다.즉,데이터 베이스 에서 쉽게 얻 을 수 있 는 자체 성장 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
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
VBS 에서 파일 이름 을 대량으로 바 꾸 고 작업 전에 기 존 파일 을 백업 합 니 다.핵심 함수 프로필 필요 매개 변수 설정 사용 방법: statue=true 시 접두사 추가 statue=false 시 접미사 추가 statue=number 시 질서 있 는 숫자 를 추가 하기 위해 서 입 니 다. st...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.