waiterphp的核心类库
该项目提供了php的一些基础操作封装。可直接采用composer装载该类。, (*1)
以下是类库的相关功能介绍。, (*2)
可通过以下方式获取配置文件中的数据。, (*3)
$configs = load_configs($fileNames);
函数可以从basePaths设置的多个路径里面,加载fileNames里面设置的多个文件中的内容,覆盖顺序为后者覆盖前者。, (*4)
通过以下函数设置环境变量和获取环境变量:, (*5)
set_env('app_name', 'waiterphp_core'); print get_env('app_name');
可采用dot方式,如下两种写法作用相同:, (*6)
set_env('database.default.username', 'test'); set_env('database', [ 'default'=>[ 'username'=>'test' ] ]);
也可以直接写入数组:, (*7)
set_env(['database'=>['default'=>[ 'host'=>'localhost', 'username'=>'root', 'password'=>'', 'database'=>'tests' ]]])
注意:, (*8)
重复设置的环境变量,后者会覆盖前者 环境变量有一些默认键名,如database为数据库设置,cache为缓存设置,函数会检测该键名,并自动初始化到相关类库, (*9)
// 设置数据库配置,可通过load_configs从文件直接装载 set_env('database.default', [ 'host'=>'127.0.0.1', 'username'=>'root', 'password'=>'', 'database'=>'tests' ]); // 获取多行数据 $data = table('article')->select('articleId,userId,title,hit as hit_num') ->where([ 'userId'=>1, 'articleId'=>[1,2,3,4,5,6,7,8], 'addTime >='=>'2018-01-01 00:00:00', 'title like'=>'%测试%' ])->orderBy('articleId desc') ->limit(10) ->offset(0)->fetchAll(); // 获取单行 $data = table('article')->where(['userId'=>1])->fetchRow(); // 写入数据 $articleId = table('article')->insert([ 'userId'=>2, 'title'=>'insert data' ]); // 删除数据 table('article')->where([ 'articleId'=>$articleId ])->delete(); // 更新数据 table('article')->where([ 'articleId'=>1 ])->update([ 'hit'=>211 ]); // 表达式更新 table('article')->where([ 'articleId'=>1 ])->update([ 'hit=hit+1' ]); // 统计 table('article')->where(['userId'=>1])->count(); // 分组 table('article')->select('userId,count(*)')->groupBy('userId')->fetchAll();
//file // redis set_env('cache.redis', []); cache('redis')->hmget('some_key'); // memcache
set_env('view', []); echo render('user/login.html', ['username'=>'测试'], 'smarty');
第三个参数可以选择你采用的渲染引擎,默认为smarty。 目前可支持的有:smarty、twig, (*10)
可以设置自定义的第三个参数,要求类本身实现render方法。如下:, (*11)
set_env('view', []); render('user/login.html', ['username'=>'测试'], 'tools.myView');
页面渲染需在您自己的项目composer.json中加入相关类库,, (*12)
use waiterphp\core\database\DaoTrait; class User { use DaoTrait; }
可以利用trait快速构建一个过滤器, (*13)
use waiterphp\core\Filter\FilterTrait; class HttpRequest { use Filter; }
当然,你也可以直接使用Filter直接过滤数据, (*14)
filter($data)->getInt('userId', '');
注意:, (*15)
第二个参数为默认值。如果没有设置,当获取不到数据时,抛出异常!, (*16)
用法如下:, (*17)
assert_exception(false, '程序异常!', 500);
bind_to_env($tab, $action); env_trigger($tab, $params = []);
build();
print request()->hostname(); print request()->query(); print request()->query('userId'); print request()->post(); print request()->post('userId');
curl($url, $params, $httpType, $header);
get_files('/home/user'); write('/home/user/test.txt', $content, 'a+');