>백엔드 개발 >PHP 튜토리얼 >php实现encode64编码类实例_PHP教程

php实现encode64编码类实例_PHP教程

WBOY
WBOY원래의
2016-07-13 10:00:48859검색

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程序设计有所帮助。

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/973111.htmlTechArticlephp实现encode64编码类实例 这篇文章主要介绍了php实现encode64编码类,实例分析了php实现encode64编码的技巧,具有一定参考借鉴价值,需要的朋友可...
성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.