日韩天天综合网_野战两个奶头被亲到高潮_亚洲日韩欧美精品综合_av女人天堂污污污_视频一区**字幕无弹窗_国产亚洲欧美小视频_国内性爱精品在线免费视频_国产一级电影在线播放_日韩欧美内地福利_亚洲一二三不卡片区

XMLHttpRequest和AJAX入主Web開發(fā)_AJAX教程

編輯Tag賺U幣
教程Tag:暫無Tag,歡迎添加,賺取U幣!

推薦:如何根據(jù)郵編自動完成地址信息
采用一個開源的AJAX庫:Ajax Toybox 描述: 在注冊或購物車結(jié)帳的時候,需要用戶填入個人資料,這個環(huán)節(jié)可以簡練一下,我們只需客人填入郵政編碼,然后就根據(jù)這個郵政編碼,自動從數(shù)據(jù)庫中取出相應(yīng)的省,市等地址信息。這樣既可以減少客戶的輸入,增加客戶體

一、 引言

在XMLHttpRequest對象和AJAX給用戶和開發(fā)者帶給巨大好處的同時,也許還有一些問題你沒
有考慮到-但是的確到了值得引起每個人注意的時候了。

甚至非常討厭的人也都喜歡XMLHttpRequest,因?yàn)樗峁┙o程序員真正夢想的功能。也正
是因?yàn)橛辛诉@樣的新技術(shù),Web應(yīng)用軟件開始變得具有象桌面應(yīng)用軟件相似的行為。如今,
問題總是象"假定為……"那樣地簡單,這把幼稚的終端用戶從需要了解服務(wù)端、客戶、回
寄和提交按鈕-"提交?提交給什么東西?"-等一系列問題的苦海中解脫出來。

最近,無數(shù)可怕的案例爆炸式出現(xiàn)在Web上,它們充分說明為什么遠(yuǎn)程腳本(或稱"AJAX",如
果你喜歡的話)是自從單像素點(diǎn)gif技術(shù)以來最偉大的事情。事實(shí)上,成串的酷極的、有用的
應(yīng)用軟件正日益增長,象站點(diǎn)Flickr,Google Maps,The WebORB Presentation Server等所
宣傳的那樣。

這些站點(diǎn)和另外許多地方大肆宣傳AJAX的能力。公正地說,這種技術(shù)在提高在線操作的質(zhì)量
方面的確有相當(dāng)?shù)臐摿�。然�?盡管它有許多的優(yōu)點(diǎn),但是這個神圣的Web通訊大杯中嗅
起來仍然有一股奇怪的味道;就象擺動在我們面前的啤酒和巧克力,仍有一個邪惡的方面存
在于其中-表面上看起來是多么地純潔和天真。

這種潛在的邪惡存在于用戶熟悉的操作界面背后的重要的功能性差距之中。你們當(dāng)中許多
人可能已經(jīng)使用互聯(lián)網(wǎng)近10年了,并且你知道它怎樣工作:你到處點(diǎn)按鼠標(biāo),填充表單,
修改你的輸入;當(dāng)做完所有這些,你可以點(diǎn)擊提交按鈕。你們都了解這些精華經(jīng)驗(yàn)-它們從
因特網(wǎng)的一代傳遞到新的一代,如:"不要點(diǎn)按提交按鈕兩次-否則,表單可能要提交兩次"或
"等待稍微長一些時間,它正在處理"或"在你提交了表單后,不要點(diǎn)按'向后'按鈕",等等。


但是既然現(xiàn)在AJAX已登堂入室,那么你可以把基本知識拋出窗外。簡直是"什么東西都可以
"-突然間出現(xiàn)一種新的可被跟蹤的數(shù)據(jù)-可以在任何時候發(fā)送出去,而不需要用戶的任何了
解,甚至用戶還不了解這竟然是可能發(fā)生的。每一次擊鍵,每一個鼠標(biāo)移動,每一下點(diǎn)按
鼠標(biāo),每一次停頓,都能被捕獲并發(fā)送到Web服務(wù)器,而你對此無能為力。

