X@X.X域名转向的实现

www.chinacs.net 中文C#技术站

当你看到csdn@csdn.com时,你肯定把这当作电子邮件地址,其实这个不一定是邮件地址,有可能是域名。现在有越来越多的人开始使用这个形式的地址了。初看起来,你不要以为这个是一个什么非常了不起的技术,其实是一个非常简单的东西。

     我们如果要在IE中访问FTP,会用到ftp://user:pwd@pft.csdn.com这样的形式,其实csdn@csdn.com这种形式就是从上面那个衍生出来的,当我们用csdn@csdn.com这样的形式访问时,IE会自动解析csdn.com得到IP,并在这个IP下调用默认的文档,假如是default.html,此时如果我们用以下的语句:

  <script>

  this.location = "gol.aspx?user=" + this.location.href;

  </script>

 

就把csdn@csdn.com作为user的值提交到了gol.aspx

此时我们可以用一下的gol.aspx来实现域名转向

<%@ Page Language="C#" Debug=true%>
<%@ Import NameSpace="System.Data" %>
<%@ Import NameSpace="System.Data.SqlClient" %>
<script language="C#" runat="server">
void Page_Load(Object src,EventArgs e)
{
 string url=Request.QueryString["user"].ToString();//获取user的值,即在浏览器中的地址
 url=url.ToLower();//将这个地址转成小写形式
 url=url.Replace("http://","");//如果地址前带http://,则除掉这个前缀
 string[] prefix=url.Split('@');  //以@拆分这个地址,

 if(prefix[0]=="")如果没有采用@类型的域名,则转到默认文档.
 {
  Response.Redirect("ip.aspx?ip="+Request.ServerVariables["REMOTE_ADDR"]);
  return;
 }

 try//连接SQL 数据库,从数据库提取信息,实现域名转向,并增加访问计数。
 {
  SqlConnection conn=new SqlConnection("server=127.0.0.1;uid=sa;pwd=qi4c;database=qi4c");
  conn.Open();
 
  SqlCommand comm=new SqlCommand("select location,click from redr where prefix='"+prefix[0]+"'",conn);

  SqlDataReader dr=comm.ExecuteReader();
  if(dr.Read())
  {
   string click=(dr.GetInt32(1)+1).ToString();
   string redirecturl=dr.GetString(0).ToString();
   dr.Close();
   comm.CommandText="Update redr set click="+click+"where prefix='"+prefix[0]+"'";
   comm.ExecuteNonQuery();
   Response.Redirect(redirecturl);
  }
  else
  {
   dr.Close();

   Response.Redirect("ip.aspx");
  }
  conn.Close();
 }
 catch(Exception exec)
 {
  Response.Redirect("ip.aspx?ip="+Request.ServerVariables["REMOTE_ADDR"]);
 }
}

</script>
<html>
<head>
<title></title>
</head>
<body>

</body>
</html>
数据库的结构

prefix          char         10

location       char         50

click            int           4


 

posted @ 2004-10-27 19:42  leonardleonard  阅读(140)  评论(0编辑  收藏  举报