CI修改如下:

	if($modle_file=config_item('modle_file'))
{
if ($modle_file === TRUE)
{
$modle_file=config_item('modle_type'); $MOF=& load_class('Newfile','core'); //$MOF->createModule($modle_file); //创建文件加载类
$MOF->createModule();
}
}

<?php /**
* 这是一个扩展类
*
* 主要用来添加 常用的model模块还有controller控制器
*/
defined('BASEPATH') OR exit('No direct script access allowed'); /**
* model、controller扩展类
*
* @package CodeIgniter
* @subpackage Libraries
* @category Logging
* @author shaonian
* @link
*/
class CI_Newfile
{ /**
* 常用模块列表
*
* @var array
*/
protected $_model_arr=['Admin']; //模块前戳
protected $_model_prefix='Model_'; //自定义模块
protected $custom_model=[]; /**
* 常用控制器列表
*
* @var int
*/
protected $_controller_arr = []; //自定义控制器
protected $custom_controller=[]; /**
* 目录权限
*
* @var int
*/
protected $_chmod = 0775; /**
* 创建时间
*
* @var string
*/
protected $_date_fmt = 'Y-m-d H:i:s'; //获取全部的定义
protected $_arr_info=[]; /**
* 控制类
*
* 其实这个类 也可以写在扩展里面 因为 ci本来就让扩展用法的
*
* 这里支持两种方法 一种 在定义的环境下config配置 一种定义下的直接读取单独个配置文件
*
* @return void
*/
public function __construct($is_build=false)
{
$config =& get_config(); //加载全局配置文件 if (!empty($config['custom_controller']))
{
$this->custom_controller=$config['custom_controller'];
} if (!empty($config['custom_model']))
{
$this->custom_model=$config['custom_model'];
}
} /**
* 根据路径创建模块
*
* @param [type] $path
* @return void
*/
public function createModule($is_type_system='new')
{ //根文件
// $Model_path_base=BASEPATH.'core/newfile/model/'.$is_type_system.DIRECTORY_SEPARATOR; // $this->mkdirs($Model_path_base); //递归创建目录 // $get_content=$this->file_get_contents_write($Model_path_base); //马上 //还有一种方法
/**
* $content=$get_content instanceof Iterator; 这个详细的方法 看php手册的 迭代接口
*/ // foreach($get_content as $model_key=>$content)
// { // //创建文件
// $this->mkdirs(APPPATH.'models/sys/'); // file_put_contents(APPPATH.'models/sys/'.$model_key.'.php', $content);
// } if(!empty($this->custom_model)) { //循环自定义的控制器
foreach($this->custom_model as $model_k=>$model_v) { if (strpos($model_v, '/')!==false) { //这段程序处理前面的目录的 支持无限极目录
$dir_arr=explode('/', rtrim($model_v, '/'));
array_pop($dir_arr);
$dir_str=(count($dir_arr)>=2)?implode('/', $dir_arr):$dir_str[0];
$this->mkdirs(APPPATH.'models/'.$dir_str.DIRECTORY_SEPARATOR); }
//读模板内容
$content_con=$this->modelTpl($this->_model_prefix.ucwords($model_v)); if(!empty($dir_str)) { $file_path=APPPATH.'models/'.$dir_str.DIRECTORY_SEPARATOR.$this->_model_prefix.ucwords($model_v).'.php'; }
$file_path=APPPATH.'models/'.$this->_model_prefix.ucwords($model_v).'.php'; if (file_exists($file_path)==true) { continue;
} //echo $file_path;
file_put_contents($file_path, $content_con); }
} } /**
* 这里用的是思想模板替换
* 这里我都没判断应用目录是否可写 这是不对的
*
* @param string $is_type_system
* @return void
*/
public function createController($is_type_system='new')
{
// //根文件
// $controller_path_base=BASEPATH.'core/newfile/controller/'.$is_type_system.DIRECTORY_SEPARATOR; // $this->mkdirs($controller_path_base); //递归创建目录 // $get_content=$this->file_get_contents_write($controller_path_base); // //这里创建常用的代码
// foreach($get_content as $controller_key=>$content)
// { // //创建文件
// $this->mkdirs(APPPATH.'controller/sys/'); // file_put_contents(APPPATH.'controller/sys/'.$controller_key.'.php', $content);
// } //这里创建配置文件中的控制器,支持层级创建目录 if(!empty($this->custom_controller)) { //循环自定义的控制器
foreach($this->custom_controller as $controller_k=>$controller_v) { if (strpos($controller_v, '/')!==false) { //这段程序处理前面的目录的 支持无限极目录
$dir_arr=explode('/', rtrim($controller_v, '/'));
array_pop($dir_arr);
$dir_str=(count($dir_arr)>=2)?implode('/', $dir_arr):$dir_str[0];
$this->mkdirs(APPPATH.'controller/'.$dir_str.DIRECTORY_SEPARATOR); }
//读模板内容
$content_con=$this->controolerTpl(ucwords($controller_v)); if(!empty($dir_str)) { $file_path=APPPATH.'controllers/'.$dir_str.DIRECTORY_SEPARATOR.ucwords($controller_v).'.php'; }
$file_path=APPPATH.'controllers/'.ucwords($controller_v).'.php'; if (file_exists($file_path)==true) { continue;
} //echo $file_path;
file_put_contents($file_path, $content_con); }
} } /**
* 生成controller模板
*
* @param [type] $controoler_name
* @return void
*/
public function controolerTpl($controoler_name)
{
$content='';
$content.="<?php\ndefined('BASEPATH') OR exit('No direct script access allowed');\n\n\n\nclass {$controoler_name} extends MY_Controller\n{\n\n";
$content.=" public function __construct()\n {\n parent::__construct();\n }\n\n}"; return $content;
} public function modelTpl($model_name)
{
$content='';
$content.="<?php\ndefined('BASEPATH') OR exit('No direct script access allowed');\n\n\n\nclass {$model_name} extends MY_Model\n{\n\n";
$content.=" public function __construct()\n {\n parent::__construct();\n }\n\n}"; return $content; } /**
* 创建目录
*
* @access protected
* @param string $dirname 目录名称
* @return void
*/
protected static function checkDirBuild($dirname)
{
!is_dir($dirname) && mkdir($dirname, 0755, true);
} /**
* 根据传入的 build 资料创建目录和文件
*
* @access public
* @param array $build build 列表
* @param string $namespace 应用类库命名空间
* @param bool $suffix 类库后缀
* @return void
* @throws Exception
*/
public static function run(array $build = [], $namespace = 'app', $suffix = false)
{
// 锁定
$lock = APP_PATH . 'build.lock'; // 如果锁定文件不可写(不存在)则进行处理,否则表示已经有程序在处理了
if (!is_writable($lock)) {
if (!touch($lock)) {
throw new Exception(
'应用目录[' . APP_PATH . ']不可写,目录无法自动生成!<BR>请手动生成项目目录~',
10006
);
} foreach ($build as $module => $list) {
if ('__dir__' == $module) {
// 创建目录列表
self::buildDir($list);
} elseif ('__file__' == $module) {
// 创建文件列表
self::buildFile($list);
} else {
// 创建模块
self::module($module, $list, $namespace, $suffix);
}
} // 解除锁定
unlink($lock);
}
} /*
* 创建文件
* @access protected
* @param array $list 文件列表
* @return void
*/
protected static function buildFile($list)
{
foreach ($list as $file) {
// 先创建目录
if (!is_dir(APP_PATH . dirname($file))) {
mkdir(APP_PATH . dirname($file), 0755, true);
} // 再创建文件
if (!is_file(APP_PATH . $file)) {
file_put_contents(
APP_PATH . $file,
'php' == pathinfo($file, PATHINFO_EXTENSION) ? "<?php\n" : ''
);
}
}
} /**
* 循环读取文件并创建
* 其实可以不用生成器的 反正就4个文件 file_Get_content直接读取 这些文件 还不到 10kb也挺快的
*/
public function file_get_contents_write($path)
{
foreach($this->_model_arr as $val)
{
if(!file_exists($path.strtolower($val).'.txt')) {
echo "你的文件{$this->_model_prefix}{$val}未找到,请放入后查看";exit(0);
}
yield $this->_model_prefix.$val=>file_get_contents($path.strtolower($val).'.txt');
}
} /**
* 递归创建目录
*
* @param [type] $dir
* @return void
*/
public function mkdirs($dir=null)
{
return is_dir($dir) or ($this->mkdirs(dirname($dir))) and mkdir($dir, 0755);
} //在这里要实现数据库的话 得调用文件的为 database.php 文件 //还得吧 loader的db文件拿过来用 这个类 可以在controller后面加载 }

