zoukankan      html  css  js  c++  java
  • PHP获取项目所有控制器方法名称

    PHP获取项目所有控制器方法名称

      //获取模块下所有的控制器和方法写入到权限表
        public function initperm() {
            $modules = array('admin');  //模块名称
            $i = 0;
            foreach ($modules as $module) {
                $all_controller = $this->getController($module);
                foreach ($all_controller as $controller) {
                    $all_action = $this->getAction($module, $controller);
                    foreach ($all_action as $action) {
                        $controller = str_replace('Controller', '', $controller);
                        $data[$i]['module'] = $module;
                        $data[$i]['controller'] = $controller;
                        $data[$i]['action'] = $action;
    
                        //入库
                        if (!empty($module) && !empty($controller) && !empty($action)) {
                            $rule_name = $module . '-' . $controller . '-' . $action;
                            $rule = M()->table('tky_authrule')->where('name="' . strtolower($rule_name) . '"')->find();
                            if (!$rule) {
                                $idata = array();
                                $idata['module'] = strtolower($module . '-' . $controller);
                                $idata['type'] = "1";
                                $idata['name'] = strtolower($rule_name);
                                $idata['title'] = "";
                                $idata['regex'] = "";
                                $idata['status'] = "1";
                                M()->table('tky_authrule')->add($idata);
                            }
                        }
    
                        $i++;
                    }
                }
            }
            echo '<pre>';
            print_r($data);
            echo '</pre>';
        }
    
        //获取所有控制器名称
        private function getController($module) {
            if (empty($module)) {
                return null;
            }
            $module_path = APP_PATH . '/' . $module . '/controllers/';  //控制器路径
            if (!is_dir($module_path)) {
                return null;
            }
            $module_path .= '/*.php';
            $ary_files = glob($module_path);
            foreach ($ary_files as $file) {
                if (is_dir($file)) {
                    continue;
                } else {
                    $files[] = basename($file, '.php');
                }
            }
            return $files;
        }
    
        //获取所有方法名称
        protected function getAction($module, $controller) {
            if (empty($controller)) {
                return null;
            }
            $file = APP_PATH . $module . '/controllers/' . $controller . '.php';
            if (file_exists($file)) {
                $content = file_get_contents($file);
                preg_match_all("/.*?public.*?function(.*?)(.*?)/i", $content, $matches);
                $functions = $matches[1];
                //排除部分方法
                $inherents_functions = array('_initialize', '__construct', 'getActionName', 'isAjax', 'display', 'show', 'fetch', 'buildHtml', 'assign', '__set', 'get', '__get', '__isset', '__call', 'error', 'success', 'ajaxReturn', 'redirect', '__destruct', '_empty');
                foreach ($functions as $func) {
                    $func = trim($func);
                    if (!in_array($func, $inherents_functions)) {
                        $customer_functions[] = $func;
                    }
                }
                return $customer_functions;
            } else {
                	ickyLog::record('is not file ' . $file, Log::INFO);
            }
            return null;
        }

     mysql

    DROP TABLE IF EXISTS tky_authrule;
    CREATE TABLE tky_authrule (
    	ruleid MEDIUMINT (8) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT '编号',
    	module VARCHAR (20) NOT NULL DEFAULT '' COMMENT '规则所属module',
    	type TINYINT (1) NOT NULL DEFAULT '1' COMMENT '类型 1-url;2-主菜单',
    	name CHAR (80) NOT NULL DEFAULT '' COMMENT '规则唯一英文标识',
    	title CHAR (20) NOT NULL DEFAULT '' COMMENT '规则中文描述',
    	regex CHAR (100) NOT NULL DEFAULT '' COMMENT '规则表达式',
    	status TINYINT (1) NOT NULL DEFAULT '1' COMMENT '状态',
    	PRIMARY KEY (ruleid)
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT = '规则表';
    

      

  • 相关阅读:
    MongoDB 常用故障排查工具
    MongoDB ServerStatus返回信息
    SQL Server 2012实施与管理实战指南(笔记)——Ch6连接的建立和问题排查
    SQL Server 2012实施与管理实战指南(笔记)——Ch5启动SQL Server服务和数据库
    [20140504] ADO.NET客户端超时
    SQL Server 2012实施与管理实战指南(笔记)——Ch4数据库连接组件
    SQL Server 2012实施与管理实战指南(笔记)——Ch3Alwayson可用组
    SQL Server 2014新特性——Buffer Pool扩展
    SQL Server 2014新特性——事务持久性控制
    SQL Server 2014新特性——基数评估(白皮书阅读笔记)
  • 原文地址:https://www.cnblogs.com/luomingui/p/8444813.html
Copyright © 2011-2022 走看看