可能重复:
PHP短散列类URL缩短网站
我需要一个函数,在这个函数中,我可以用唯一的字母数字标记制作url标记,我会使用uniqid
,但对于一个用户喜欢的标记来说,它太长了,我必须去掉uniqid
字符串的末尾多少,这样它会更短,但同时我可以在一秒钟内有1000个请求(所以每毫秒1个)。我知道uniqid
使用microtime()
来计算字符串。
这可能吗?或者我必须使用其他功能。如果我必须使用另一个功能,你能给我看一两个吗?
提前感谢!
md4似乎是最快的:http://www.php.net/manual/en/function.hash.php但产生32个字符的
crc32b是8个字符,仍然是中最快的散列之一
echo散列('rc32b','http://stackoverflow.com');
这是由luka8088在1000 Kb:上发布的性能结果
Results: (in microseconds)
1. md4 5307.912
2. md5 6890.058
3. crc32b 7298.946
4. crc32 7561.922
5. sha1 8886.098
6. tiger128,3 11054.992
7. haval192,3 11132.955
8. haval224,3 11160.135
9. tiger160,3 11162.996
10. haval160,3 11242.151
11. haval256,3 11327.981
12. tiger192,3 11630.058
13. haval128,3 11880.874
14. tiger192,4 14776.945
15. tiger128,4 14871.12
16. tiger160,4 14946.937
17. haval160,4 15661.954
18. haval192,4 15717.029
19. haval256,4 15759.944
20. adler32 15796.184
21. haval128,4 15887.022
22. haval224,4 16047.954
23. ripemd256 16245.126
24. haval160,5 17818.927
25. haval128,5 17887.115
26. haval224,5 18085.002
27. haval192,5 18135.07
28. haval256,5 18678.903
29. sha256 19020.08
30. ripemd128 20671.844
31. ripemd160 21853.923
32. ripemd320 22425.889
33. sha384 45102.119
34. sha512 45655.965
35. gost 57237.148
36. whirlpool 64682.96
37. snefru 80352.783
38. md2 705397.844
p.s.delivery过去对所有URI使用MD5(因此delicious.com/md5hash对任何URI)
你试过这样的东西吗?
$string = md5(rand());
如果它太长,你可以用substr()
来缩短它。我发现它很快。