PHP通过URL发送加密数据

时间:2013-11-16 03:03:13

标签: php encryption base64 url-encoding mcrypt

我正在尝试通过网址将加密数据发送到另一个网站(使用file_get_contents("anotherUrl.php?hash=$encryptedString")。问题是,有时加密包含一些特殊字符,如+,这会导致解密失败。< / p>

以下是我的加密/解密方法:

public function encrypt($string, $key)
{
    return base64_encode(mcrypt_encrypt(MCRYPT_RIJNDAEL_256, md5($key), $string, MCRYPT_MODE_CBC, md5(md5($key))));
}

public function decrypt($encrypted, $key)
{
    return rtrim(mcrypt_decrypt(MCRYPT_RIJNDAEL_256, md5($key), base64_decode($encrypted), MCRYPT_MODE_CBC, md5(md5($key))), "\0");
}

这是一个包含+的示例加密字符串,我猜这会导致解密失败。

oWCrVPaS+5GbxcQFc0fulUk/zRAkDD60av4zlPiWskE=

我应该如何解决这个问题?我试图在哈希上做urlencode()urldecode(),但这似乎也会导致加密中断。有没有办法更改加密算法,使其只返回url安全字符?

4 个答案:

答案 0 :(得分:18)

看一下这个帖子:

Passing base64 encoded strings in URL

基本上, DO 希望在发送字符串之前urlencode(),但是 NOT 希望{}为另一端的urldecode()

答案 1 :(得分:7)

为了解决这个问题,我现在使用以下(经过3个小时的疼痛),效果很好。

随意复制和粘贴

function encrypt($pure_string) {
    $dirty = array("+", "/", "=");
    $clean = array("_PLUS_", "_SLASH_", "_EQUALS_");
    $iv_size = mcrypt_get_iv_size(MCRYPT_BLOWFISH, MCRYPT_MODE_ECB);
    $_SESSION['iv'] = mcrypt_create_iv($iv_size, MCRYPT_RAND);
    $encrypted_string = mcrypt_encrypt(MCRYPT_BLOWFISH, $_SESSION['encryption-key'], utf8_encode($pure_string), MCRYPT_MODE_ECB, $_SESSION['iv']);
    $encrypted_string = base64_encode($encrypted_string);
    return str_replace($dirty, $clean, $encrypted_string);
}

function decrypt($encrypted_string) { 
    $dirty = array("+", "/", "=");
    $clean = array("_PLUS_", "_SLASH_", "_EQUALS_");

    $string = base64_decode(str_replace($clean, $dirty, $encrypted_string));

    $decrypted_string = mcrypt_decrypt(MCRYPT_BLOWFISH, $_SESSION['encryption-key'],$string, MCRYPT_MODE_ECB, $_SESSION['iv']);
    return $decrypted_string;
}

答案 2 :(得分:2)

除了使用Base64对数据进行编码外,您还可以使用URL安全的Base32(RFC 4648),因为它只使用字母A-Z(不区分大小写)和数字2-7。编码/解码已经有PHP library。请注意,Base32比Base64多占用大约20%的空间。

您还可以使用URLcrypt这是一个方便的库,可以帮助您进行加密和Base32编码。

答案 3 :(得分:0)

class Encryption {
    var $skey   = "SuPerEncKey2010"; // you can change it

    public  function safe_b64encode($string) {

        $data = base64_encode($string);
        $data = str_replace(array('+','/','='),array('-','_',''),$data);
        return $data;
    }

    public function safe_b64decode($string) {
        $data = str_replace(array('-','_'),array('+','/'),$string);
        $mod4 = strlen($data) % 4;
        if ($mod4) {
            $data .= substr('====', $mod4);
        }
        return base64_decode($data);
    }

    public  function encode($value){ 

        if(!$value){return false;}
        $text = $value;
        $iv_size = mcrypt_get_iv_size(MCRYPT_RIJNDAEL_256, MCRYPT_MODE_ECB);
        $iv = mcrypt_create_iv($iv_size, MCRYPT_RAND);
        $crypttext = mcrypt_encrypt(MCRYPT_RIJNDAEL_256, $this-&gt;skey, $text, MCRYPT_MODE_ECB, $iv);
        return trim($this-&gt;safe_b64encode($crypttext)); 
    }

    public function decode($value){

        if(!$value){return false;}
        $crypttext = $this-&gt;safe_b64decode($value); 
        $iv_size = mcrypt_get_iv_size(MCRYPT_RIJNDAEL_256, MCRYPT_MODE_ECB);
        $iv = mcrypt_create_iv($iv_size, MCRYPT_RAND);
        $decrypttext = mcrypt_decrypt(MCRYPT_RIJNDAEL_256, $this-&gt;skey, $crypttext, MCRYPT_MODE_ECB, $iv);
        return trim($decrypttext);
    }
}