<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>幻想曲.Net &#187; des</title>
	<atom:link href="http://yibin.us/tag/des/feed" rel="self" type="application/rss+xml" />
	<link>http://yibin.us</link>
	<description>曾经沧海难为水，除却巫山不是云</description>
	<lastBuildDate>Tue, 15 May 2012 14:31:27 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.3.2</generator>
		<item>
		<title>真正兼容.net的php 3DES加解密</title>
		<link>http://yibin.us/archives/6307</link>
		<comments>http://yibin.us/archives/6307#comments</comments>
		<pubDate>Mon, 15 Jun 2009 08:16:31 +0000</pubDate>
		<dc:creator>幻想曲</dc:creator>
				<category><![CDATA[Develop]]></category>
		<category><![CDATA[des]]></category>
		<category><![CDATA[PHP]]></category>

		<guid isPermaLink="false">http://yibin.us/?p=6307</guid>
		<description><![CDATA[php中3des加密的结果与.Net/java不同的帖子与话题实在是太多了， 我前不久也在倒腾这些，不过今天已经搞定了，完全与.net中的兼容 直接拿去用吧。]]></description>
			<content:encoded><![CDATA[<p>php中3des加密的结果与.Net/java不同的帖子与话题实在是太多了，</p>
<p>我前不久也在倒腾这些，不过今天已经搞定了，完全与.net中的兼容</p>
<pre class="brush: php; title: ; notranslate">
&amp;lt;?php
class Crypt3Des
{
private $key = &amp;quot;&amp;quot;;
private $iv = &amp;quot;&amp;quot;;
/**
* 构造，传递二个已经进行base64_encode的KEY与IV
*
* @param string $key
* @param string $iv
*/
function __construct ($key, $iv)
{
if (empty($key) || empty($iv)) {
echo 'key and iv is not valid';
exit();
}
$this-&amp;gt;key = $key;
$this-&amp;gt;iv = $iv;
}
/**
*加密
* @param &amp;lt;type&amp;gt; $value
* @return &amp;lt;type&amp;gt;
*/
public function encrypt ($value)
{
$td = mcrypt_module_open(MCRYPT_3DES, '', MCRYPT_MODE_CBC, '');
$iv = base64_decode($this-&amp;gt;iv);
$value = $this-&amp;gt;PaddingPKCS7($value);
$key = base64_decode($this-&amp;gt;key);
mcrypt_generic_init($td, $key, $iv);
$ret = base64_encode(mcrypt_generic($td, $value));
mcrypt_generic_deinit($td);
mcrypt_module_close($td);
return $ret;
}
/**
*解密
* @param &amp;lt;type&amp;gt; $value
* @return &amp;lt;type&amp;gt;
*/
public function decrypt ($value)
{
$td = mcrypt_module_open(MCRYPT_3DES, '', MCRYPT_MODE_CBC, '');
$iv = base64_decode($this-&amp;gt;iv);
$key = base64_decode($this-&amp;gt;key);
mcrypt_generic_init($td, $key, $iv);
$ret = trim(mdecrypt_generic($td, base64_decode($value)));
$ret = $this-&amp;gt;UnPaddingPKCS7($ret);
mcrypt_generic_deinit($td);
mcrypt_module_close($td);
return $ret;
}
private function PaddingPKCS7 ($data)
{
$block_size = mcrypt_get_block_size('tripledes', 'cbc');
$padding_char = $block_size - (strlen($data) % $block_size);
$data .= str_repeat(chr($padding_char), $padding_char);
return $data;
}
private function UnPaddingPKCS7 ($text)
{
$pad = ord($text{strlen($text) - 1});
if ($pad &amp;gt; strlen($text)) {
return false;
}
if (strspn($text, chr($pad), strlen($text) - $pad) != $pad) {
return false;
}
return substr($text, 0, - 1 * $pad);
}
}
?&amp;gt;
</pre>
<pre>直接拿去用吧。</pre>
]]></content:encoded>
			<wfw:commentRss>http://yibin.us/archives/6307/feed</wfw:commentRss>
		<slash:comments>10</slash:comments>
		</item>
	</channel>
</rss>

