首頁  >  文章  >  後端開發  >  ThinkPHP空操作、空白控制器處理

ThinkPHP空操作、空白控制器處理

高洛峰
高洛峰原創
2017-02-09 10:05:101484瀏覽

當一個高手瀏覽你的網站的時候,你網站的報錯訊息將給駭客提供攻擊你網站的資訊。例如空操作、空控制器,你會暴露給給駭客你網站後台所使用的框架,駭客會根據框架本省的漏洞對你網站進行攻擊。因此,我們需要對空控制器、空操作進行處理,不給駭客留下任何蛛絲馬跡。

1. 空操作處理

首先看一下效果:
對於我在IndexController.class.php這個文件裡我並沒有hello這個方法,擔任如果我試圖去訪問這個方式時,會報如下信息:
註:空操作的本質:一個物件(控制器)呼叫本身不存在的方法

ThinkPHP空操作、空控制器处理


對於懂ThinkPHP的開發人員來說,很容易看出此網站後台用的是ThinkPHP框架。那我們要怎麼來屏蔽這些問題呢?這就是我們今天要討論的內容。

解決方式1,在控制器裡添加一個__call($method,$argvs)的方法

ThinkPHP空操作、空控制器处理

ThinkPHP空操作、空控制器处理
這樣,當你再次訪問hello方法是就會默認調用控制器的__call((( $method,$args)方法。

但是!當我們有很多個控制器的時候,我還要每個控制器都寫一個__call($method,$args)方法?顯然不合理!因此,我們需要把此方法寫到控制器的父類別裡,只需透過繼承的方式即可。我們走進Controller.class.php卻能找到__call()方法,因為TP已經幫我們做好了,在他的思想裡,是看我們是否在控制器裡定義了一個叫做_empty()的方法。如果定義了,則呼叫這個方法

普通控制器父類別的位置:ThinkPHP/Library/Think/Controller.class.php

解決方式2

給空操作的名稱製作一個同名的模板出來,解決方式2

給空操作的名稱製作一個同名的模板出來,系統會自動呼叫該模板。

2. 空控制器處理ThinkPHP空操作、空控制器处理

由於沒有BeijingController.class.php這個文件,所以報錯了! !

經過分析TP框架的源碼,我們有如下解ThinkPHP空操作、空控制器处理

所以,我們需要定義一個空的控制器。當我們存取不存在的控制器的時候,就會按照我們指定的錯誤給我們報錯。 ThinkPHP空操作、空控制器处理

ThinkPHP空操作、空控制器处理

好啦,空操作、空控制器就先說到這裡O(∩_∩)O~~

當一個高手瀏覽你的網站的時候,你的網站的報錯資訊將給駭客提供攻擊你網站的資訊。例如空操作、空控制器,你會暴露給給駭客你網站後台所使用的框架,駭客會根據框架本省的漏洞對你網站進行攻擊。因此,我們需要對空控制器、空操作進行處理,不給駭客留下任何蛛絲馬跡。

1. 空操作處理



首先看一下效果:

對於我在IndexController.class.php這個文件裡我並沒有hello這個方法,擔任如果我試圖去訪問這個方式時,會報如下信息:

註:空白操作的本質:一個物件(控制器)呼叫本身不存在的方法ThinkPHP空操作、空控制器处理


🎜對於懂ThinkPHP的開發人員來說,很容易看出此網站後台用的是ThinkPHP框架。那我們要怎麼來屏蔽這些問題呢?這就是我們今天要討論的內容。 🎜

解決方式1,在控制器裡添加一個__call($method,$argvs)的方法

ThinkPHP空操作、空控制器处理

ThinkPHP空操作、空控制器处理
這樣,當你再次訪問hello方法是就會默認調用控制器的__call(&dollar ;method,$args)方法。

但是!當我們有很多個控制器的時候,我還要每個控制器都寫一個__call($method,$args)方法?顯然不合理!因此,我們需要把此方法寫到控制器的父類別裡,只需透過繼承的方式即可。我們走進Controller.class.php卻能找到__call()方法,因為TP已經幫我們做好了,在他的思想裡,是看我們是否在控制器裡定義了一個叫做_empty()的方法。如果定義了,則呼叫這個方法

普通控制器父類別的位置:ThinkPHP/Library/Think/Controller.class.php

解決方式2

給空操作的名稱製作一個同名的模板出來,解決方式2

給空操作的名稱製作一個同名的模板出來,系統會自動呼叫該模板。

2. 空控制器處理ThinkPHP空操作、空控制器处理

由於沒有BeijingController.class.php這個文件,所以報錯了! !

經過分析TP框架的源碼,我們有如下解ThinkPHP空操作、空控制器处理

所以,我們需要定義一個空的控制器。當我們存取不存在的控制器的時候,就會按照我們指定的錯誤給我們報錯。 ThinkPHP空操作、空控制器处理

ThinkPHP空操作、空控制器处理

更多ThinkPHP空白操作、空白控制器處理 相關文章請關注PHP中文網!

🎜🎜
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn