thinkphp5底层基类封装、内部类函数
记录下thinkphp5自定义底层基类、内部类函数使用笔记 大部分笔记来自tp手册。
底层常用代码的封装
在控制器中基类的起着至关重要的作用,整个项目的代码安全,复杂程度,易读性都要看你项目的基类架构的.
比如api中都需要某一个功能函数,我们就可以写在基类里。
贴上一个基类返回错误码的例子:
<?php
namespace app\member\controller;
class Base extends \app\base\controller\Base
{
static public function showReturnCode($code = '', $data = [], $msg = '')
{
$return_data = [
'code' => '500',
'msg' => '未定义消息',
'data' => $code == 1001 ? $data : [],
];
if (empty($code)) return $return_data;
$return_data['code'] = $code;
if(!empty($msg)){
$return_data['msg'] = $msg;
}else if (isset(ReturnCode::$return_code[$code]) ) {
$return_data['msg'] = ReturnCode::$return_code[$code];
}
return $return_data;
}
static public function showReturnCodeWithOutData($code = '', $msg = '')
{
return self::showReturnCode($code,[],$msg);
}
}
基类:
<?php
namespace app\base\controller;
class ReturnCode
{
static public $return_code = [
'1001' => '操作成功',
'1002' => '你想做什么呢', //非法的请求方式 非ajax
'1003' => '请求参数错误', //如参数不完整,类型不正确
'1004' => '请先登陆再访问', //未登录 或者 未授权
'1005' => '请求授权不符', ////非法的请求 无授权查看
'1006' => '数据加载失败', //
'1010' => '数据不存在', //
'1020' => '验证码输入不正确', //
'1021' => '用户账号或密码错误', //
'1022' => '用户账号被禁用', //
'1030' => '数据操作失败', //
];
}
然后就可以调用了
private function getUid(){
//数据库字段 网页字段转换
$param = [
'userid' => 'userid',
'userpwd' => 'userpwd',
'mobile' => 'mobile',
];
$param_data = $this->buildParam($param);
if (empty($param_data['userid'])&&empty($param_data['mobile'])) return self::showReturnCodeWithOutData(1003);
$check_login = $this->doModelAction($param_data, 'base/Member.login', 'base/Member', 'checkLogin');
if (!isset($check_login['code'])) $this->showReturnCodeWithSaveLog(1111);
if ($check_login['code'] == 1001) {
}
return $check_login;
}
框架构造函数使用
构造函数 在类的初始化时候执行的一个方法,构造函数中不要使用return关键词。
那么我们经常在构造函数里面做做什么呢?
- 数据初始化 注入对象等
- 前置工作的处理
- 权限判断
我们看一下TP5 控制器的构造函数,他在初始化时候注入了request对象,我们继承了控制器,直接就可以使用$this->request调用,同时也封装了View类.同时对前置的beforeActionList属性的方法 进行处理.
public function __construct(Request $request = null)
{
if (is_null($request)) {
$request = Request::instance();
}
$this->view = View::instance(Config::get('template'), Config::get('view_replace_str'));
$this->request = $request;
// 控制器初始化
$this->_initialize();
// 前置操作方法
if ($this->beforeActionList) {
foreach ($this->beforeActionList as $method => $options) {
is_numeric($method) ?
$this->beforeAction($options) :
$this->beforeAction($method, $options);
}
}
}
对于权限判断的例子:
public function _initialize()
{
parent::_initialize(); // TODO: Change the autogenerated stub
$user_agent = $this->request->server('HTTP_USER_AGENT');
if (! strpos($user_agent, 'MicroMessenger') === false ) $this->isWechatBrowser = true;
//判断提交方式和是否微信浏览器
if ($this->request->method() == 'GET' && $this->isWechatBrowser === true){
//未登录 重新登录
if (!$this->checkAuth()&& !$this->no_login ) $this->wxoauth();
$this->isLogin=true;
//设置全局登录
$this->loginGlobal();
if(!$this->isReg){
if(!$this->checkUuidMobile()) $this->redirect('user/user_blind.html');
}
}
}
控制起来继承:
<?php
namespace app\api\controller;
class WxpayAction extends Auth
{
public function _initialize()
{
config('default_return_type','html');
parent::_initialize(); // TODO: Change the autogenerated stub
}
public function index($order_no='2017020453102495'){
if(!$this->isWechatBrowser){
//*******
为了演示方便 这里省略了订单的是否支付验证
另外 微信支付本身就有支付重复验证 这里并没有加入乐观锁过滤
//*******
$data=controller('base/WxPay')->payByOrderNo($order_no);
$assign_data=[
'title'=>'为了家健康--订单支付',
'amount'=>$data['amount'],
'order_no'=>$order_no,
"jsApiParameters" =>$data['jsApiParameters'],
'openid'=>$this->open_id,
'data_md5'=>md5($order_no.$this->open_id.$data['amount']), //md5验证( 订单号 openid 金额)
];
$this->assign($assign_data);
return $this->fetch('wxpay/index');
}
public function showOrdersPayOk($order_no,$order_amount,$data_md5){
//md5验证( 订单号 openid 金额)
if (md5($order_no.$this->open_id.$order_amount)<>$data_md5){
$assign_data=[
'title'=>'为了家健康--支付出错了',
'content'=>'你要支付的订单号不存在请核对后再支付!',
];
$this->assign($assign_data);
return $this->fetch('wxpay/err');
}else{
$assign_data=[
'title'=>'为了家健康--该订单已经支付成功',
'amount'=>$order_amount,
'order_no'=>$order_no,
];
$this->assign($assign_data);
return $this->fetch('wxpay/ok');
}
}
public function jsSign($url=''){
$url= $url ? : $this->request->server('HTTP_REFERER');
return json(controller('base/WxApi')->getJsSign($url));
}
框架析构函数使用
析构函数就是一个收尾的一个方法,
例子:创建一个虚拟基类
<?php
namespace app\base\controller;
use think\Cache;
use think\Controller;
use think\Session;
use think\Loader;
abstract class Base extends Controller
{
protected $error; //出错时候的记录
protected $log=[]; //要保存的记录
protected $saveLog = false ;
static public function showReturnCode($code = '', $data = [], $msg = '')
{
$return_data = [
'code' => '500',
'msg' => '未定义消息',
'data' => $code == 1001 ? $data : [],
];
if (empty($code)) return $return_data;
$return_data['code'] = $code;
if(!empty($msg)){
$return_data['msg'] = $msg;
}else if (isset(ReturnCode::$return_code[$code]) ) {
$return_data['msg'] = ReturnCode::$return_code[$code];
}
return $return_data;
}
protected function addLog($code='',$msg=''){
$this->log[] =[
'uuid' => $this->uuid,
'url' => $this->request->url(true),
'method' => $this->request->method(),
'data' => $this->getData(),
'ip' => $this->request->ip(),
'code'=>$code,
'desc' => $msg,
];
}
protected function toSaveLog(){
$this->saveLog = true ;
$this->addLog();
}
protected function showReturnCodeWithSaveLog($code = '', $data = [], $msg = ''){
$this->saveLog = true ;
$this->addLog($code,$msg);
return self::showReturnCode($code, $data, $msg);
}
protected function getData(){
if ($this->request->isPost()){
return $this->request->post();
}else{
return $this->request->get();
}
}
protected function saveLogAction(){
if (!empty($this->log)){
foreach($this->log as $value){
dump($value);
}
}
}
public function __destruct()
{
// TODO: Implement __destruct() method.
//记录日志
if (!empty($this->log) && $this->saveLog == true){
$this->saveLogAction();
}
}
}
控制器继承:
<?php
namespace app\member\controller;
use app\base\model\Member;
use think\Cache;
use think\Db;
class Test extends Base
{
public function index(){
return $this->showReturnCodeWithSaveLog(1001,'演示析构函数成功了');
}
}
thinkphp5底层基类封装、内部类函数的更多相关文章
- C++:抽象基类和纯虚函数的理解
转载地址:http://blog.csdn.net/acs713/article/details/7352440 抽象类是一种特殊的类,它是为了抽象和设计的目的为建立的,它处于继承层次结构的较上层. ...
- C++基础知识 基类指针、虚函数、多态性、纯虚函数、虚析构
一.基类指针.派生类指针 父类指针可以new一个子类对象 二.虚函数 有没有一个解决方法,使我们只定义一个对象指针,就可以调用父类,以及各个子类的同名函数? 有解决方案,这个对象指针必须是一个父类类型 ...
- 四、spring集成ibatis进行项目中dao层基类封装
Apache iBatis(现已迁至Google Code下发展,更名为MyBatis)是当前IT项目中使用很广泛的一个半自动ORM框架,区别于Hibernate之类的全自动框架,iBatis对数据库 ...
- salesforce 零基础学习(四十八)自定义列表分页之Pagination基类封装 ※※※
我们知道,salesforce中系统标准列表页面提供了相应的分页功能,如果要使用其分页功能,可以访问http://www.cnblogs.com/zero-zyq/p/5343287.html查看相关 ...
- Android 开发技巧 - Android 6.0 以上权限大坑和权限检查基类封装
简单介绍 关于运行时权限的说法,早在Google发布android 6.0的时候,大家也听得蛮多的.从用户的角度来讲,用户是受益方,更好的保护用户的意思,而对于开发者来说,无疑增加了工作量. 对于6. ...
- python基础(14)-反射&类的内置函数
反射 几个反射相关的函数可参考python基础(10)-匿名函数&内置函数中2.2.4反射相关 类的一些内置函数 __str__()&__repr__() 重写__str__()函数类 ...
- C++ 由虚基类 虚继承 虚函数 到 虚函数表
//虚基类:一个类可以在一个类族中既被用作虚基类,也被用作非虚基类. class Base1{ public: Base1(){cout<<"Construct Base1!&q ...
- (转)(C++)关于抽象基类和纯虚函数
★抽象类:一个类可以抽象出不同的对象来表达一个抽象的概念和通用的接口,这个类不能实例化(创造)对象. ★纯虚函数(pure virtual):在本类里不能有实现(描述功能),实现需要在子类中实现.例: ...
- python面向对象的多态-类相关内置函数-类内置魔法函数-迭代器协议-上下文管理-04
多态 一种事物具备不同的形态 例如:水 --> 固态.液态.气态 多态:# 多个不同对象可以相应同一个对象,产生不同的结果 首先强调,多态不是一种特殊的语法,而是一种状态,特性(多个不同对象可以 ...
随机推荐
- Zookeeper系列一:Zookeeper基础命令操作
有些事不是努力就可以改变的,五十块的人民币设计的再好看,也没有一百块的招人喜欢. 前言 由于公司年底要更换办公地点,所以最近投了一下简历,发现面试官现在很喜欢问dubbo.zookeeper和高并发等 ...
- Redis的实现(java)
日常操作 public static void main(String[] args) { Jedis jedis = ); //1.开启事务 Transaction transaction = je ...
- Redis相关安装TCL
安装相关命令 wget http://downloads.sourceforge.net/tcl/tcl8.6.1-src.tar.gzsudo tar -xzvf tcl8.6.1-src.tar. ...
- WebDriver 将浏览器窗口最大化
package com.entrym.main; import java.io.File; import java.io.IOException; import org.openqa.selenium ...
- 让你的AI模型尽可能的靠近数据源
来源:Redislabs作者:Pieter Cailliau.LucaAntiga翻译:Kevin (公众号:中间件小哥) 简介 今天我们发布了一个 RedisAI 的预览版本,预集成了[tensor ...
- git 添加子模块 fatal: You are on a branch yet to be born
删除与.git / modules /目录下的子模块具有相同路径的文件夹.当子模块添加子模块时,如果子模块的url不正确,则会出现此错误.
- oracle 11g 下载安装 使用记录
Oracle 11g 使用记录 1.下载oracle快捷安装版: (1)下载连接:https://pan.baidu.com/s/1ClC0hQepmTw2lSJ2ODtL7g 无提取码 (2)去 ...
- 项目管理知识点-结合Enovia项目管理模块
核心知识域:整体管理.范围管理.进度管理.成本管理.质量管理.信息安全管理 保障域:人力资源管理.合同管理.采购管理.风险管理.信息(文档)管理.配置管理.知识产权管理.法律法规标准规范管理.职业道德 ...
- 12.Django基础十之Form和ModelForm组件
一 Form介绍 我们之前在HTML页面中利用form表单向后端提交数据时,都会写一些获取用户输入的标签并且用form标签把它们包起来. 与此同时我们在好多场景下都需要对用户的输入做校验,比如校验用户 ...
- C#刷遍Leetcode面试题系列连载(1) - 入门与工具简介
目录 为什么要刷LeetCode 刷LeetCode有哪些好处? LeetCode vs 传统的 OJ LeetCode刷题时的心态建设 C#如何刷遍LeetCode 选项1: VS本地Debug + ...