PHP和C#可共用的可逆加密算法详解
发布时间:2020-12-13 02:54:08 所属栏目:PHP教程 来源:网络整理
导读:《PHP实例:PHP和C#可共用的可逆加密算法详解》要点: 本文介绍了PHP实例:PHP和C#可共用的可逆加密算法详解,希望对您有用。如果有疑问,可以联系我们。 PHP实战 在一些项目中要求在php中生成加密,然后在asp.net中接受过来的暗码再解密,下面和大家分享一个P
《PHP实例:PHP和C#可共用的可逆加密算法详解》要点: PHP实战在一些项目中要求在php中生成加密,然后在asp.net中接受过来的暗码再解密,下面和大家分享一个PHP与asp.net C#可共用的可逆加密算法,感兴趣的可以参考参考. PHP实战php加密算法: PHP实战
<?php
class DES
{
var $key;
var $iv; //偏移量
function DES($key = '11001100',$iv=0 ) {
//key长度8例如:1234abcd
$this->key = $key;
if( $iv == 0 ) {
$this->iv = $key; //默认以$key 作为 iv
} else {
$this->iv = $iv; //mcrypt_create_iv ( mcrypt_get_block_size (MCRYPT_DES,MCRYPT_MODE_CBC),MCRYPT_DEV_RANDOM );
}
}
function encrypt($str) {
//加密,返回大写十六进制字符串
$size = mcrypt_get_block_size ( MCRYPT_DES,MCRYPT_MODE_CBC );
$str = $this->pkcs5Pad ( $str,$size );
return strtoupper( bin2hex( mcrypt_cbc(MCRYPT_DES,$this->key,$str,MCRYPT_ENCRYPT,$this->iv ) ) );
}
function decrypt($str) {
//解密
$strBin = $this->hex2bin( strtolower( $str ) );
$str = mcrypt_cbc( MCRYPT_DES,$strBin,MCRYPT_DECRYPT,$this->iv );
$str = $this->pkcs5Unpad( $str );
return $str;
}
function hex2bin($hexData) {
$binData = "";
for($i = 0; $i < strlen ( $hexData ); $i += 2) {
$binData .= chr ( hexdec ( substr ( $hexData,$i,2 ) ) );
}
return $binData;
}
function pkcs5Pad($text,$blocksize) {
$pad = $blocksize - (strlen ( $text ) % $blocksize);
return $text . str_repeat ( chr ( $pad ),$pad );
}
function pkcs5Unpad($text) {
$pad = ord ( $text {strlen ( $text ) - 1} );
if ($pad > strlen ( $text ))
return false;
if (strspn ( $text,chr ( $pad ),strlen ( $text ) - $pad ) != $pad)
return false;
return substr ( $text,- 1 * $pad );
}
}
?>
PHP实战asp.net程序代码: PHP实战
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Security.Cryptography;
using System.Text;
namespace WindowsFormsApplication1
{
/// <summary>
/// DES加密解密字符串
/// </summary>
public class DesEncryption
{
/// <summary>
/// DES加密字符串
/// </summary>
/// <param name="encryptString">待加密的字符串</param>
/// <param name="encryptKey">加密密钥,要求为8位</param>
/// <returns>加密成功返回加密后的字符串,失败返回null</returns>
public static string EncryptDES(string encryptString,string encryptKey = "11001100")
{
try
{
byte[] rgbKey = ASCIIEncoding.ASCII.GetBytes(encryptKey.Substring(0,8));
byte[] rgbIV = rgbKey;
byte[] inputByteArray = Encoding.UTF8.GetBytes(encryptString);
DESCryptoServiceProvider dCSP = new DESCryptoServiceProvider();
MemoryStream mStream = new MemoryStream();
CryptoStream cStream = new CryptoStream(mStream,dCSP.CreateEncryptor(rgbKey,rgbIV),CryptoStreamMode.Write);
cStream.Write(inputByteArray,inputByteArray.Length);
cStream.FlushFinalBlock();
StringBuilder ret = new StringBuilder();
foreach (byte b in mStream.ToArray())
{
ret.AppendFormat("{0:X2}",b);
}
ret.ToString();
return ret.ToString();
}
catch
{
return null;
}
}
/// <summary>
/// DES解密字符串
/// </summary>
/// <param name="decryptString">待解密的字符串</param>
/// <param name="decryptKey">解密密钥,要求为8位,和加密密钥相同</param>
/// <returns>解密成功返回解密后的字符串,失败返回null</returns>
public static string DecryptDES(string decryptString,string decryptKey = "11001100")
{
try
{
byte[] rgbKey = ASCIIEncoding.ASCII.GetBytes(decryptKey);
byte[] rgbIV = rgbKey;
byte[] inputByteArray = new byte[decryptString.Length / 2];
for (int x = 0; x < decryptString.Length / 2; x++)
{
int i = (Convert.ToInt32(decryptString.Substring(x * 2,2),16));
inputByteArray[x] = (byte)i;
}
DESCryptoServiceProvider DCSP = new DESCryptoServiceProvider();
MemoryStream mStream = new MemoryStream();
CryptoStream cStream = new CryptoStream(mStream,DCSP.CreateDecryptor(rgbKey,inputByteArray.Length);
cStream.FlushFinalBlock();
return Encoding.UTF8.GetString(mStream.ToArray());
}
catch
{
return null;
}
}
}
}
PHP实战以上就是PHP和C#可共用的可逆加密算法,希望对大家的学习有所赞助. 欢迎参与《PHP实例:PHP和C#可共用的可逆加密算法详解》讨论,分享您的想法,编程之家 52php.cn为您提供专业教程。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |