首页 > php教程 > php手册 > php实现encode64编码类实例

php实现encode64编码类实例

WBOY
发布: 2016-06-13 09:09:57
原创
1362 人浏览过

php实现encode64编码类实例

 这篇文章主要介绍了php实现encode64编码类,实例分析了php实现encode64编码的技巧,具有一定参考借鉴价值,需要的朋友可以参考下

 

 

本文实例讲述了php实现encode64编码类。分享给大家供大家参考。具体如下:

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

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

//encode64编码可以同时取代encodeURI,encodeURIComponent,endode函数

//因为选取的这些字符都不会被编码.

class Encode64{

function code($str) {

$KEY = 'PaAwO65goUf7IK2vi9-xq8cFTEXLCDY1Hd3tV0ryzjbpN_BlnSs4mGRkQWMZJeuh';

$a = StrToBytes($str);

$len = count($a);

$res = $len % 3;

$s = "";$i = 2;$v = 0;

for (; $i

$v = $a[$i - 2] + ($a[$i - 1]

$s .= $KEY[$v & 0x3f];

$s .= $KEY[($v >> 6) & 0x3f];

$s .= $KEY[($v >> 12) & 0x3f];

$s .= $KEY[($v >> 18)];

}

if ($res == 1) {

$v = $a[$i - 2];

$s .= $KEY[$v & 0x3f];

$s .= $KEY[($v >> 6) & 0x3f];

} else if ($res == 2) {

$v = $a[$i - 2] + ($a[$i - 1]

$s .= $KEY[$v & 0x3f];

$s .= $KEY[($v >> 6) & 0x3f];

$s .= $KEY[($v >> 12) & 0x3f];

}

return $s;

}

function decode($codeStr) {

$KEY = 'PaAwO65goUf7IK2vi9-xq8cFTEXLCDY1Hd3tV0ryzjbpN_BlnSs4mGRkQWMZJeuh';

$dic = array();

for ($i = 0; $i

$dic[$KEY[$i]] = $i;

}

$len = strlen($codeStr);

$res = $len % 4;

$cLen = floor($len/4)*3;

if($res==2) $clen += 1;

elseif($res==3) $clen += 2;

$code = range(0,$clen);

$i = 3;$v = 0; $j = 0;

for (; $i

$v = $dic[$codeStr[$i - 3]];

$v += $dic[$codeStr[$i - 2]]

$v += $dic[$codeStr[$i - 1]]

$v += $dic[$codeStr[$i]]

$code[$j] = $v & 0xff;

$code[$j+1] = ($v >> 8) & 0xff;

$code[$j+2] = ($v >> 16) & 0xff;

$j += 3;

}

if ($res == 2) {

//正确的字节数肯定是余2或3, 没有1的情况, 如果出现, 舍弃.

$v = $dic[$codeStr[$i - 3]];

$v += $dic[$codeStr[$i - 2]]

$code[$j] = $v & 0xff;

} else if ($res == 3) {

$v = $dic[$codeStr[$i - 3]];

$v += $dic[$codeStr[$i - 2]]

$v += $dic[$codeStr[$i - 1]]

$code[$j] = $v & 0xff;

$code[$j+1] = ($v >> 8) & 0xff;

}

return BytesToStr($code);

}

}

function BytesToStr($bytes) {

$str = '';

foreach($bytes as $ch) {

$str .= chr($ch);

}

return iconv('UTF-16BE','utf-8',$str);

}

function StrToBytes($str) {

$str = iconv('utf-8','UTF-16BE',$str);

$len = strlen($str);

$bytes = array();

for($i=0;$i

$bytes[] = ord($str[$i]) ;

}

return $bytes;

}

?>

希望本文所述对大家的php程序设计有所帮助。

相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门推荐
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板