php数据加密和解密 php数据加密和解密的区别

请教php源码加密及解密问题base64 可加可解 。md5 不可解
2种PHP的源码加密方式,此加密方法支持任意PHP版 。
注意,加密后的PHP代码无需第三方工具解密,像往常一样 , 直接运行即可 。
复制代码 代码如下:
?php
function encode_file_contents($filename) {$type=strtolower(substr(strrchr($filename,'.'),1));if ('php' == $typeis_file($filename)is_writable($filename)) { // 如果是PHP文件 并且可写 则进行压缩编码$contents = file_get_contents($filename); // 判断文件是否已经被编码处理$contents = php_strip_whitespace($filename);// 去除PHP头部和尾部标识
$headerPos = strpos($contents,'?php');
$footerPos = strrpos($contents,'?');
$contents = substr($contents, $headerPos5, $footerPos - $headerPos);$encode = base64_encode(gzdeflate($contents)); // 开始编码$encode = '?php'."\n eval(gzinflate(base64_decode("."'".$encode."'".")));\n\n?";return file_put_contents($filename, $encode);}
return false;
}
//调用函数
$filename = 'dam.php';
encode_file_contents($filename);
echo "OK,加密完成!"
?
加密方式2:
复制代码 代码如下:
?php
function RandAbc($length = "") { // 返回随机字符串$str = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz";return str_shuffle($str);
}
$filename = 'index.php'; //要加密的文件
$T_k1 = RandAbc(); //随机密匙1
$T_k2 = RandAbc(); //随机密匙2
$vstr = file_get_contents($filename);
$v1 = base64_encode($vstr);
$c = strtr($v1, $T_k1, $T_k2); //根据密匙替换对应字符 。
$c = $T_k1.$T_k2.$c;
$q1 = "O00O0O";
$q2 = "O0O000";
$q3 = "O0OO00";
$q4 = "OO0O00";
$q5 = "OO0000";
$q6 = "O00OO0";
$s = '$'.$q6.'=urldecode("n1zb/ma5\vt0i28-pxuqy*6lrkdg9_ehcswo4 f37j");$'.$q1.'=$'.$q6.'{3}.$'.$q6.'{6}.$'.$q6.'{33}.$'.$q6.'{30};$'.$q3.'=$'.$q6.'{33}.$'.$q6.'{10}.$'.$q6.'{24}.$'.$q6.'{10}.$'.$q6.'{24};$'.$q4.'=$'.$q3.'{0}.$'.$q6.'{18}.$'.$q6.'{3}.$'.$q3.'{0}.$'.$q3.'{1}.$'.$q6.'{24};$'.$q5.'=$'.$q6.'{7}.$'.$q6.'{13};$'.$q1.'.=$'.$q6.'{22}.$'.$q6.'{36}.$'.$q6.'{29}.$'.$q6.'{26}.$'.$q6.'{30}.$'.$q6.'{32}.$'.$q6.'{35}.$'.$q6.'{26}.$'.$q6.'{30};eval($'.$q1.'("'.base64_encode('$'.$q2.'="'.$c.'";eval(\'?\'.$'.$q1.'($'.$q3.'($'.$q4.'($'.$q2.',$'.$q5.'*2),$'.$q4.'($'.$q2.',$'.$q5.',$'.$q5.'),$'.$q4.'($'.$q2.',0,$'.$q5.'))));').'"));';$s = '?php '."\n".$s."\n".' ?';
//echo $s;
// 生成 加密后的PHP文件
$fpp1 = fopen('temp_'.$filename, 'w');
fwrite($fpp1, $s) or die('写文件错误');
?
【php数据加密和解密 php数据加密和解密的区别】其实,PHP加密源码方式有很多,譬如,免费的微盾PHP加密,还有搞的在线加密,只是phpjm更复杂点而已 。
另外 , 分享一个 PHP类,它能对 文本的内容进行 二进制加密 与 解密,代码如下:
复制代码 代码如下:
?php
class text_auth
{
var $n_iter;
function text_auth()
{
$this-setIter(32);
}
function setIter($n_iter)
{
$this-n_iter = $n_iter;
}
function getIter()
{
return $this-n_iter;
}
function encrypt($data, $key)
{
$n = $this-_resize($data, 4);
$data_long[0]= $n;
$n_data_long= $this-_str2long(1, $data, $data_long);$n = count($data_long);
if (($n1) == 1) {
$data_long[$n] = chr(0);
$n_data_long;
}
$this-_resize($key, 16, true);
if ( '' == $key )
$key = '0000000000000000';
$n_key_long = $this-_str2long(0, $key, $key_long);$enc_data=https://www.04ip.com/post/'';
$w= array(0, 0);
$j= 0;
$k= array(0, 0, 0, 0);
for ($i = 0; $i$n_data_long;$i) {
if ($j4 = $n_key_long) {
$k[0] = $key_long[$j];
$k[1] = $key_long[$j1];
$k[2] = $key_long[$j2];
$k[3] = $key_long[$j3];
} else {
$k[0] = $key_long[$j % $n_key_long];
$k[1] = $key_long[($j1) % $n_key_long];$k[2] = $key_long[($j2) % $n_key_long];$k[3] = $key_long[($j3) % $n_key_long];}
$j = ($j4) % $n_key_long;
$this-_encipherLong($data_long[$i], $data_long[$i], $w, $k);$enc_data .= $this-_long2str($w[0]);
$enc_data .= $this-_long2str($w[1]);
}
return $enc_data;
}
function decrypt($enc_data, $key)
{
$n_enc_data_long = $this-_str2long(0, $enc_data, $enc_data_long);$this-_resize($key, 16, true);
if ( '' == $key )
$key = '0000000000000000';
$n_key_long = $this-_str2long(0, $key, $key_long);$data=https://www.04ip.com/post/'';
$w= array(0, 0);
$j= 0;
$len= 0;
$k= array(0, 0, 0, 0);
$pos= 0;
for ($i = 0; $i$n_enc_data_long; $i= 2) {if ($j4 = $n_key_long) {
$k[0] = $key_long[$j];
$k[1] = $key_long[$j1];
$k[2] = $key_long[$j2];
$k[3] = $key_long[$j3];
} else {
$k[0] = $key_long[$j % $n_key_long];
$k[1] = $key_long[($j1) % $n_key_long];$k[2] = $key_long[($j2) % $n_key_long];$k[3] = $key_long[($j3) % $n_key_long];}
$j = ($j4) % $n_key_long;
$this-_decipherLong($enc_data_long[$i], $enc_data_long[$i1], $w, $k);if (0 == $i) {
$len = $w[0];
if (4 = $len) {
$data .= $this-_long2str($w[1]);
} else {
$data .= substr($this-_long2str($w[1]), 0, $len % 4);}
} else {
$pos = ($i - 1) * 4;
if ($pos4 = $len) {
$data .= $this-_long2str($w[0]);
if ($pos8 = $len) {
$data .= $this-_long2str($w[1]);
} elseif ($pos4$len) {
$data .= substr($this-_long2str($w[1]), 0, $len % 4);}
} else {
$data .= substr($this-_long2str($w[0]), 0, $len % 4);}
}
}
return $data;
}
function _encipherLong($y, $z, $w, $k)
{
$sum= (integer) 0;
$delta= 0x9E3779B9;
$n= (integer) $this-n_iter;
while ($n--0) {
$y= $this-_add($y,
$this-_add($z4 ^ $this-_rshift($z, 5), $z) ^$this-_add($sum, $k[$sum3]));
$sum= $this-_add($sum, $delta);
$z= $this-_add($z,
$this-_add($y4 ^ $this-_rshift($y, 5), $y) ^$this-_add($sum, $k[$this-_rshift($sum, 11)3]));}
$w[0] = $y;
$w[1] = $z;
}
function _decipherLong($y, $z, $w, $k)
{
$sum= 0xC6EF3720;
$delta= 0x9E3779B9;
$n= (integer) $this-n_iter;
while ($n--0) {
$z= $this-_add($z,
-($this-_add($y4 ^ $this-_rshift($y, 5), $y) ^$this-_add($sum, $k[$this-_rshift($sum, 11)3])));$sum= $this-_add($sum, -$delta);
$y= $this-_add($y,
-($this-_add($z4 ^ $this-_rshift($z, 5), $z) ^$this-_add($sum, $k[$sum3])));
}
$w[0] = $y;
$w[1] = $z;
}
function _resize($data, $size, $nonull = false){
$n= strlen($data);
$nmod= $n % $size;
if ( 0 == $nmod )
$nmod = $size;
if ($nmod0) {
if ($nonull) {
for ($i = $n; $i$n - $nmod$size;$i) {$data[$i] = $data[$i % $n];
}
} else {
for ($i = $n; $i$n - $nmod$size;$i) {$data[$i] = chr(0);
}
}
}
return $n;
}
function _hex2bin($str)
{
$len = strlen($str);
return pack('H' . $len, $str);
}
function _str2long($start, $data, $data_long){
$n = strlen($data);
$tmp= unpack('N*', $data);
$j= $start;
foreach ($tmp as $value)
$data_long[$j] = $value;
return $j;
}
function _long2str($l)
{
return pack('N', $l);
}
function _rshift($integer, $n)
{
if (0xffffffff$integer || -0xffffffff$integer) {$integer = fmod($integer, 0xffffffff1);}
if (0x7fffffff$integer) {
$integer -= 0xffffffff1.0;
} elseif (-0x80000000$integer) {
$integer= 0xffffffff1.0;
}
if (0$integer) {
$integer = 0x7fffffff;
$integer = $n;
$integer |= 1(31 - $n);
} else {
$integer = $n;
}
return $integer;
}
function _add($i1, $i2)
{
$result = 0.0;
foreach (func_get_args() as $value) {
if (0.0$value) {
$value -= 1.00xffffffff;
}
$result= $value;
}
if (0xffffffff$result || -0xffffffff$result) {$result = fmod($result, 0xffffffff1);
}
if (0x7fffffff$result) {
$result -= 0xffffffff1.0;
} elseif (-0x80000000$result) {
$result= 0xffffffff1.0;
}
return $result;
}
}
?
使用方法参考如下:
// 加密过程
view sourceprint?
$text_file = S_ROOT . './456.php';
$str = @file_get_contents($text_file);
require_once S_ROOT . "./text_auth.php";
$text_auth = new text_auth(64);
$str = $text_auth-encrypt($str, "qianyunlai.com");$filename = S_ROOT . './789.php'; // 加密后的文本为二进制,普通的文本编辑器无法正常查看file_put_contents($filename, $str);
// 解密过程
view sourceprint
?01 $text_file = S_ROOT . './789.php';
$str = @file_get_contents($text_file);
require_once S_ROOT . "./text_auth.php";
$text_auth = new text_auth(64);
$str = $text_auth-decrypt($str, "qianyunlai.com");$filename = S_ROOT . './456.php';
file_put_contents($filename, $str);
PHP常用加密解密方法作者/上善若水
1.md5(string $str,bool $flag = false);
$flag = false 默认返回32位php数据加密和解密的16进至数据散列值
$flag = true返回原始流数据
2.sha1($string,$flag = false)
$flag = false 默认返回40位的16进至数据散列值
true返回原始流数据
3.hash(string $algo,srting $str,bool $flag);
$algo : 算法名称php数据加密和解密 , 可通过hash_algos()函数获取所有hash加密的算法
如php数据加密和解密:md5,sha1等,采用md5,sha1加密所得结果和1,2两种方式结 果相同 。
$flag = false 默认返回16进至的数据散列值,具体长度根据算法不同
而不同 。
true返回原始流数据 。
4.crypt(string $str,$string $salt)php数据加密和解密;
函数返回使用 DES、Blowfish 或 MD5 算法加密的字符串 。
具体算法依赖于PHP检查之后支持的算法和$salt的格式和长度,当 然具体结果也和操作系统有关 。比较结果采用 hash_equals($crypted,crypt($input,$salt));//且salt值相同
Password_verify($str,$crypted);
5.password_hash ( string $str, integer $algo [, array $options ] )
函数返回哈希加密后的密码字符串,password_hash() 是crypt()的 一个简单封装
$algo : 算法 PASSWORD_DEFAULT ,PASSWORD_BCRYPT
$options = [
“cost”=10,//指明算法递归的层数,
“salt”=“xxadasdsad”//加密盐值 , 即将被遗 弃,采用系统自动随机生成安全性更高
];
使用的算法、cost 和盐值作为哈希的一部分返回
Password_verify($str,$hashed);
6.base64_encode(string $str)
设计此种编码是为php数据加密和解密了使二进制数据可以通过非纯 8-bit 的传输层 传输,例如电子邮件的主体 。base64_decode(string $encoded)
可以进行解码;
7.mcrypt_encrypt ( string $cipher , string $key , string $data ,
string $mode [, string $iv ] )
mcrypt_decrypt ( string $cipher , string $key , string $crypted ,
string $mode [, string $iv ] )
$ciper:加密算法,mcrypt_list_algorithms()可以获取该函数所有支持的算法
如MCRYPT_DES(“des”),MCRYPT_RIJNDAEL_128(“rijndael-128”);
$mode : 加密模式,mcrypt_list_modes()获取所有支持的加密模式,ecb,cbc
$key: 加密的秘钥,mcrypt_get_key_size ( string $cipher , string $mode )
获取指定的算法和模式所需的密钥长度 。$key要满足这个长度,如果长 度无效会报出警告 。
$iv : 加密的初始向量,可通过mcrypt_create_iv ( int $size [, int $source = MCRYPT_DEV_URANDOM ] ),
Iv的参数size:
通过mcrypt_get_iv_size ( string $cipher , string $mode )获取
Iv 的参数source:
初始向量数据来源 。可选值有: MCRYPT_RAND (系统随机数生成 器), MCRYPT_DEV_RANDOM (从 /dev/random 文件读取数据) 和MCRYPT_DEV_URANDOM (从 /dev/urandom 文件读取数据) 。在 Windows 平台 , PHP 5.3.0 之前的版本中,仅支持 MCRYPT_RAND 。
请注意,在 PHP 5.6.0 之前的版本中, 此参数的默认值 为 MCRYPT_DEV_RANDOM 。
Note: 需要注意的是 , 如果没有更多可用的用来产生随机数据的信息,那么 MCRYPT_DEV_RANDOM 可能进入阻塞状态 。
$data : 要加密的字符串数据
php SHA256WithRSA签名验签&加密解密使用:
$pri_key ="";
$pub_key = "";
$char = '方方块儿';//要加密的字符
$sign = $this-RsaEncrypt($char,$pri_key);//加密结果
$result = $this-RsaDecrypt($sign,$pub_key);//对加密结果进行解密
加密:
public function RsaEncrypt($str,$pri_key){
$pi_key =openssl_pkey_get_private($pri_key);
if(!$pi_key)return false;//秘钥不可用
openssl_private_encrypt($str,$encrypted,$pi_key);
$encrypted =base64_encode($encrypted);
return $encrypted;
}
解密:
public function RsaDecrypt($str,$pub_key){
$pu_key =openssl_pkey_get_public($pub_key);
if(!$pu_key)return false;//秘钥不可用
openssl_public_decrypt(base64_decode($str),$decrypted,$pu_key);
return $decrypted;
}
注:开启PHP的php_openssl扩展
PHP对称加密-AES 对称加解密算法中php数据加密和解密,当前最为安全php数据加密和解密的是 AES 加密算法(以前应该是是 DES 加密算法),PHP 提供php数据加密和解密了两个可以用于 AES 加密算法的函数簇: Mcrypt和OpenSSL。
其中 Mcrypt 在 PHP 7.1.0 中被弃用(The Function Mycryptis Deprecated),在 PHP 7.2.0 中被移除,所以即可起你应该使用 OpenSSL 来实现 AES 的数据加解密 。
在一些场景下,php数据加密和解密我们不能保证两套通信系统都使用了相函数簇去实现加密算法 , 可能 siteA 使用了最新的 OpenSSL 来实现了 AES 加密,但作为第三方服务的 siteB 可能仍在使用 Mcrypt 算法 , 这就要求我们必须清楚 Mcrypt 同 OpenSSL 之间的差异,以便保证数据加解密的一致性 。
下文中我们将分别使用 Mcrypt 和 OpenSSL 来实现 AES-128/192/256-CBC加解密 , 二者同步加解密的要点为:
协同好以上两点,就可以让 Mcrypt 和 OpenSSL 之间一致性的对数据进行加解密 。
AES 是当前最为常用的安全对称加密算法 , 关于对称加密这里就不在阐述了 。
AES 有三种算法,主要是对数据块的大小存在区别:
AES-128:需要提供 16 位的密钥 key
AES-192:需要提供 24 位的密钥 key
AES-256:需要提供 32 位的密钥 key
AES 是按数据块大?。?28/192/256)对待加密内容进行分块处理的,会经常出现最后一段数据长度不足的场景,这时就需要填充数据长度到加密算法对应的数据块大小 。
主要的填充算法有填充 NUL("0") 和 PKCS7,Mcrypt 默认使用的 NUL("0") 填充算法,当前已不被推荐,OpenSSL 则默认模式使用 PKCS7 对数据进行填充并对加密后的数据进行了 base64encode 编码,所以建议开发中使用 PKCS7 对待加密数据进行填充,已保证通用性(alipay sdk 中虽然使用了 Mcrypt 加密簇,但使用 PKCS7 算法对数据进行了填充,这样在一定程度上亲和了 OpenSSL 加密算法) 。
Mcrypt 的默认填充算法 。NUL 即为 Ascii 表的编号为 0 的元素 , 即空元素,转移字符是 "\0",PHP 的 pack 打包函数在 'a' 模式下就是以 NUL 字符对内容进行填充的 , 当然,使用 "\0" 手动拼接也是可以的 。
OpenSSL的默认填充算法 。下面我们给出 PKCS7 填充算法 PHP 的实现:
默认使用 NUL("\0") 自动对待加密数据进行填充以对齐加密算法数据块长度 。
获取 mcrypt 支持的算法,这里我们只关注 AES 算法 。
注意:mcrypt 虽然支持 AES 三种算法,但除MCRYPT_RIJNDAEL_128外 , MCRYPT_RIJNDAEL_192/256并未遵循AES-192/256标准进行加解密的算法,即如果你同其他系统通信(java/.net),使用MCRYPT_RIJNDAEL_192/256可能无法被其他严格按照AES-192/256标准的系统正确的数据解密 。官方文档页面中也有人在 User Contributed Notes 中提及 。这里给出如何使用 mcrpyt 做标注的AES-128/192/256加解密
即算法统一使用MCRYPT_RIJNDAEL_128 , 并通过 key 的位数 来选定是以何种 AES 标准做的加密 , iv 是建议添加且建议固定为16位(OpenSSL的 AES加密 iv 始终为 16 位,便于统一对齐),mode 选用的 CBC 模式 。
mcrypt 在对数据进行加密处理时,如果发现数据长度与使用的加密算法的数据块长度未对齐,则会自动使用 "\0" 对待加密数据进行填充,但 "\0" 填充模式已不再被推荐,为了与其他系统有更好的兼容性 , 建议大家手动对数据进行 PKCS7 填充 。
openssl 簇加密方法更为简单明确,mcrypt 还要将加密算法分为 ciphermode 去指定,openssl 则只需要直接指定 method 为AES-128-CBC,AES-192-CBC,AES-256-CBC即可 。且提供了三种数据处理模式,即默认模式 0 /OPENSSL_RAW_DATA /OPENSSL_ZERO_PADDING。
openssl 默认的数据填充方式是 PKCS7,为兼容 mcrpty 也提供处理 "0" 填充的数据的模式,具体为下:
options参数即为重要 , 它是兼容 mcrpty 算法的关键:
options = 0 : 默认模式,自动对明文进行 pkcs7 padding,且数据做 base64 编码处理 。
options = 1 : OPENSSL_RAW_DATA , 自动对明文进行 pkcs7 padding,且数据未经 base64 编码处理 。
options = 2 : OPENSSL_ZERO_PADDING,要求待加密的数据长度已按 "0" 填充与加密算法数据块长度对齐,即同 mcrpty 默认填充的方式一致,且对数据做 base64 编码处理 。注意 , 此模式下 openssl 要求待加密数据已按 "0" 填充好,其并不会自动帮你填充数据 , 如果未填充对齐,则会报错 。
故可以得出 mcrpty簇 与 openssl簇 的兼容条件如下:
建议将源码复制到本地运行,根据运行结果更好理解 。
1.二者使用的何种填充算法 。
2.二者对数据是否有 base64 编码要求 。
3.mcrypt 需固定使用 MCRYPT_RIJNDAEL_128,并通过调整 key 的长度 16, 24,32 来实现 ase-128/192/256 加密算法 。
请教 php如何对字符串加密和解密 , 求一个相关的实例!字符串加密解密算法
php5.5中有更为可靠和方便的加密方式 。喜欢钻研的朋友可以了解一下:
password_hash()
基于mcrypt扩展 , 按位异或总结的两个字符串加密解密算法
?php
/**
* @info 字符串加密解密算法一,利用mcrypt扩展
* @param string $string 待处理字符串
* $action ENCODE,加密 | DECODE,解密
* @return string $returnstr
*/
functionmcrypt_handle_string($string,$action= 'ENCODE')
{
!is_array($string) orexit;
$action== 'DECODE' $string=base64_decode($string);
$key= "123456";//key可自定义或在配置文件中获取
$mcryptAlgorithm= MCRYPT_DES;//选择一种加密算法
$mcryptMode= MCRYPT_MODE_ECB;//选择一种加密模式
$mcryptIv= mcrypt_create_iv(mcrypt_get_iv_size($mcryptAlgorithm,$mcryptMode),MCRYPT_RAND);//创建初始化向量$returnstr=base64_encode(mcrypt_encrypt($mcryptAlgorithm,$key,$string,$mcryptMode,$mcryptIv));
if('DECODE' ==$action)
{$returnstr=mcrypt_decrypt($mcryptAlgorithm,$key,$string,$mcryptMode,$mcryptIv);
}return$returnstr;
}
?php
/**
*
* @info 字符串加密解密算法二 利用按位异或
* @param string $string 待处理字符串
* @param $action ENCODE 加密 | DECODE 解密
* @return string*/
functionStrCode($string,$action= 'ENCODE')
{$action!= 'ENCODE' $string=base64_decode($string);
$code= '';$key=substr(md5($GLOBALS['pwServer']['HTTP_USER_AGENT'] .$GLOBALS['db_hash']),
8,18);$keyLen=strlen($key);
$strLen=strlen($string);
for($i= 0;$i$strLen;$i)
{$k=$i%$keyLen;$code.=$string[$i] ^$key[$k];
}
return($action!= 'DECODE' ?base64_encode($code) :$code);
}
来源jingyan.baidu.com/m/article/e4d08ffdd1ca6b0fd2f60d13.html
php数据加密和解密的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于php数据加密和解密的区别、php数据加密和解密的信息别忘了在本站进行查找喔 。

    推荐阅读