ci框架根据配置自动生成controller控制器和model控制器(改版本)的更多相关文章

  1. 使用mybatis plus自动生成controller、service、dao、mapper、entity代码

    官网:http://mp.baomidou.com(这个项目不仅仅可以用于代码生成,还有分页等其他功能,是对mybatis的一层封装) 要求:基于sql自动生成domain.controller.se ...

  2. Spring Boot从入门到精通(十一)集成Swagger框架,实现自动生成接口文档

    Swagger是一个规范和完整的框架,用于生成.描述.调用和可视化 RESTful 风格的 Web 服务.Swagger 是一组开源项目,其中主要要项目如下: Swagger-tools:提供各种与S ...

  3. SSM框架通过mybatis-generator自动生成代码

    一.首先eclipse配置好maven环境,并且创建好一个SSM框架的工程 二.在pom.xml中添加plugin <build> <finalName>ssm_web< ...

  4. CI框架基本配置/教你学习CI框架codelgniter

    CI框架现在中国可以说还是不成熟,不像thinkphp那样有那么多的中文手册,在国内,很多国人英语都很烂,CI现在教程还是不多.大家心里都存在这严重想法 CI 框架现在中国可以说还是不成熟,不像thi ...

  5. hibernate如何配置自动生成表

    hibernate自动生成表有两种方法: 1.直接写代码,通过方法来创建数据库表. 2.通过 hibernate.cfg.xml配置标签来创建数据表. 下面依次实现: 1.直接写代码,通过方法来创建数 ...

  6. unittest框架扩展(自动生成用例)自动化-上

    一.思想: 基于数据驱动和代码驱动结合的自动化测试框架. 二.自动化测试框架步骤: 1.获取用例,用例格式:.ymal 2.调用接口 3.校验结果 4.发送测试报告 5.异常处理 6.日志模块 三.基 ...

  7. ci框架 自定义配置方法

    系统自动在Application文件夹下生成的config.php文件,采用key-value关联数组的形式来存放配置项和值.为了使结构更清晰,手动新建另外一个配置文件myconfig.php,所采用 ...

  8. mybatis generator.xml 配置 自动生成model,dao,mapping

    generator.xml文件: <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE gener ...

  9. Nginx 支持 CI 框架的配置并禁止使用 ip 访问

    #CIserver {        listen      80;        server_name www.ci.com;        index       index.php index ...

