久久久久av_欧美日韩一区二区在线_国产精品三区四区_日韩中字在线

Discuz! 官方交流社區

標題: discuz X2如何判斷當前頁面的動作 [打印本頁]

作者: 我是小站長    時間: 2019-6-1 16:44
標題: discuz X2如何判斷當前頁面的動作
*************************************************
** 本教程基于版本:Discuz! X 2.0                                         **
*************************************************



在制作插件,或者想自己修改一些功能的時候,經常會遇到一個情況,就是需要獲取到當前頁面在進行一個什么動作,比如是在看帖,還是在看主題列表,或者是在搜索,還是在后臺操作。然后根據相關動作進行判斷執行什么代碼,比如在后臺操作,就自動記錄一些相關LOG,或者搜索的時候,把數據庫切換到從庫去。


X2在每個頁面都做了標記,很好的解決了這個問題。

隨便打開一個文件,就能看到類似
  1. define('CURSCRIPT', 'forum');
復制代碼

或者

  1. define('CURSCRIPT', 'admin');
復制代碼

這樣的語句,這就是入口文件標記。

通過判斷入口文件標記,能實現判斷現在在論壇還是家園,門戶,群組,后臺管理,雜項等。

下面是入口文件標記列表:

列表整理中....

通過判斷入口文件標記,已經能知道當前是在哪個大類下操作了。還可以通過判斷當前模塊,來實現更詳細的判斷,比如詳細到看帖,還是在列表頁。

下面是模塊標記列表:

列表整理中...

知道了怎么判斷當前頁面動作后,可以靈活的通過這個小技巧來自定義一些功能。下面是一個例子:

X2有讀寫分離功能,但是只要設置了讀寫分離,所有的讀取操作都到從庫去了。希望能靈活控制查詢從庫的動作。

在source/class/class_mysql_slave.php 文件下  有個 function query函數,可以在里面添加各種判斷進行控制。

例如
  1. if($this->slaveid && !$this->slaveexcept && strtoupper(substr($sql, 0 , 6)) == 'SELECT' && in_array(CURSCRIPT, array('search','misc','admin'))) {
復制代碼



那么就是只有“搜索”“統計和排行榜”“管理后臺”  才會進行讀取從庫,其他操作還是在主庫上進行。

再例如
  1. if($this->slaveid && !$this->slaveexcept && strtoupper(substr($sql, 0 , 6)) == 'SELECT' && in_array(CURSCRIPT, array('forum')) && in_array(CURMODULE, array('forumdisplay', 'viewthread'))) {
復制代碼


那么就是只有論壇的“列表頁”“看帖頁”才會讀取從庫,其他的操作全部還是讀取主庫的。

這只是其中一個靈活運用的例子,更多的還要根據自己的需要來進行修改,有了這些詳細的標記,那么判斷起來就隨心應手了。







歡迎光臨 Discuz! 官方交流社區 (http://www.9999xn.com/) Powered by Discuz! W1.0