公布到网页上的Email经常会被一些工具自动提取,一些非法用户就会利用所提取的Email大肆发送垃圾邮件。这些工具大多都是查找链接中 “mailto:”后面的信息或是“@”前后的信息来达到提取Email的目的。我在看DotNetNuke(以下简称DNN)的源代码时发现了一个不错 的方式来防止这些信息被自动提取。

在DNN中有这么一段函数(Globals.vb中):

End Function

C#代码如下:

private string CloakText(string text)
{
StringBuilder sb = new StringBuilder();
System.Text.ASCIIEncoding asciiEncoding = new ASCIIEncoding();
byte[] bytes = new byte[text.Length];
int count = asciiEncoding.GetBytes(text,0,text.Length,bytes,0);
for(int i=0;i<count;i++)
{
sb.Append((int)bytes[i]);
if(i<count-1)
{
sb.Append(",");
}
}
return sb.ToString();
}
 

--------------------------------------------------------------------------------------------------------

该段代码先将需要加密的信息转换成ASCII编码字符串形式,然后用javascript中的document.write方法写到页面。

我测试了以下效果,还不错。大家也可以试试。

如何防止页面中的敏感信息被提取<html>
如何防止页面中的敏感信息被提取
<head>
如何防止页面中的敏感信息被提取
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
如何防止页面中的敏感信息被提取
<title>测试信息加密</title>
如何防止页面中的敏感信息被提取
</head>
如何防止页面中的敏感信息被提取
如何防止页面中的敏感信息被提取
<body>
如何防止页面中的敏感信息被提取可以被提取的链接:
<href="mailto:aaa@163.com">aaa@163.com</a><br>
如何防止页面中的敏感信息被提取不能被提取的链接:


如果大家有兴趣,还可以用更加复杂的方法来进行加密,一句话:再也不能让人轻易获取信息了!

这个不是防破解的,作用是防止蜘蛛偷用户EMAIL等信息发拉圾用的。因此跟破解没有关系。

相关文章: