**1 thinkphp5開發流程**

目錄配置如圖【IDE phpstorm】
1. 把public文件夾下面的index.php和.htaccess都放到根目錄下
2. 
3. 修改如上圖所示。最好自己自定義一個ROOt_PATH.方便未來上傳文件或者進行xls以及word讀寫編輯的時候發生路徑不統一的問題
4. 把build.php放到runtime下面。方便git進行配置。因為runtime設置為gitignore
5. 隨后自己新建一個模塊。命名隨意。只需要有Controller文件夾。同時又一個php控制器!
* * * * *
~~~
namespace app\xzxs\controller;
class Build
{
public function index(){
$build = new \think\Build();
$info = require APP_PATH."/runtime/build.php";
$build->run($info);
}
}
~~~
* * * * *
6. 訪問http://localhost/yourfolder/YourModel/YourController/index/ 就可以看到生成了所有的目錄。分別為Api對應輸出目錄。后臺backstage,前臺index。另外需要再有一個基礎控制模塊。
7. 至此整個運行流程創建完成。可以根據以前版本一樣進行流程開發
* * * * *
**2 Cron定時器**
前提:需要自己在behavior下面先新建CronRunBehavior.php
代碼如下:
~~~
namespace Behavior;
/**
* 自動執行任務
*/
class CronRunBehavior {
public function run(&$params) {
// 鎖定自動執行
$lockfile = RUNTIME_PATH.'cron.lock';
if(is_writable($lockfile) && filemtime($lockfile) > $_SERVER['REQUEST_TIME'] - C('CRON_MAX_TIME',null,60)) {
return ;
} else {
touch($lockfile);
}
set_time_limit(1000);
ignore_user_abort(true);
// 載入cron配置文件
// 格式 return array(
// 'cronname'=>array('filename',intervals,nextruntime),...
// );
if(is_file(RUNTIME_PATH.'~crons.php')) {
$crons = include RUNTIME_PATH.'~crons.php';
}elseif(is_file(APP_PATH.'crons.php')){
$crons = include APP_PATH.'crons.php';
}
if(isset($crons) && is_array($crons)) {
$update = false;
$log = array();
foreach ($crons as $key=>$cron){
if(empty($cron[2]) || $_SERVER['REQUEST_TIME']>=$cron[2]) {
// 到達時間 執行cron文件
G('cronStart');
include ROOT_PATH.'public/cron/'.$cron[0].'.php';
G('cronEnd');
$_useTime = G('cronStart','cronEnd', 6);
// 更新cron記錄
$cron[2] = $_SERVER['REQUEST_TIME']+$cron[1];
$crons[$key] = $cron;
$log[] = "Cron:$key Runat ".date('Y-m-d H:i:s')." Use $_useTime s\n";
$update = true;
}
}
if($update) {
// 記錄Cron執行日志
\Think\Log::write(implode('',$log));
// 更新cron文件
$content = "<?php\nreturn ".var_export($crons,true).";\n?>";
file_put_contents(RUNTIME_PATH.'~crons.php',$content);
}
}
// 解除鎖定
unlink($lockfile);
return ;
}
}
~~~
或者從3.2.3拷貝。但是需要做一定修改
需要application目錄如下

首先在Tags.php里面進行如下配置
~~~
return array(
'app_begin' => array('behavior\CronRunBehavior'),
);
~~~
然后在crons.php里面進行如下配置
~~~
return array(
'測試定時任務' => array('index', '10', ''), //路徑(格式同R)、間隔秒(0為一直運行)、指定一個開始時間
);
~~~

對應的運行文件在如下目錄
**3 Taglib類庫自動加載**
- 更新記錄
- 概述
- 文件索引
- 函數索引
- 章節格式
- 框架流程
- 前:章節說明
- 主:(index.php)入口
- 主:(start.php)框架引導
- 主:(App.php)應用啟動
- 主:(App.php)應用調度
- C:(Controller.php)應用控制器
- M:(Model.php)數據模型
- V:(View.php)視圖對象
- 附:(App.php)應用啟動
- 附:(base.php)全局變量
- 附:(common.php)模式配置
- 附:(convention.php)全局配置
- 附:(Loader.php)自動加載器
- 附:(Build.php)自動生成
- 附:(Hook.php)監聽回調
- 附:(Route.php)全局路由
- 附:(Response.php)數據輸出
- 附:(Log.php)日志記錄
- 附:(Exception.php)異常處理
- 框架工具
- 另:(helper.php)輔助函數
- 另:(Cache.php)數據緩存
- 另:(Cookie.php)cookie操作
- 另:(Console.php)控制臺
- 另:(Debug.php)開發調試
- 另:(Error.php)錯誤處理
- 另:(Url.php)Url操作文件
- 另:(Loader.php)加載器實例化
- 另:(Input.php)數據輸入
- 另:(Lang.php)語言包管理
- 另:(ORM.php)ORM基類
- 另:(Process.php)進程管理
- 另:(Session.php)session操作
- 另:(Template.php)模板解析
- 框架驅動
- D:(\config)配置解析
- D:(\controller)控制器擴展
- D:(\model)模型擴展
- D:(\db)數據庫驅動
- D:(\view)模板解析
- D:(\template)模板標簽庫
- D:(\session)session驅動
- D:(\cache)緩存驅動
- D:(\console)控制臺
- D:(\process)進程擴展
- T:(\traits)Trait目錄
- D:(\exception)異常實現
- D:(\log)日志驅動
- 使用范例
- 服務器與框架的安裝
- 控制器操作
- 數據模型操作
- 視圖渲染控制
- MVC開發初探
- 模塊開發
- 入口文件定義全局變量
- 運行模式開發
- 框架配置
- 自動生成應用
- 事件與插件注冊
- 路由規則注冊
- 輸出控制
- 多種應用組織
- 綜合應用
- tp框架整合后臺auto架構快速開發
- 基礎原理
- php默認全局變量
- php的魔術方法
- php命名空間
- php的自動加載
- php的composer
- php的反射
- php的trait機制
- php設計模式
- php的系統時區
- php的異常錯誤
- php的輸出控制
- php的正則表達式
- php的閉包函數
- php的會話控制
- php的接口
- php的PDO
- php的字符串操作
- php的curl
- 框架心得
- 心:整體結構
- 心:配置詳解
- 心:加載器詳解
- 心:輸入輸出詳解
- 心:url路由詳解
- 心:模板詳解
- 心:模型詳解
- 心:日志詳解
- 心:緩存詳解
- 心:控制臺詳解
- 框架更新
- 4.20(驗證類,助手函數)
- 4.27(新模型Model功能)
- 5.4(新數據庫驅動)
- 7.28(自動加載)