我想知道如何加密Apache / PHP上的URL?
例如:
www.example.com/how-to-encrypt.html
到
www.example.com/DMQRzZWMDdGQtbndzBHNsawN0aXRsZQR0ZXN0AzcwMQR3b2UDMjQwMjEwNQ
这个例子也可以在雅虎上看到,就像这个链接一样:
us.yahoo.com/_ylt=As6pPqj3t7OBn2LQbZCUU7abvZx4;_ylu=X3oDMTVocThw330824863
我想知道如何做到这一点,是通过JavaScript / PHP / Apache吗?
答案 0 :(得分:1)
你可能正在和PHP一起寻找Apache mod_rewrite。该URL不是(并且不应该)加密,它可能只是一个重定向到Yahoo!数据库的密钥。切断。见this article。
答案 1 :(得分:0)
最好在数据库级别执行安全操作。以下是使用PHP执行MySQL数据库操作的方法:PHP Database Operations with MySQL。然后,您可以访问与安全性相关的所有数据库操作,例如:Encryption and Compression Functions。因此,您可以在数据库中生成字符串,并将URL参数中的标记传递给用户。最好还将另一个参数(例如用户名)传递到URL中以降低安全风险。在客户端响应后,您只需从URL中获取参数并验证用户。在执行数据库操作之前,请务必清理并验证输入。 Sanitize and validate before assuming data is safe.
有关信息,您绝不应该使用JavaScript来执行重要的安全操作,至少在没有认真评估风险和替代选项的情况下。 (任何黑客都会在JavaScript代码中看到您的整个安全逻辑。)
请注意,你可以抓住_ylt&来自此网址的_ylu参数:
这些参数是您为数据库操作获取的参数。您可以在特定页面中使用这些:
答案 2 :(得分:-4)
我不是一个PHP家伙,但很快Google Search把我带到了this link。
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->skey, $text, MCRYPT_MODE_ECB, $iv);
return trim($this->safe_b64encode($crypttext));
}
public function decode($value){
if(!$value){return false;}
$crypttext = $this->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->skey, $crypttext, MCRYPT_MODE_ECB, $iv);
return trim($decrypttext);
}
}
和用法
$this->encrypt->encode('Your data');
$this->encrypt->decode('Your encrypted data');