Home  >  Article  >  Backend Development  >  Summary of Six Methods for Uploading and Renaming PHP Images

Summary of Six Methods for Uploading and Renaming PHP Images

WBOY
WBOYOriginal
2016-07-25 08:54:261570browse
  1. /*
  2. com_create_guid() is a function supported by the php5 version. For unsupported versions, you can define it yourself
  3. */
  4. function guid(){
  5. if (function_exists('com_create_guid')){
  6. return com_create_guid();
  7. }else{
  8. mt_srand((double)microtime()*10000);//optional for php 4.2.0 and up.
  9. echo(mt_rand());
  10. $charid = strtoupper(md5(uniqid( rand(), true)));
  11. $hyphen = chr(45);// "-"
  12. $uuid = chr(123)// "{"
  13. .substr($charid, 0, 8).$hyphen
  14. .substr($charid, 8, 4).$hyphen
  15. .substr($charid,12, 4).$hyphen
  16. .substr($charid,16, 4).$hyphen
  17. .substr($charid,20 ,12)
  18. .chr(125);// "}"
  19. return $uuid;
  20. }
  21. }
Copy code

2. MD5 Like guid, it will output a 32-character hexadecimal number. The difference is that guid is randomly generated, and md5 needs to be generated based on the input data. example:

  1. $str = "Hello";
  2. echo md5($str);
  3. ?>
Copy code

Output: 8b1a9953c4611296a827abf8c47804d7 Advantages: The output value can be controlled based on the input seed data. If the seed data is regular and non-repeating, the data can be protected through md5, which will cause great confusion; Disadvantages: 32-bit characters are too long; unique seed data needs to be provided; Usage: High concurrency, using seconds as the seed data, duplication will still occur.

  1. /*
  2. * Used in conjunction with the time() function, using the number of seconds from 1970 to the current time as the seed number
  3. */
  4. $str=time();
  5. echo md5($ str);
  6. ?>
Copy code

3. uniqid(): returns a 13 or 23-digit string For our purposes, uniqid() is like an improved version of md5(), especially since we can use differential identifiers as string prefixes, which can reduce the chance of repeated naming. For extreme situations such as non-high concurrency, it is recommended to use this function, which can already meet general needs. Detailed description: Definition: The uniqid() function generates a unique ID based on the current time in microseconds; Usage: uniqid(prefix,more_entropy); Note: prefix can add a prefix to the output string. The example is as follows. When the more_entropy parameter is true, a 23-bit string will be output.

  1. var_dump(uniqid());
  2. var_dump(uniqid("a"));
  3. ?>
Copy code

The output is: string(13) "51734aa562254" string(14) "a51734aa562257" Advantages: 13-bit string length is an acceptable file naming length; prefixes can be added, and the result contains data obfuscation, which can avoid back-referencing the original data; Disadvantages: Similar to md5, high concurrency, using seconds as the seed data, duplication will still occur. 3. Upgraded version plan 1. fast_uuid: returns 17 digits A bit like an incompletely customized version of uniqid(), the concept of "seed number starting time" that appears in this function is very enlightening. The default time used in time() and uniqid() is calculated from 1970, and the length is ten digits (1366512439). Using the "seed number starting time" can reduce this value, because what we actually need is only It can be a value that can grow automatically. After the start time is customized, in addition to reducing the length, it can also play a role in confusion.

  1. /*
  2. * The parameter suffix_len specifies how many random digits are appended to the generated ID value. The default value is 3
  3. * @param int suffix_len
  4. * @return string
  5. */
  6. function fast_uuid($suffix_len=3) {
  7. //! The starting time for calculating the seed number
  8. $being_timestamp = strtotime('2013-3-21');
  9. $time = explode(' ', microtime());
  10. $id = ($time[1 ] - $being_timestamp) . sprintf('%06u', substr($time[0], 2, 6));
  11. if ($suffix_len > 0)
  12. {
  13. $id .= substr(sprintf('%010u ', mt_rand()), 0, $suffix_len);
  14. }
  15. return $id;
  16. }
Copy code

Output: 29832412631099013 2. time()+random number The use of random numbers has already appeared in the above example, in order to solve multiple requests that occur in one second. Two functions are provided:

  1. function random($length) {
  2. $hash = '';
  3. $chars = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789abcdefghijklmnopqrstuvwxyz';
  4. $max = strlen($chars ) - 1;
  5. PHP_VERSION < ' 4.2.0' && mt_srand((double)microtime() * 1000000);
  6. for($i = 0; $i < $length; $i++) {
  7. $hash .= $chars[mt_rand(0, $max )];
  8. }
  9. return $hash;
  10. }
  11. function random2($length, $numeric = 0) {
  12. PHP_VERSION < '4.2.0' ? mt_srand((double)microtime() * 1000000) : mt_srand() ;
  13. $seed = base_convert(md5(print_r($_SERVER, 1).microtime()), 16, $numeric ? 10 : 35);
  14. $seed = $numeric ? (str_replace('0', '', $ seed).'012340567890') : ($seed.'zZ'.strtoupper($seed));
  15. $hash = '';
  16. $max = strlen($seed) - 1;
  17. for($i = 0; $i < $length; $i++) {
  18. $hash .= $seed[mt_rand(0, $max)];
  19. }
  20. return $hash;
  21. }
  22. ?>
Copy code

four ,The final proposal Idea: userid+second+random number. Among them, "userid+second" is converted from decimal to 64, reducing the number of digits. illustrate: 1. userid: The maximum value of "ZZZZ" in hexadecimal is converted to decimal equal to "16777215", and the maximum value of "ZZZ" converted to decimal is equal to "262143"; 2. Seconds: Set your own time starting point. $less=time()-strtotime(’2012-4-21′) is converted to hexadecimal “1SpRe”, 5 digits $less=time()-strtotime(’2013-3-21′) is converted to hexadecimal “_jHY”, 4 digits 3. Random number: Use random(3) to generate a 3-digit random number. Final result: 4-digit userid + 4-digit second + 3-digit random number = 11-digit string. Although the results look similar to uniqid(), the robustness is improved. 1 2 Next Page Last Page



Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn