>백엔드 개발 >PHP 튜토리얼 >ph 값은 C#과 PHP 간의 TripleDES 암호화 및 암호 해독을 의미합니까?

ph 값은 C#과 PHP 간의 TripleDES 암호화 및 암호 해독을 의미합니까?

WBOY
WBOY원래의
2016-07-28 08:29:561313검색

C#의 공통 암호화 및 복호화 기사에서는 여러 가지 암호화 및 복호화 방법을 소개합니다. 그 중 하나는 대칭 암호화 알고리즘 DES를 사용하는 방법입니다. 이번에는 DES의 업그레이드 버전인 TripleDES에 대해 설명하겠습니다.

DES와 TripleDES의 관계에 대해서는 다음 블로그 게시물을 참고하세요.
대칭형 암호화 DES와 TripleDES

핵심 내용은 C#과 PHP에서 각각 TripleDES를 사용하여 상대방이 보낸 암호화된 내용을 둘 다 복호화할 수 있도록 하는 방법입니다.

더 이상 고민하지 않고 양쪽 끝의 코드로 직접 이동해 보겠습니다.

C# 코드

<code><span>using</span> System;
<span>using</span> System.Security.Cryptography;
<span>using</span> System.Text;

namespace TripleDes
{
    class Program
    {
        <span>static</span><span>void</span> Main(<span>string</span>[] args)
        {
            <span>//加密的字符串</span><span>string</span> source = <span>"Happy Father's Day!"</span>;

            <span>//用来加密的key 但是最终用在des加密的key</span><span>//是这个key的 md5 hash</span><span>string</span> sourceKey = <span>"home"</span>;

            <span>//获取原始key值的 md5 hash</span><span>byte</span>[] keyBytes = GetKeyMd5Hash(sourceKey);

            <span>string</span> encryptedStr = DesEncrypt(source, keyBytes);
            Console.WriteLine(<span>"encrypted string: "</span>+ encryptedStr);

            <span>string</span> decryptedStr = DesDecrypt(encryptedStr, keyBytes);
            Console.WriteLine(<span>"Decrypted String: "</span> + decryptedStr);
            Console.ReadKey();
        }

        <span><span>///</span><span><summary></span></span><span><span>///</span> 获取加密key的 md5 hash,最终DES加密的时候使用这个hash值</span><span><span>///</span><span></summary></span></span><span><span>///</span><span><param name="key"></span>原始key值<span></param></span></span><span><span>///</span><span><returns></span><span></returns></span></span><span>public</span><span>static</span><span>byte</span>[] <span>GetKeyMd5Hash</span>(<span>string</span> key)
        {
            MD5CryptoServiceProvider hashmd5 = <span>new</span> MD5CryptoServiceProvider();
            <span>byte</span>[] keyBytes = hashmd5.ComputeHash(UTF8Encoding.UTF8.GetBytes(key));
            hashmd5.Clear();

            <span>return</span> keyBytes;
        }

        <span><span>///</span><span><summary></span></span><span><span>///</span> TripleDES 加密</span><span><span>///</span><span></summary></span></span><span><span>///</span><span><param name="toEncrypt"></span><span></param></span></span><span><span>///</span><span><param name="privateKey"></span><span></param></span></span><span><span>///</span><span><returns></span><span></returns></span></span><span>public</span><span>static</span><span>string</span><span>DesEncrypt</span>(<span>string</span> toEncrypt, <span>byte</span>[] privateKey)
        {
            <span>byte</span>[] toEncryptArray = UTF8Encoding.UTF8.GetBytes(toEncrypt);

            TripleDESCryptoServiceProvider tdes = <span>new</span> TripleDESCryptoServiceProvider
            {
                Key = privateKey,
                Mode = CipherMode.ECB,
                Padding = PaddingMode.PKCS7
            };

            ICryptoTransform cTransform = tdes.CreateEncryptor();
            <span>byte</span>[] resultArray = cTransform.TransformFinalBlock(toEncryptArray, <span>0</span>, toEncryptArray.Length);
            tdes.Clear();

            <span>return</span> Convert.ToBase64String(resultArray, <span>0</span>, resultArray.Length);
        }

        <span><span>///</span><span><summary></span></span><span><span>///</span> TripleDES解密</span><span><span>///</span><span></summary></span></span><span><span>///</span><span><param name="toDecrypt"></span><span></param></span></span><span><span>///</span><span><param name="privateKey"></span><span></param></span></span><span><span>///</span><span><returns></span><span></returns></span></span><span>public</span><span>static</span><span>string</span><span>DesDecrypt</span>(<span>string</span> toDecrypt, <span>byte</span>[] privateKey)
        {
            <span>//先base64解密 因为加密的时候最后走了一道base64加密</span><span>byte</span>[] enBytes = Convert.FromBase64String(toDecrypt);

            TripleDESCryptoServiceProvider tdes = <span>new</span> TripleDESCryptoServiceProvider
            {
                Key = privateKey,
                Mode = CipherMode.ECB,
                Padding = PaddingMode.PKCS7
            };

            ICryptoTransform cTransform = tdes.CreateDecryptor();
            <span>byte</span>[] resultArray = cTransform.TransformFinalBlock(enBytes, <span>0</span>, enBytes.Length);
            tdes.Clear();

            <span>return</span> Encoding.UTF8.GetString(resultArray);

        }
    }
}
</code>

PHP 코드

<code><span><span><?php</span><span>/*
    TripleDES加密
*/</span><span><span>function</span><span>DesEncrypt</span><span>(<span>$data</span>)</span>
{</span><span>//Pad for PKCS7</span><span>$blockSize</span> = mcrypt_get_block_size(<span>'tripledes'</span>, <span>'ecb'</span>);
    <span>$len</span> = strlen(<span>$data</span>);
    <span>$pad</span> = <span>$blockSize</span> - (<span>$len</span> % <span>$blockSize</span>);
    <span>$data</span> .= str_repeat(chr(<span>$pad</span>), <span>$pad</span>);

    <span>$key</span> = <span>"home"</span>;
    <span>$key</span> = md5(<span>$key</span>,<span>TRUE</span>);
    <span>$key</span> .= substr(<span>$key</span>,<span>0</span>,<span>8</span>); <span>//comment this if you use 168 bits long key</span><span>//Encrypt data</span><span>$encData</span> = mcrypt_encrypt(<span>'tripledes'</span>, <span>$key</span>, <span>$data</span>, <span>'ecb'</span>); 
    <span>return</span> base64_encode(<span>$encData</span>);
}

 <span>/*
    TripleDES解密
 */</span><span><span>function</span><span>DesDecrypt</span><span>(<span>$data</span>)</span>
 {</span><span>$key</span> = <span>"home"</span>;
    <span>$key</span> = md5(<span>$key</span>, <span>TRUE</span>);
    <span>$key</span> .= substr(<span>$key</span>, <span>0</span>, <span>8</span>);

    <span>//Decrypt data</span><span>$fromBase64Str</span> = base64_decode(<span>$data</span>);
    <span>$decData</span> = mcrypt_decrypt(<span>'tripledes'</span>, <span>$key</span>, <span>$fromBase64Str</span>, <span>'ecb'</span>);

    <span>return</span><span>$decData</span>;
 }

 <span>/*
 测试
 */</span><span>$encryptStr</span> = DesEncrypt(<span>"Happy Father's Day!"</span>);     
    <span>echo</span><span>"encrypted string: $encryptStr</br>"</span>;
 <span>$decryptStr</span> = DesDecrypt(<span>$encryptStr</span>);
    <span>echo</span><span>"decrypted string: $decryptStr"</span>;
<span>?></span></span></code>

이런 방식으로 PHP는 C#으로 암호화된 내용을 복호화할 수 있고, C#에서도 암호화된 내용을 복호화할 수 있습니다. PHP 콘텐츠.

둘 다 TripleDES 암호화 알고리즘이지만 C#과 PHP에서 암호화에 사용되는 기본 모드와 패딩이 다릅니다. 각 언어에 제공되는 TripleDES를 직접 사용하면 양쪽 모두 동일한 키를 사용하게 됩니다. 동일한 콘텐츠를 암호화한 후에도 암호화 결과가 다르기 때문에 서로 해독할 수 없습니다.

다양한 언어로 사용되는 암호화 모드에 대한 자세한 내용은 Google에서 검색해 보세요. RSA 암호화 알고리즘과 마찬가지로 C#, JAVA 및 PHP는 서로 다른 키 형식을 사용합니다. JAVA는 ASN을 사용하고 C#은 XML을 사용하며 PHP는 PEM을 사용합니다. 이로 인해 서로 의사소통이 불가능해집니다.
p.s. 세 가지 중에서 RSA 상호 운용성을 위한 방법을 찾지 못했습니다.

참고 기사:

암호화 알고리즘 패턴 패딩

PHP 패딩 PKCS7

AES 암호화 문자열에서 PKCS7 패딩을 추가/제거하는 방법

PHP와 .NET 간 PCSK7 및 ECB를 사용한 Triple DES

오늘은 아버지의 날, 행복한 아빠의 날입니다!

').addClass('사전 번호 매기기').hide(); $(this).addClass('has-numbering').parent().append($numbering); for (i = 1; i ').text(i)); }; $numbering.fadeIn(1700); }); });

위에서는 ph 값의 의미를 포함하여 C#과 PHP 간의 TripleDES 암호화 및 암호 해독에 대해 소개합니다. PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.