不知道大家最近上网是否发现一个新现象,就是有一些网站开始提供“username@server”的虚拟域名服务。由于“@”的魅力,大家纷纷申请,你或许会想:“如果我也能提供这种服务,该多好阿:)人气肯定不错!”本文将给大家揭开“@”的“神秘”面纱,让大家都可以来“@”!(Do u @ today?) 别急,这个并不是电子邮件的地址,是一种虚拟域名,不相信的话可以在浏览器中访问“[email protected]”。部分朋友应该使用过IE的FTP功能,就是在浏览器的地址栏中键入“password:username@server”IE就会自动登陆FTP服务器;而在Http1.1协议中,就规定了Http访问授权功能,形式同样为“password:username@server”,其中“password:”可以省略,也是是访问“[email protected]”实际上是以bbs的身份访问“zphp.com”这个服务器。 那么我们只是需要将具体的URI传送给PHP程序,在数据库中搜索出真实的URL重定向就可以了。 首先我们需要制作一个传送URI的页面(作为服务器的默认文档,一般命名为index.htm);在JS的Window对象中就可以实现这项功能,下面是index.htm的源代码: <script> this.location = ‘gotourl.php?url=’ + this.location.href; </script> 上面的代码会将浏览器重定向到gotourl.php,并且通过QueryString给变量$url赋值为当前的URI。 成功将URI传递给PHP程序后,就可以进入数据库查找真实URL,下面是SQL数据库相对应的table 的结构: CREATE TABLE domain( Id int(3) UNSIGNED DEFAULT ‘0’ NOT NULL, # 域名ID Domain char(20) NOT NULL, # 域名 Gotourl char(255) NOT NULL, # 真实的URL ); 建立好了Table,就可以开始编写gotourl.php了,程序分为三个部分: 1、 分析URL: $url = preg_replace(“/^http:\\/\\//I”, “”, $url); // 将URL前面的“http://”去掉,不区分大小写 $url = preg_replace(“/@.+$/”, “”, $url); // 将“@”后面的部分去除 那么,剩下的URL就只含有“username”的部分了。 为了给数据库应用,需要对铭感的字符进行处理: $url = addslashes($url); 2、 搜索真实的URL: 这里为了实现程序的通用性,使用了一个数据库的操作类(修改自PHPLib)来操作SQL数据库: $db = new dbSql(); // 连接数据库 $queryString = sprinf(“SELECT gotourl FROM domain WHERE domain=’%s’;”, $url); // 生成查询字符串 $gotourl = $db->result($queryString); // 查询取得结果 3、 重定向: 在PHP中重定向浏览器有多种方法,在这里使用比较简单的HttpHeader来实现: header(“location: $gotourl”); 附 其实像网易那样子的“username.yeah.net”的虚拟域名服务和“@”的实现方法大同小异,但是“.”需要以价值200元的DNS泛解析为代价,而“@”所需要的仅仅是: 1、 PHP/SQL数据库的权限; 2、 真正DNS解析的域名。 如果需要在虚拟域名服务中加入广告,比如网易的Popup窗口,可以将重定向部分改为: <script> window.open("url","nease","width=windth,height=height"); </script> 为了对得起“天地良心”,笔者没有将合并后完整的程序加上来(骗稿费?),如果大家比较懒,需要完整的代码(包括了添加等等),可以在http://zphp.com或者http://[email protected]取得。希望大家都有一个好的访问量。 摘自:http://www.cfeng.net/ |