当前位置: 首页 > 图文教程 > 网络编程 > PHP > php中3des加密(完全与.net中的兼容)

PHP
PHP5中PDO的简单使用
更好的构造开发模板 五种PHP设计模式
PHP和AJAX打造高级RSS聚合器
跟我来学PHP5:session会话的使用和分析
构建可配置PHP应用程序的正确方式
在PHP中全面阻止SQL注入式攻击之一
在PHP中全面阻止SQL注入式攻击之二
在PHP中全面阻止SQL注入式攻击之三
7种流行PHP集成开发工具(IDE)的比较
PHP中的XML应用
PHP会话——session 时间设定使用入门
PHP对GB编码动态转UTF-8几种方法评测
确保PHP安全,不能违反的四条安全规则
如何利用PHP会话显示出当前在线的用户
PHP开发实例:创建PDF中文文档的程序代码
动态网页技术PHP的数组处理函数库
一贴学会PHP 为落伍的MJJ们量身定做的教程
PHP生成RSS类 (PHP类)
基于PHP和AJAX创建RSS聚合器 (1)
PHP实例——PHP创建动态图像

PHP 中的 php中3des加密(完全与.net中的兼容)


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-28   浏览: 113 ::
收藏到网摘: n/a

php中3des加密的结果与.Net/java不同的帖子与话题实在是太多了,我前不久也在倒腾这些,不过今天已经搞定了,完全与.net中的兼容

01.<?php

02.class Crypt3Des

03.{

04.private $key = "";

05.private $iv = "";

06./**

07.* 构造,传递二个已经进行base64_encode的KEY与IV

08.*

09.* @param string $key

10.* @param string $iv

11.*/

12.function __construct ($key, $iv)

13.{

14.if (empty($key) || empty($iv)) {

15.echo 'key and iv is not valid';

16.exit();

17.}

18.$this->key = $key;

19.$this->iv = $iv;

20.}

21./**

22.*加密

23.* @param <type> $value

24.* @return <type>

25.*/

26.public function encrypt ($value)

27.{

28.$td = mcrypt_module_open(MCRYPT_3DES, '', MCRYPT_MODE_CBC, '');

29.$iv = base64_decode($this->iv);

30.$value = $this->PaddingPKCS7($value);

31.$key = base64_decode($this->key);

32.mcrypt_generic_init($td, $key, $iv);

33.$ret = base64_encode(mcrypt_generic($td, $value));

34.mcrypt_generic_deinit($td);

35.mcrypt_module_close($td);

36.return $ret;

37.}

38./**

39.*解密

40.* @param <type> $value

41.* @return <type>

42.*/

43.public function decrypt ($value)

44.{

45.$td = mcrypt_module_open(MCRYPT_3DES, '', MCRYPT_MODE_CBC, '');

46.$iv = base64_decode($this->iv);

47.$key = base64_decode($this->key);

48.mcrypt_generic_init($td, $key, $iv);

49.$ret = trim(mdecrypt_generic($td, base64_decode($value)));

50.$ret = $this->UnPaddingPKCS7($ret);

51.mcrypt_generic_deinit($td);

52.mcrypt_module_close($td);

53.return $ret;

54.}

55.private function PaddingPKCS7 ($data)

56.{

57.$block_size = mcrypt_get_block_size('tripledes', 'cbc');

58.$padding_char = $block_size - (strlen($data) % $block_size);

59.$data .= str_repeat(chr($padding_char), $padding_char);

60.return $data;

61.}

62.private function UnPaddingPKCS7 ($text)

63.{

64.$pad = ord($text{strlen($text) - 1});

65.if ($pad > strlen($text)) {

66.return false;

67.}

68.if (strspn($text, chr($pad), strlen($text) - $pad) != $pad) {

69.return false;

70.}

71.return substr($text, 0, - 1 * $pad);

72.}

73.}

74.?>