Yii框架官方指南系列51—專題:安全措施 (Security)
1. 跨站腳本攻擊的防範
跨站腳本攻擊(簡稱 XSS),即web應用程式從使用者收集使用者資料。 攻擊者常常為易受攻擊的web應用注入JavaScript,VBScript,ActiveX,HTML或 Flash來迷惑訪客以收集訪客的資訊。 舉個例子,一個未經良好設計的論壇系統可能不經過檢查就顯示使用者所輸入的內容。 攻擊者可以在貼文內容中註入一段惡意的JavaScript程式碼。 這樣,當其他訪客在閱讀這個貼文的時候,這些JavaScript程式碼就可以在訪客的電腦上運作了。
一個防範XSS攻擊的最重要的措施之一就是:在顯示使用者輸入的內容之前進行內容檢查。 例如,你可以對內容中的HTML進行轉義處理。但在某些情況下這種方法就不可取了,因為這種方法禁用了所有的HTML標籤。
Yii整合了HTMLPurifier並且為開發者提供了一個很有用的元件CHtmlPurifier, 這個元件封裝了HTMLPurifier類別。它可以將透過有效的審查、安全性和白名單功能來把所審核的內容中的所有的惡意程式碼清除掉,並且確保過濾之後的內容過濾符合標準。
CHtmlPurifier元件可以當作一個widget或filter來使用。 當作為一個widget來使用的時候,CHtmlPurifier可以對在視圖中顯示的內容進行安全過濾。 以下是程式碼範例:
<?php $this->beginWidget('CHtmlPurifier'); ?> //...这里显示用户输入的内容... <?php $this->endWidget(); ?>
2. 跨站請求偽造攻擊的防範
跨站請求惡意瀏覽器在網頁RFRF)時候,讓使用者的瀏覽器向一個受信任的網站發動攻擊者指定的請求。 舉個例子,一個惡意網站有一個圖片,這個圖片的src
地址指向一個銀行網站:http://www.php.cn/
。 如果使用者在登陸銀行的網站之後造訪了這個惡意網頁,那麼使用者的瀏覽器會向銀行網站發送一個指令,這個指令的內容可能是「向攻擊者的帳號轉帳10,000元」。 跨站攻擊方式利用使用者信任的某個特定網站,而CSRF攻擊正相反,它利用使用者在某個網站中的特定使用者身分。
要防範CSRF攻擊,必須謹記一條:GET
請求只允許檢索資料而不能修改伺服器上的任何資料。 而POST
請求應當含有一些可以被伺服器識別的隨機數值,用來確保表單資料的來源和運行結果發送的去向是相同的。
Yii實作了一個CSRF防範機制,用來幫助防範基於POST
的攻擊。 這個機制的核心就是在cookie中設定一個隨機數據,然後把它同表單提交的POST
數據中的相應值進行比較。
預設情況下,CSRF防範是禁用的。如果你要啟用它,可以編輯應用程式設定 中的元件中的CHttpRequest部分。
程式碼範例:
return array( 'components'=>array( 'request'=>array( 'enableCsrfValidation'=>true, ), ), );
要顯示一個表單,請使用CHtml::form而不要自己寫HTML程式碼。因為CHtml::form可以自動地在表單中嵌入一個隱藏項,這個隱藏項儲存著驗證所需的隨機數據,這些數據可在表單提交的時候發送到伺服器進行驗證。
3. Cookie攻擊的防範
保護cookie免受攻擊是非常重要的。因為session ID通常儲存在Cookie中。 如果攻擊者竊取到了一個有效的session ID,他就可以使用這個session ID對應的session資訊。
這裡有幾個防範對策:
您可以使用SSL來產生一個安全通道,並且只透過HTTPS連接來傳送驗證cookie。這樣攻擊者是無法解密所傳送的cookie的。
設定cookie的過期時間,對所有的cookie和seesion令牌也這樣做。這樣可以減少被攻擊的機會。
防範跨站代碼攻擊,因為它可以在用戶的瀏覽器觸發任意代碼,這些代碼可能會洩露用戶的cookie。
在cookie有變動的時候驗證cookie的內容。
Yii實作了一個cookie驗證機制,可以防止cookie被修改。啟用之後可以對cookie的值進行HMAC檢查。
Cookie驗證在預設情況下是禁用的。如果你要啟用它,可以編輯應用程式設定 中的元件中的CHttpRequest部分。
程式碼範例:
return array( 'components'=>array( 'request'=>array( 'enableCookieValidation'=>true, ), ), );
一定要使用經過Yii驗證過的cookie資料。使用Yii內建的cookies組件來進行cookie操作,不要使用$_COOKIES
。
// 检索一个名为$name的cookie值 $cookie=Yii::app()->request->cookies[$name]; $value=$cookie->value; ...... // 设置一个cookie $cookie=new CHttpCookie($name,$value); Yii::app()->request->cookies[$name]=$cookie;
以上就是Yii框架官方指南系列51——專題:安全措施 (Security)的內容,更多相關內容請關注PHP中文網(www.php.cn)!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

