当前位置:Gxlcms > PHP教程 > php的encode64编码类

php的encode64编码类

时间:2021-07-01 10:21:17 帮助过:16人阅读

encode64可以获得最短的由26个英文大小写字母数字加上"-_"两个符号编码的数据, 这个个字串可以在网络自由传输, 无需考虑被自动转码引起的混乱. 缺点: 对于大字串太慢了, 原因不明, 可能PHP脚本本身就是慢, 所以它内置 很多函数, 这些函数如果用脚本来实现是不可忍受的. 而JavaScript就没这个问题, 脚本的速度快的多.

  1. //encode64编码可以同时取代encodeURI,encodeURIComponent,endode函数, 因为选取的这些字符都不会被编码.
  2. class Encode64{
  3. function code($str) {
  4. $KEY = 'PaAwO65goUf7IK2vi9-xq8cFTEXLCDY1Hd3tV0ryzjbpN_BlnSs4mGRkQWMZJeuh';
  5. $a = StrToBytes($str);
  6. $len = count($a);
  7. $res = $len % 3;
  8. $s = "";$i = 2;$v = 0;
  9. for (; $i < $len; $i += 3) {
  10. $v = $a[$i - 2] + ($a[$i - 1] << 8) + ($a[$i] << 16);
  11. $s .= $KEY[$v & 0x3f];
  12. $s .= $KEY[($v >> 6) & 0x3f];
  13. $s .= $KEY[($v >> 12) & 0x3f];
  14. $s .= $KEY[($v >> 18)];
  15. }
  16. if ($res == 1) {
  17. $v = $a[$i - 2];
  18. $s .= $KEY[$v & 0x3f];
  19. $s .= $KEY[($v >> 6) & 0x3f];
  20. } else if ($res == 2) {
  21. $v = $a[$i - 2] + ($a[$i - 1] << 8);
  22. $s .= $KEY[$v & 0x3f];
  23. $s .= $KEY[($v >> 6) & 0x3f];
  24. $s .= $KEY[($v >> 12) & 0x3f];
  25. }
  26. return $s;
  27. }
  28. function decode($codeStr) {
  29. $KEY = 'PaAwO65goUf7IK2vi9-xq8cFTEXLCDY1Hd3tV0ryzjbpN_BlnSs4mGRkQWMZJeuh';
  30. $dic = array();
  31. for ($i = 0; $i < 64; $i++) {
  32. $dic[$KEY[$i]] = $i;
  33. }
  34. $len = strlen($codeStr);
  35. $res = $len % 4;
  36. $cLen = floor($len/4)*3;
  37. if($res==2) $clen += 1;
  38. elseif($res==3) $clen += 2;
  39. $code = range(0,$clen);
  40. $i = 3;$v = 0; $j = 0;
  41. for (; $i < $len; $i += 4) {
  42. $v = $dic[$codeStr[$i - 3]];
  43. $v += $dic[$codeStr[$i - 2]] << 6;
  44. $v += $dic[$codeStr[$i - 1]] << 12;
  45. $v += $dic[$codeStr[$i]] << 18;
  46. $code[$j] = $v & 0xff;
  47. $code[$j+1] = ($v >> 8) & 0xff;
  48. $code[$j+2] = ($v >> 16) & 0xff;
  49. $j += 3;
  50. }
  51. if ($res == 2) {//正确的字节数肯定是余2或3, 没有1的情况, 如果出现, 舍弃.
  52. $v = $dic[$codeStr[$i - 3]];
  53. $v += $dic[$codeStr[$i - 2]] << 6;
  54. $code[$j] = $v & 0xff;
  55. } else if ($res == 3) {
  56. $v = $dic[$codeStr[$i - 3]];
  57. $v += $dic[$codeStr[$i - 2]] << 6;
  58. $v += $dic[$codeStr[$i - 1]] << 12;
  59. $code[$j] = $v & 0xff;
  60. $code[$j+1] = ($v >> 8) & 0xff;
  61. }
  62. return BytesToStr($code);
  63. }
  64. }
  65. function BytesToStr($bytes) {
  66. $str = '';
  67. foreach($bytes as $ch) {
  68. $str .= chr($ch);
  69. }
  70. return iconv('UTF-16BE','utf-8',$str);
  71. }
  72. function StrToBytes($str) {
  73. $str = iconv('utf-8','UTF-16BE',$str);
  74. $len = strlen($str);
  75. $bytes = array();
  76. for($i=0;$i<$len;$i++) {
  77. $bytes[] = ord($str[$i]) ;
  78. }
  79. return $bytes;
  80. }
  81. ?>

php

人气教程排行