随机推荐

  1. LCD显示器缺陷自动化检测方案

    很牛的测试 参考: 1.https://www.radiantvisionsystems.com/ 2.https://www.radiantvisionsystems.com/node/275 LC ...

  2. Spring Boot+Spring Security+JWT 实现 RESTful Api 认证(二)

    Spring Boot+Spring Security+JWT 实现 RESTful Api 认证(二) 摘要 上一篇https://javaymw.com/post/59我们已经实现了基本的登录和t ...

  3. TTL电平,CMOS电平,232/485电平,OC门,OD门基础知识

     1.RS232电平 或者说串口电平,有的甚至说计算机电平,所有的这些说法,指得都是计算机9针串口 (RS232)的电平,采用负逻辑, -15v ~ -3v 代表1 +3v ~ +15v 代表0 2. ...

  4. Linux系统的一些问题

    1.操作系统提供的服务: - 进程调度 - 内存管理 - 磁盘管理 - 网络服务 - 设备管理 - 提供应用程序编程接口 2.shell是什么? shell是一种具有特殊用途的程序,主要用于读取用户输 ...

  5. 多测师讲解常用的测试工具分为10类_高级讲师肖sir

    我们将常用的测试工具分为10类. 1. 测试管理工具 2. 接口测试工具 3. 性能测试工具 4. C/S自动化工具 5.白盒测试工具 6.代码扫描工具 7.持续集成工具 8.网络测试工具 9.app ...

  6. Gradle的构建过程都不会?带你全面了解Android如何自定义Gradle 插件

    目前 Android 工程的默认构建工具为 Gradle,我们在构建 APK 的时候往往会执行 ./gradlew assembleDebug 这样的命令.. 那么这个命令到底代表着什么含义呢?命令的 ...

  7. 【学习笔记】Min-max 容斥

    经常和概率期望题相结合. 对于全序集合 \(S\),有: \[\max S=\sum\limits_{T\subseteq S,T\not=\varnothing}(-1)^{\vert T\vert ...

  8. 【线段树分治】Dash Speed

    代码的美妙 #include <bits/stdc++.h> %:pragma GCC optimize(3) using namespace std; const int maxn=7e ...

  9. golang拾遗:为什么我们需要泛型

    从golang诞生起是否应该添加泛型支持就是一个热度未曾消减的议题.泛型的支持者们认为没有泛型的语言是不完整的,而泛型的反对者们则认为接口足以取代泛型,增加泛型只会徒增语言的复杂度.双方各执己见,争执 ...

  10. 【转】time 模块详解(时间获取和转换)

    转自鱼C论坛--https://fishc.com.cn/forum.php?mod=viewthread&tid=51326&highlight=time time 模块 -- 时间 ...