Yii是一款基於PHP的高效能MVC框架,它提供了非常豐富的工具和功能,支援快速、有效率地開發Web應用程式。其中,Yii框架的RESTfulAPI功能得到了越來越多開發者的關注和喜愛,因為使用Yii框架可以非常方便地構建出高性能、易擴展的RESTful接口,為Web應用的開發提供了強有力的支持。 RESTfulAPI簡介RESTfulAPI是一種基於

隨著Web應用程式的快速發展,現代Web開發已成為一項重要技能。許多框架和工具可用於開發高效的Web應用程序,其中Yii框架就是一個非常流行的框架。 Yii是一個高效能、基於元件的PHP框架,它採用了最新的設計模式和技術,提供了強大的工具和元件,是建立複雜Web應用程式的理想選擇。在本文中,我們將討論如何使用Yii框架來建立Web應用程式。安裝Yii框架首先,

Yii框架中間件:為應用程式提供多重資料儲存支援介紹中間件(middleware)是Yii框架中的重要概念,它為應用程式提供了多重資料儲存支援。中間件的作用類似於一個過濾器,它能夠在應用程式的請求和回應之間插入自訂程式碼。透過中間件,我們可以對請求進行處理、驗證、過濾,然後將處理後的結果傳遞給下一個中間件或最終的處理程序。 Yii框架中的中間件使用起來非常

使用Yii框架實現網頁快取和頁面分塊的步驟引言:在Web開發過程中,為了提升網站的效能和使用者體驗,常常需要對頁面進行快取和分塊處理。 Yii框架提供了強大的快取和佈局功能,可以幫助開發者快速實現網頁快取和頁面分塊,本文將介紹如何使用Yii框架進行網頁快取和頁面分塊的實作。一、網頁快取開啟網頁快取在Yii框架中,可以透過設定檔來開啟網頁快取。開啟主設定檔co

近年來,隨著遊戲產業的快速發展,越來越多的玩家開始尋找遊戲攻略來幫助遊戲過關。因此,創建遊戲攻略網站可以讓玩家更方便取得遊戲攻略,同時也能為玩家提供更好的遊戲體驗。在創建這樣一個網站時,我們可以使用Yii框架來進行開發。 Yii框架是一個基於PHP程式語言的Web應用開發框架。它具有高效、安全、擴展性強等特點,可以為我們更快速、高效地創建一個遊戲攻略

Yii框架中間件:為應用程式新增日誌記錄和偵錯功能【引言】在開發Web應用程式時,我們通常需要添加一些附加功能以提高應用程式的效能和穩定性。 Yii框架提供了中間件的概念,使我們能夠在應用程式處理請求之前和之後執行一些額外的任務。本文將介紹如何使用Yii框架的中間件功能來實作日誌記錄和除錯功能。 【什麼是中間件】中間件是指在應用程式處理請求之前和之後,對請求和回應做

在Yii框架中,控制器(Controllers)扮演著處理請求的重要角色。除了處理常規的頁面請求之外,控制器還可以用於處理Ajax請求。本文將介紹在Yii框架中處理Ajax請求的方法,並提供程式碼範例。在Yii框架中,處理Ajax請求可以透過以下步驟進行:第一步,建立一個控制器(Controller)類別。可以透過繼承Yii框架提供的基礎控制器類別yiiwebCo

使用Yii框架中間件加密和解密敏感資料引言:在現代的網路應用中,隱私和資料安全是非常重要的問題。為了確保用戶的敏感資料不會被未經授權的訪客取得,我們需要對這些資料進行加密。 Yii框架為我們提供了一種簡單且有效的方法來實現加密和解密敏感資料的功能。在本文中,我們將介紹如何使用Yii框架的中間件來實現這一目標。 Yii框架簡介Yii框架是一個高效能的PHP框架,