二、 XMLHttpRequest:利與弊

就象許多技術(shù)存在利弊一樣,產(chǎn)生這種技術(shù)的目的是為了利用其優(yōu)點(diǎn)。直到如今,XMLHtt
pRequest帶給人們?nèi)绱硕嗟膬?yōu)點(diǎn),諸如不需回滾的輸入校驗(yàn),文本區(qū)域的拼寫檢查以及Gm
ail等等,簡直幾乎為人們捧之為神圣�;贏JAX技術(shù)創(chuàng)建的接口使用起來非常有趣,甚至
編碼更有趣味。簡直很難令人相信,這樣一種神奇的技術(shù)竟然能夠做錯事情。

但是,即使還沒有發(fā)現(xiàn)存在巨大的安全漏洞,該XMLHttpRequest也有可能因?yàn)槠渫庠诘膬?yōu)
雅而失敗。它很可能會失敗在"用戶輪廓圖"-用于更好的描述之目的-的應(yīng)用之中。當(dāng)前,用
戶輪廓圖幫助Web站主偵探趨勢,跟蹤網(wǎng)頁瀏覽習(xí)慣并幫助消除使用性問題。但是直到現(xiàn)在
,開發(fā)人員還只能分析寄回的數(shù)據(jù)-用戶決定讓服務(wù)器取得的數(shù)據(jù)并為提交后得到處理而高
興。

但是通過一種微秒的手段,這種能量平衡會發(fā)生易位。通過使用AJAX技術(shù),一個用戶的行
為可以被持續(xù)地并小心地監(jiān)控。因?yàn)樗鼙蛔?所以它將被做;這就帶給人們一個相當(dāng)頭疼
的問題,而不僅僅是浪費(fèi)帶寬、成兆的垃圾信息以及更慢的網(wǎng)頁裝載次數(shù)的問題。

設(shè)想一下,這里僅是舉例說明問題,你把一部新購買的iPod掉到地上去了,結(jié)果它停止了
工作。抱著希望得到免費(fèi)的替換的想法,你發(fā)了一封電子郵件給Apple公司的售后服務(wù)部,
信中說:"我剛剛買了一個新牌子的iPod。我不小心把它掉到了樓梯上,它突然停止工作了
。"之后,你決定刪去第二句以支持你的理由。太晚了!如果該網(wǎng)站使用了AJAX技術(shù),你的
反映可能早就被殺死在了你的抱怨桌前!

或者-一個更惡意破壞性的例子-請考慮這種情況:大多數(shù)人都有一個或兩個用戶名/口令組
合以用于他們的"并不重要"的站點(diǎn),如新聞?wù)军c(diǎn)、博客、論壇等。他們可能還有幾個保留
的這種組合以用于更敏感的網(wǎng)站-銀行業(yè)務(wù),Web郵件和工作帳號等。在一個給定頁面中輸
入不正確的登錄細(xì)節(jié)是非常普通和極易犯的錯誤。雖然他們以前形成的習(xí)慣的影響應(yīng)對此
負(fù)主要責(zé)任,但是在人們點(diǎn)擊提交按鈕前常常是已經(jīng)意識到他們所做的事情的。

不幸的是,一個AJAX擊鍵記錄程序?qū)崿F(xiàn)起來相當(dāng)麻煩。使用如此的一個擊鍵記錄程序,就可
以用代碼來收集不正確的登錄嘗試,然后針對一系列"重要的"站點(diǎn)對之進(jìn)行試驗(yàn)-當(dāng)然,也
可以使用XMLHttpRequest對象。

三、 "惡意"暗示

