使用現成的Ajax開發框架,究竟安不安全? | ||
文/黃天賜 (記者) 2007-10-03 | ||
雖然使用現成的Ajax開發框架,能加快新一代網頁應用程式開發速度,但使用這些框架,日後會不會帶來安全上的問題? | ||
| ||
Ajax已經是現在網站設計的顯學,在Google、Yahoo!這些網站許多的服務上,都能看到應用Ajax帶來的方便性,像是自動建議選字或是Outlook的Web郵件等。因此,許多網站也想導入Ajax。 不過重頭學Ajax速度太慢,許多開發人員便紛紛找尋現成Ajax框架作為解決方案,但是心裡又不免擔心,Ajax似乎也有一些潛在風險? 做好後端把關,風險大為降低 首先我們要先了解的是Ajax究竟有哪些安全上的風險。所謂Ajax,最狹義的說法是指非同步傳輸的溝通方式,藉由XMLHttpRequest這個瀏覽 器物件,處理用戶端與伺服器端資料交換的過程。後來Ajax也進一步包含操作CSS與DOM(文件物件模型)呈現豐富效果的技巧。 不管是狹義或廣義,大多數Ajax技巧使用的是JavaScript語法,由於JavaScript語法屬於用戶端的程式語言,它的一大特性就是 程式碼會隨著頁面下載到使用者的電腦中。不像是PHP、ASP這類伺服器端的程式語言,程式在伺服器上執行,前端看不到原始碼,相反地 JavaScript的變數宣告、程式邏輯等都攤開在使用者面前,有人便擔心如此一來會增加被攻擊的機會。 另外,最容易與JavaScript聯想在一起的XSS(Cross-site scripting)攻擊手法,不是網站本身已經被攻陷,不然就是沒對使用者的內容進行過濾,造成有心人士可以上傳攻擊程式碼到網站上,一旦瀏覽網頁,使用者就有被植入木馬的風險。 這些攻擊成立的條件,通常是JavaScript設計不當,或是後端程式沒有盡到把關工作。前者例如透過JavaScript進行購物清單的加總計算,而讓使用者有機可趁可以竄改價格,而後者就像是常聽見的SQL Injection的攻擊手法。 一般來說Ajax通常應該只負責像動畫效果、使用者介面元件這些與商務邏輯無關的部分。至於非同步傳輸雖然會呼叫後端的程式,送資料到後端去,但 任何資料送到伺服器,系統本身原本就要執行把關工作,這與Ajax框架無關。事實上現成的Ajax框架是由精熟JavaScript的程式人員所開發,會 避免誤用,相對來說更安全。
Ajax框架更新到安全版本,網站更為安全 Ajax使用的XMLHttp Request,在設計之初就限制請求資源與呼叫的程式,必須同在一個網域內,藉此降低風險。相對來說,這個前提也讓Ajax的安全性大為提高。 由於Ajax是否安全,相當大的比例是建立在後端程式把關上,因此使用現成的Ajax框架並不會帶來安全上的疑慮,甚至通常會比自己寫程式更為安全,畢竟這些框架使用的人多,發現問題與修正的速度也快。 唯一要注意的是,世界上沒有百分之百安全的程式,使用時只要留意該框架的更新訊息,一旦發布有關安全性的升級資訊時,應該盡快升級到較新、安全的版本,就能降低遭到攻擊的機會。文☉黃天賜 iThome歡迎讀者提問,請將你所遇到的各種企業IT疑難雜症,寄至iThome編輯部:QA@mail.ithome.com.tw |
--
[垃圾桶] 裡沒有會話群組。 當您有 2000 MB 以上的儲存空間時,誰還需要刪除郵件?!
沒有留言:
張貼留言