有一天我突發(fā)奇想,要是我每到一個網(wǎng)站,那里都能立刻調(diào)出我需要看的信息,那豈非美妙得很。接下來我想更深入地考慮這個問題,坐到椅子上拿一支鉛筆,卻不知道自己寫什么。如此一來,我還是得著手對付代碼它們。
我的朋友開了一個小型站點,原本是我設(shè)計的。這是個檢驗我想法的好平臺。所以我寫出代碼,上傳了文件。真叫人興奮,程序工作起來煞是圓滿,同時也證明我的想法的確不錯。
以前看過一些網(wǎng)絡(luò)使用者傾向報告,其中有一個規(guī)律給我印象很深。說是大多數(shù)用戶如果在三次點擊內(nèi)無法找到自己需要的內(nèi)容,就會立刻離開該站點。我的代碼就可以針對這個問題,保險用戶只要點一次鼠標(biāo)就找到目標(biāo)。在我的例子里,假設(shè)有個用戶上了Yahoo,檢索關(guān)鍵字為Fireplace Accessories(飛行器材配件)。在給出的結(jié)果里,他來到我朋友的站點,將看到"你正在搜索Fireplace Accessories"等字樣的畫面。接著他會按照網(wǎng)站上的提示,直接到想要去的頁面。
你要作的第一步,是在global.asa文件中建立一個初始變量,放置在你的Sub Session_onStart()程序中。
Sub Session_onStart()
Referer = Trim(Request.ServerVariables("HTTP_REFERER"))
If Referer = "" Then
Referer = "None"
End If
Session("Referer") = Referer
End Sub
接著我們來著手看看如何完成程序的主要功能。
因為url經(jīng)過了編碼,所以首先要把來訪者主機(jī)的指向數(shù)據(jù)還原成對我們有用的東西。建立一個ASP頁面,叫它decode.asp,是我們程序的主干。第一個功能是要對編碼過的指向頭進(jìn)行解碼。程序有點長,而且很直接,沒有什么轉(zhuǎn)彎抹角,如果你嫌麻煩,不如到
源代碼 第二件要作的事情是:從URL頭信息里分離出查詢部分--這個才是我們需要的。 '從指向URL中分離查詢字段。 Function Finder(byRef prodList, byVal refList) 具體如下: '如果指向頭不為空,調(diào)出此功能If lCase(Session("Referer")) <> "none" OR Session("Referer") <> "" Then' 解析指向數(shù)據(jù) Response.Write vbCrLf & "
Function isProduct(pStr)
If pStr <> "" And lCase(pStr) <> "none" Then
'向后搜索字段
temp = inStrRev(pStr, "/")
'得到目錄分離的位置
tempStr = Right(pStr, temp)
'得到有關(guān)數(shù)據(jù)長度
temp2 = Len(pStr)
'得到查詢數(shù)據(jù)行
pStr = Mid(pStr, temp, temp2)
'設(shè)定返回功能的值
isProduct = pStr
Else
isProduct = ""
End If
End Function
接著是要確立查找的明確標(biāo)準(zhǔn)。為達(dá)到這個目的,建立兩個靜態(tài)空間"指?查找指向數(shù)據(jù)
'模糊查詢
refList = lCase(refList)
' 通過指針循環(huán)查找匹配字段
For i = 0 To uBound(prodList) - 1
If inStr(refList, lCase(prodList(i, 0))) Then
'找到匹配
tHolder = tHolder & "Are You looking For " _
& "" _
& prodList(i, 0) & "
"
End If
'第二次循環(huán)
Next
'返回結(jié)果
Finder = tHolderEnd Function
通過一個inclue,把我們做好的decode.asp放到需要此功能的任何頁面,大功告成啦。
" _ & Finder(pArray, URLDecode(isProduct(Session("Referer")))) _ & "
" & vbCrLf
End If