使用xmlhttp爲網站增加股市行情查詢功能
一般情況下,如果我們想了解股市行情,必須登錄專業股票網站,輸入公司代碼才能看到具體股價。其實,利用XMLHTTP協議,我們每個人都可以在自己的個人網站中提供股市行情詳細情況查詢服務,本文介紹瞭如何使用ASP、VbScript結合xmlhttp編程來實現這個功能。
一、原理
原理非常簡單,在很多大型網站上都有實時更新的股市行情信息,我們通過自己的WEB服務器發送出XMLHTTP命令訪問雅虎財經站點的股市行情數據庫服務器,從數據庫中查詢我們所需要的內容,然後通過ASP組合成網頁回送給客戶端。
同時,我們使用XmlHttp協議實現客戶端網頁無刷新效果以及向服務端提出檢索數據的要求。
XMLHTTP允許你打開一個到任意服務器上的HTTP連接,發送一些數據和取回一些數據。並且所有的這一切都是在很少的幾段腳本中就能夠實現。使用XMLHTTP對象通常是進行XML數據交換,但其他格式的數據也是允許的。
在商業程序中的運用這種交換類型的標準模式是客戶端發送一個文本字符串到服務端,然後服務端將這個字符串裝載入一個XMLDOM對象中並且解釋它,然後返回一段HTML給客戶端,或則是另外一段XML代碼給客戶端讓客戶端的瀏覽器自己解釋。在這種方式下,對於信息的傳遞來說是非常有效的形式,尤其是當你使用DHTML允許你根據返回信息動態顯示時。
具體流程爲:客戶端通過xmlhttp提出股票行情查詢要求-->WEB服務器中的ASP偵聽頁接受請求後使用xmlhttp向股市行情數據庫服務器發送檢索命令-->數據庫執行查詢操作,返回結果給我們自己的WEB服務器(html形式)-->WEB服務器接收到內容後,過濾掉HTML多餘部分,挑選出純股票數據,組合後將結果傳送給客戶端->客戶端瀏覽器使用vbscript顯示出來。
二、ASP XmlHttp編程簡述
1、客戶端dns2.htm頁面:
<script language="vbscript">
Sub submit1_onmouseup
Dim objXML, objXSL, objFSO,strFile, strFileName, strXSL,strURL, theString,TheForm
Set TheForm = Document.wordfind
window.status="正在檢索數據???"
strURL="dns2.asp" ' 服務器偵聽頁地址
Set objXML = CreateObject("Microsoft.XMLHTTP") '創建MS的XMLHTTP組件
stra = "submit=submit&fqdn="&TheForm.webname.value
objXML.Open "post",strURL,false '採用Post提交方式;
objXML.setrequestheader "content-length",len(stra)
objXML.setrequestheader "content-type","application/x-www-form-urlencoded"
objXML.send stra ' 發送信息
xmlGet = objXML.responsebody '稍等片刻後,得到服務器端傳回來的結果;
xmlGet = bytes2bstr(xmlGet) '將單字節轉換成文本格式函數,源程序可以下面的dns2.asp程序中找到;
TheForm.comments.value=xmlGet
Set objXML = Nothing
end sub
</script>
<html><head><title>XMLHTTP之股票行情篇</title><meta http-equiv="Content-Type" content="text/html; charset=gb2312">
</head>
<body bgColor=#a1bae6>
<table border="0" cellpadding="0" cellspacing="0" width="100%">
<tr>
<td width="100%" align=center>
<form method="post" name=wordfind οnsubmit="javascript:return false">
<FONT color=#002e5b face=geneva,arial,sans-serif size=2>
<B>請選擇股票名稱(美國納斯達克)</B></FONT>
<FONT color=#002e5b face=geneva,arial,sans-serif size=2><B>:<br>
<select name=webname style="HEIGHT: 22px; WIDTH: 80px">
<option value="^IXIC">納斯達克</option><option value="ASIA">亞信</option>
<option value="CHINA">中華網</option> <option value="NTES">網易</option>
<option value="SINA">新浪網</option> <option value="SOHU">搜狐</option>
</select><input type="submit" value="查詢" id=Submit1 name=Submit1></B>
<TEXTAREA name=comments readonly rows=10 cols=76 ></TEXTAREA>
</form></td></tr></table></body></html>