ホームページ  >  記事  >  バックエンド開発  >  暗号化要素を使用した PHP カスタム暗号化メソッド

暗号化要素を使用した PHP カスタム暗号化メソッド

高洛峰
高洛峰オリジナル
2016-10-21 10:57:161654ブラウズ

現在、PHP 暗号化方式は多数あります。一般に、単純な暗号化方式は直接 MD5 ですが、一部の単純な MD5 パスワードは逆コンパイルできるため、現在はカスタム方式を使用して暗号化する方が安全です。

現在、いくつかの PHP 暗号化方法を収集して要約し、参考のために共有しています。

メソッド 1:

/**
* 对用户的密码进行加密
* @param $password
* @param $encrypt //传入加密串,在修改密码时做认证
* @return array/password
*/
function password($password, $encrypt='') {
    $pwd = array();
    $pwd['encrypt'] = $encrypt ? $encrypt : rand(1000,9999); 
    $pwd['password'] = md5(md5(trim($password)).$pwd['encrypt']);
    return $encrypt ? $pwd['password'] : $pwd;
}

メソッドの説明: パスワードのみを渡すと、メソッドは暗号化係数と新しく生成された暗号化パスワードを返します。この暗号化係数とパスワードはランダムに生成され、毎回変更されることはありません。 。


方法 2:

/* 
* rc4加密算法 
* $pwd 密钥 
* $data 要加密的数据 
*/ 
 
//$pwd密钥 $data需加密字符串 
function rc4 ($pwd, $data){ 
    $key[] =""; 
    $box[] =""; 
    $pwd_length = strlen($pwd); 
    $data_length = strlen($data); 
    for ($i = 0; $i < 256; $i++){ 
        $key[$i] = ord($pwd[$i % $pwd_length]); 
        $box[$i] = $i; 
    } 
    for ($j = $i = 0; $i < 256; $i++) { 
        $j = ($j + $box[$i] + $key[$i]) % 256; 
        $tmp = $box[$i]; 
        $box[$i] = $box[$j]; 
        $box[$j] = $tmp; 
    } 
    for ($a = $j = $i = 0; $i < $data_length; $i++) { 
        $a = ($a + 1) % 256; 
        $j = ($j + $box[$a]) % 256; 
        $tmp = $box[$a]; 
        $box[$a] = $box[$j]; 
        $box[$j] = $tmp; 
        $k = $box[(($box[$a] + $box[$j]) % 256)]; 
        $cipher .= chr(ord($data[$i]) ^ $k); 
    } 
    return $cipher; 
}

方法 3:

/** 
+----------------------------------------------------- 
* Mcrypt 加密/解密 
* @param String $date 要加密和解密的数据 
* @param String $mode encode 默认为加密/decode 为解密 
* @return String 
* @author zxing@97md.net Mon Sep 14 22:59:28 CST 2009 
+----------------------------------------------------- 
* @example 
*/ 
function ZxingCrypt($date,$mode = &#39;encode&#39;){ 
    $key = md5(&#39;zxing&#39;);//用MD5哈希生成一个密钥,注意加密和解密的密钥必须统一 
    if ($mode == &#39;decode&#39;){ 
        $date = base64_decode($date); 
    } 
    if (function_exists(&#39;mcrypt_create_iv&#39;)){ 
        $iv_size = mcrypt_get_iv_size(MCRYPT_RIJNDAEL_256, MCRYPT_MODE_ECB); 
        $iv = mcrypt_create_iv($iv_size, MCRYPT_RAND); 
    } 
    if (isset($iv) && $mode == &#39;encode&#39;){ 
        $passcrypt = mcrypt_encrypt(MCRYPT_RIJNDAEL_256, $key, $date, MCRYPT_MODE_ECB, $iv); 
    }elseif (isset($iv) && $mode == &#39;decode&#39;){ 
        $passcrypt = mcrypt_decrypt(MCRYPT_RIJNDAEL_256, $key, $date, MCRYPT_MODE_ECB, $iv); 
    } 
    if ($mode == &#39;encode&#39;){ 
        $passcrypt = base64_encode($passcrypt); 
    } 
    return $passcrypt; 
}


声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。