公平地說,上面引用的大多數(shù)的"惡意"應(yīng)用軟件都能被合理地加以處理,即使在XMLHttpRe
quest技術(shù)出現(xiàn)以前。的確,request對象是一種相對于以前的IFrame技術(shù)更為優(yōu)雅的成功
提交表單數(shù)據(jù)的方法。但是,XMLHttpRequest以一種更為自然的方式工作,這種方式簡直
可以能使客戶端與服務(wù)器端的交互差別逐漸消失。

具有諷刺意味的是,直到最近,隨著Firefox Web瀏覽器的不斷流行,才使得較多用戶真正
了解到可以由Web客戶端儲存和控制的信息的深度和廣度。隨著廣泛采用象Greasemonkey,
Web開發(fā)者擴(kuò)展以及cookie編輯器這樣的工具,人們比以往任何時候更為確信,如果問題發(fā)
生在客戶端,那么責(zé)任一般應(yīng)歸咎于該用戶。

但是現(xiàn)在,即使象我們這樣狂妄的人也不再只是右擊鼠標(biāo),看一下源代碼,然后就能確信正
在發(fā)生的事情了。請考慮下面的OnReadyStateChange JavaScript語句,運(yùn)行它是為了響應(yīng)
一個XMLHttpRequest:

xmlReq.onreadystatechange =
{
if( xmlReq.readyState == 4 )
eval( xmlReq.responseText );
}


上面的代碼執(zhí)行包含在來自于XMLHttpRequest的響應(yīng)中的JavaScript代碼。換句話說,有可
能出現(xiàn)這種情況:即使一個頁面加載完畢,也有可能在后臺再進(jìn)行添加或修改JavaScript
函數(shù)和代碼!因此就算你觀察該頁面代碼的源代碼-它可能發(fā)送了鍵擊或鼠標(biāo)移動事件到W
eb服務(wù)器,你也無法確信你所見的代碼是當(dāng)前執(zhí)行的唯一代碼。把這些特征與一些令人膽戰(zhàn)
心驚的困惑結(jié)合起來,那么你可以看到,惡意目的與XMLHttpRequest對象相結(jié)合,怎么不
能實(shí)現(xiàn)Web客戶的信息竊��!

四、 還不確信?

你還不感到害怕并因此而憤怒嗎?還不準(zhǔn)備憤起并刪去你的瀏覽器中的XMLHttpRequest代
碼嗎?那么,好,也許本文強(qiáng)勢的措詞論證會嚇倒了你;那么在游戲"Fonzie尋寶記"(Th
e Search For 's Treasure。譯者注:在GOOGLE中輸入這幾個關(guān)鍵詞,你肯定能找到這個
在線文本游戲,本人沒有深入試驗(yàn)。難道這個小東西那么可愛的面孔下竟然埋伏著上面所
述的那么恐怖的……)中-你能夠救出Fonzie嗎?

通過使用很有藝術(shù)的命令行接口,穿過充滿文本的門廳尋找丟失的Arthur 'Fonzie' Fonza
relli寶藏。祝你幸運(yùn),但是請記住…雖然它看上去就象無危害的客戶交互-你每作四次移
動,該游戲通過XMLHttpRequest對象發(fā)送一個請求到服務(wù)器上并保存你的移動。永遠(yuǎn)記住
:不要做一個印刷工(Don't make a typo);不要嘗試一些愚蠢的東西如"eat jukebox"

;不要在游戲中輸入一個用戶名和口令字;否則……

 

分享:使用Ajax技術(shù)開發(fā)Web應(yīng)用程序
在過去,由于為了獲得新數(shù)據(jù)而不得不重新加載web頁面(或者加載其他頁面)導(dǎo)致web應(yīng)用程序發(fā)展被限制。雖然有其他方法可用(不加載其他頁面),但是這些技術(shù)都沒有被很好地支持而且有bug成災(zāi)的趨向。在過去的幾個月里,一個過去并不被廣泛支持的技術(shù)已經(jīng)被越

來源:模板無憂//所屬分類:AJAX教程/更新時間:2010-04-06
相關(guān)AJAX教程