我有file1.php
& file2.php
中的file1.php
有一些链接,例如:
<a href="http://google.com/">Open google site</a>
<a href="http://facebook.com/">Open facebook site</a>
我尝试在file1.php
上制作安全链接,我使用此功能进行加密
function enc_safelink($url_target){
$key = '1q2w3e4r5t';
$iv = mcrypt_create_iv(
mcrypt_get_iv_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_CBC),
MCRYPT_DEV_URANDOM
);
$encrypted = base64_encode(
$iv .
mcrypt_encrypt(
MCRYPT_RIJNDAEL_128,
hash('sha256', $key, true),
$url_target,
MCRYPT_MODE_CBC,
$iv
)
);
return $encrypted;
}
因此file1.php
上的所有链接都是这样的:
<a href="file2.php?link=D6/thGZQ3MpUf6ePqqDBrXdQC3rAVQHMHGm9KOn6GVjB3CNyDqljwt7DIwkWU6HV">Open google site</a>
<a href="file2.php?link=HYOyBzxnpd1MrzN4YMF1qpWSg4KMlE1mz2HTxOl+ZGdS3zUSQymoMIPoBMVu3Mpm">Open facebook site</a>
在file2.php
我希望显示一个链接,并从参数
<?php
function dnc_safelink($params_code){
$key = '1q2w3e4r5t';
$data = base64_decode($params_code);
$iv = substr($data, 0, mcrypt_get_iv_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_CBC));
$decrypted = rtrim(
mcrypt_decrypt(
MCRYPT_RIJNDAEL_128,
hash('sha256', $key, true),
substr($data, mcrypt_get_iv_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_CBC)),
MCRYPT_MODE_CBC,
$iv
),
"\0"
);
return $decrypted;
}
if ( isset($_GET["link"]) ) :
$dnc_url = dnc_safelink($_GET['link']);
echo '<div style="text-align:center" id="aDivSafeLink"><a href="'.$dnc_url.'">Download Here</a></div>';
endif;
?>
但输出如下:
<a href="�uJ�`*���_����gyܥ�w�W�X�#">Download Here</a>
我确定,我已在同一页面上测试过加密和放大解密功能完美无缺。我如何使用加密&amp;解密一个不同页面或不同网站的字符串?
答案 0 :(得分:0)
如何在不同页面或不同站点上使用字符串进行加密和解密?
如果您发现自己正在加密URL参数,则说明您犯了一个错误。
将random_bytes()
与bin2hex()
或base64_encode()
结合使用,而不是加密。如果您使用Base64,则使字节数生成3的偶数倍(例如random_bytes(24)
表示32个字符的字符串)。
您也可以像这样使用URL-safe base64:
<?php
use ParagonIE\ConstantTime\Base64UrlSafe;
$token = Base64UrlSafe::encode(random_bytes(24));
但是加密只是the wrong tool for the job。