程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> 玩轉虛擬域名◎+

玩轉虛擬域名◎+

編輯:關於PHP編程

不知道大家最近上網是否發現一個新現象,就是有一些網站開始提供“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:

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved