凹丫丫网络社区's Archiver

oyaya 发表于 2008-5-17 08:32

如何防止页面中的敏感信息被提取

<P>公布到网页上的Email经常会被一些工具自动提取,一些非法用户就会利用所提取的Email大肆发送垃圾邮件。这些工具大多都是查找链接中“mailto:”后面的信息或是“@”前后的信息来达到提取Email的目的。我在看DotNetNuke(以下简称DNN)的源代码时发现了一个不错的方式来防止这些信息被自动提取。</P>
<P>[quote] </P>
<P>在DNN中有这么一段函数(Globals.vb中): <BR>&nbsp;&nbsp; Public Function CloakText()Function CloakText(ByVal PersonalInfo As String) As String <BR>&nbsp;&nbsp;&nbsp;<BR>&nbsp;&nbsp;&nbsp; If Not PersonalInfo Is Nothing Then <BR>&nbsp;&nbsp;&nbsp; Dim sb As New StringBuilder <BR>&nbsp;&nbsp;&nbsp;<BR>&nbsp;&nbsp;&nbsp; ' convert to ASCII character codes,将字符串转换成ASCII编码字符串形式 <BR>&nbsp;&nbsp;&nbsp; sb.Remove(0, sb.Length) <BR>&nbsp;&nbsp;&nbsp; Dim StringLength As Integer = PersonalInfo.Length - 1 <BR>&nbsp;&nbsp;&nbsp; For i As Integer = 0 To StringLength <BR>&nbsp;&nbsp;&nbsp; sb.Append(Asc(PersonalInfo.Substring(i, 1)).ToString) <BR>&nbsp;&nbsp;&nbsp; If i &lt; StringLength Then <BR>&nbsp;&nbsp;&nbsp; sb.Append(",") <BR>&nbsp;&nbsp;&nbsp; End If <BR>&nbsp;&nbsp;&nbsp; Next <BR>&nbsp;&nbsp;&nbsp;<BR>&nbsp;&nbsp;&nbsp; ' build script block <BR>&nbsp;&nbsp;&nbsp; Dim sbScript As New StringBuilder <BR>&nbsp;&nbsp;&nbsp;<BR>&nbsp;&nbsp;&nbsp; sbScript.Append(vbCrLf &amp; "&lt;script language=""javascript""&gt;" &amp; vbCrLf) <BR>&nbsp;&nbsp;&nbsp; sbScript.Append("&lt;!-- " &amp; vbCrLf) <BR>&nbsp;&nbsp;&nbsp; 'fromCharCode 方法:从一些 Unicode 字符值中返回一个字符串。 <BR>&nbsp;&nbsp;&nbsp; sbScript.Append(" document.write(String.fromCharCode(" &amp; sb.ToString &amp; "))" &amp; vbCrLf) <BR>&nbsp;&nbsp;&nbsp; sbScript.Append("// --&gt;" &amp; vbCrLf) <BR>&nbsp;&nbsp;&nbsp; sbScript.Append("&lt;/script&gt;" &amp; vbCrLf) <BR>&nbsp;&nbsp;&nbsp;<BR>&nbsp;&nbsp;&nbsp; Return sbScript.ToString <BR>&nbsp;&nbsp;&nbsp; Else <BR>&nbsp;&nbsp;&nbsp; Return Null.NullString <BR>&nbsp;&nbsp;&nbsp; End If <BR>&nbsp;&nbsp;&nbsp;<BR>&nbsp;&nbsp; End Function <BR>&nbsp;&nbsp;&nbsp;<BR>&nbsp;&nbsp; 该段代码先将需要加密的信息转换成ASCII编码字符串形式,然后用javascript中的document.write方法写到页面。 <BR>&nbsp;&nbsp;&nbsp;<BR>&nbsp;&nbsp; 我测试了以下效果,还不错。大家也可以试试。 <BR>&nbsp;&nbsp; &lt;html&gt; <BR>&nbsp;&nbsp; &lt;head&gt; <BR>&nbsp;&nbsp; &lt;meta http-equiv="Content-Type" content="text/html; charset=gb2312"&gt; <BR>&nbsp;&nbsp; &lt;title&gt;测试信息加密&lt;/title&gt; <BR>&nbsp;&nbsp; &lt;/head&gt; <BR>&nbsp;&nbsp;&nbsp;<BR>&nbsp;&nbsp; &lt;body&gt; <BR>&nbsp;&nbsp; 可以被提取的链接:&lt;a href="mailto:aaa@163.com"&gt;aaa@163.com&lt;/a&gt;&lt;br&gt; <BR>&nbsp;&nbsp; 不能被提取的链接: <BR>&nbsp;&nbsp; &lt;script language="javascript"&gt; <BR>&nbsp;&nbsp; &lt;!-- <BR>&nbsp;&nbsp;&nbsp; document.write(String.fromCharCode(60,97,32,104,114,101,102,61,34,109,97,105,108,116,111,58,120,120,120,64,116,111,109, <BR>&nbsp;&nbsp; 46,99,111,109,34,62,120,120,120,64,116,111,109,46,99,111,109,60,47,97,62)) <BR>&nbsp;&nbsp; // --&gt; <BR>&nbsp;&nbsp; &lt;/script&gt; <BR>&nbsp;&nbsp; &lt;/body&gt; <BR>&nbsp;&nbsp; &lt;/html&gt;</P>
<P>[/quote]</P>

稻草人 发表于 2008-7-23 16:09

这个是好东西
先收藏了

页: [1]

Powered by Discuz! Archiver 6.1.0  © 2001-2007 Comsenz Inc.