网络编程
位置:首页>> 网络编程>> Asp编程>> 如何防止页面中的敏感信息被提取

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

  发布时间:2008-05-04 11:59:00 

标签:email,加密,函数,js

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

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

  Public Function CloakText(ByVal PersonalInfo As String) As String 
   
   If Not PersonalInfo Is Nothing Then 
   Dim sb As New StringBuilder 
   
   ' convert to ASCII character codes,将字符串转换成ASCII编码字符串形式 
   sb.Remove(0, sb.Length) 
   Dim StringLength As Integer = PersonalInfo.Length - 1 
   For i As Integer = 0 To StringLength 
   sb.Append(Asc(PersonalInfo.Substring(i, 1)).ToString) 
   If i < StringLength Then 
   sb.Append(",") 
   End If 
   Next 
   
   ' build script block 
   Dim sbScript As New StringBuilder 
   
   sbScript.Append(vbCrLf & "<script language=""javascript"">" & vbCrLf) 
   sbScript.Append("<!-- " & vbCrLf) 
   'fromCharCode 方法:从一些 Unicode 字符值中返回一个字符串。 
   sbScript.Append(" document.write(String.fromCharCode(" & sb.ToString & "))" & vbCrLf) 
   sbScript.Append("// -->" & vbCrLf) 
   sbScript.Append("</script>" & vbCrLf) 
   
   Return sbScript.ToString 
   Else 
   Return Null.NullString 
   End If 
   
  End Function 

   
  该段代码先将需要加密的信息转换成ASCII编码字符串形式,然后用javascript中的document.write方法写到页面。
   
  我测试了以下效果,还不错。大家也可以试试。 
  

<html> 
  <head> 
  <meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
  <title>测试信息加密</title> 
  </head> 
   
  <body> 
  可以被提取的链接:<a href="mailto:aaa@163.com">aaa@163.com</a><br> 
  不能被提取的链接: 
  <script language="javascript"> 
  <!-- 
   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, 
  46,99,111,109,34,62,120,120,120,64,116,111,109,46,99,111,109,60,47,97,62)) 
  // --> 
  </script> 
  </body> 
  </html> 

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

0
投稿

猜你喜欢

  • 很久没写过东西了,今天看了chinahuman 的《用asp自动解析网页中的图片地址,并将其保存到本地服务器》,于是优化了这个程序,并且将所
  • 现在网页设计师除了把页面做的漂亮以外,越来越注重“用户体验”,就是要做“别让用户思考”的网页,使网站真正做到“可用性”。望望结合几年的工作经
  • 为庆祝jQuery的四周年生日,jQuery官方团队正式发布了jQuery 1.4版本。在这个版本中,jQuery官方团队做了大量的编码、测
  • 最近心情非常差,而且还没有触底的样子,哎~~~总是会忍不住叹气~~~前些日子在Twitter上叨唠说“不在乎IE8什么时候推出,只在乎IE6
  • XML文档对象模型(DOM)是什么?可扩展标记语言XML的基础是 DOM。XML 文档具有一个称为节点的信息单元层次结构;DOM 是描述那些
  • SQL Server 的扩展存储过程,其实就是一个普通的 Windows DLL,只不过按照某种规则实现了某些函数而已。近日在写一个扩展存储
  • 1、简单的按钮js事件 用于判断和显示提示 <script type="text/javascript&
  • 这次讨论一下关于select元素的一个问题,其实很早以前我就碰到过关于select元素的问题,这次做网站又被问到同样的问题,就是:一般div
  • 假设你想找到本书中的某一个句子。你可以一页一页地逐页搜索,但这会花很多时间。而通过使用本书的索引,你可以很快地找到你要搜索的主题。表的索引与
  • 阅读上一篇:请给PNG8一个机会 系列二:对png8的误解Png8的在ie中的怪异表现:1.半透明的png8在ie6以下的浏览器显示为全透明
  • 背景 background css  说明 background-image:url(&q
  • 1. 查看数据库的版本select @@version2.查看数据库所在机器操作系统参数exec master..xp_msver3. 查看
  • 问题:数据库实际大小为600MB, 日志文件实际大小为33MB, 但日志文件占用空间为2.8GB!试了多种方式,SHIRNK DATABAS
  • 细线边框是网页中定位区分内容常用的一种方法,配合特定图片的使用,往往能够达到不错的效果,那么如何制作细线边框呢?asp之家注:现在要实现这个
  • 一种很常见的写法: document.write('<scr'+'ipt src=&quo
  • 在设计网页之前,客户或产品经理会提出对网页视觉风格设计的期望:活跃、大气、稳重、信赖、都市化….. 设计师一听到关键词或许很自然地在心里蹦出
  • 代码如下:vbcrlfvbs常量相当于vbcr & vblf 就是常见的那个 chr(13) & chr(10),用Chr(
  • CSS styles和HTML styles有什么区别?HTM style是指自定义HTML标识中一些标签,例如说在HTML中〈B〉〈/B〉
  • 安装时建议你为MySQL管理创建一个用户和组。由该组用户运行mysql服务器并执行管理任务。(也可以以root身份运行服务器,但是不推荐)第
  • 适合各种浏览器的js拖动层,ie,firefox等,调用方便!<!DOCTYPE HTML PUBLIC "-//W3C//
手机版 网络编程 asp之家 www.aspxhome.com