一、目录和文件 1、目录使用小写+下划线,如admin/ 、 product_divert/; 2、类库、函数文件统一以.php为后缀,如app.php 、common.php; 3、类的文件名均以命名空间定义,并且命名空间的路径和类库文件所在路径一致,如ProductModel.php对应ProductModel类,命名空间app\common\model对应路径app/common/model/; 4、类(包含接口和Trait)文件采用驼峰法命名(首字母大写),类名(包括接口和Trait)和文件名保持一致,统一采用驼峰法命名(首字母大写),其它文件采用小写+下划线命名,如类文件app/common/logic/ConfigOptionsLogic.php对应ConfigOpitonsLogic类,公共函数文件app/common.php; 5、目录结构 finance 财务系统 ├─app 应用目录 │ ├─admin 后台 │ │ ├─controller 控制器目录 │ │ ├─model 模型目录(业务逻辑写这里或逻辑类里) │ │ ├─validate 验证器目录 │ ├─home 前台 │ │ ├─controller 控制器目录 │ │ ├─model 模型目录 │ │ ├─validate 验证器目录 │ ├─common 公共目录 │ │ ├─logic 逻辑类目录 │ │ ├─model 模型目录(前后台通用模型方法写这里面的model类) │ ├─command 命令行目录 │ │ ├─Cron.php 系统默认定时任务文件 │ ├─excption 错误处理目录 │ ├─http 网关目录 │ │ ├─middleware 中间件目录 │ ├─common.php 公共函数文件(写函数注释,比较通用的方式先写好,如curl) │ ├─middleware.php 中间件定义文件 ├─cron 定时任务 │ ├─cron.php 定时任务 ├─config 全局配置目录 │ ├─app.php 应用配置 │ ├─cache.php 缓存配置 │ ├─console.php 控制台配置 │ ├─cookie.php Cookie配置 │ ├─database.php 数据库配置 │ ├─filesystem.php 文件磁盘配置 │ ├─lang.php 多语言配置 │ ├─log.php 日志配置 │ ├─middleware.php 中间件配置 │ ├─route.php URL和路由配置 │ ├─session.php Session配置 │ ├─trace.php Trace配置 │ ├─route 路由目录 │ ├─admin.php 后台路由 │ ├─home.php 前台路由 │ ├─public WEB目录(对外访问目录) │ ├─index.php 入口文件 │ ├─admin 后台模板目录 │ ├─home 前台模板目录 │ ├─plugins 插件目录 │ ├─.htaccess 用于apache的重写 │ ├─runtime 应用的运行时目录(可写,可定制) ├─vendor Composer类库目录 6、使用模型方式进行增删改查,写在app/common/model/下(前后台通用);例子:创建订单,建立文件app/common/model/OrderModel.php,create()创建订单; 7、逻辑类,写在app/common/logic/下,例子:ProvisionLogic.php服务模块逻辑类等; 二、函数和类、属性命名 1、类的命名采用驼峰法(首字母大写),例如 User、UserType; 2、函数的命名使用小写字母和下划线(小写字母开头)的方式,例如 get_client_ip,公共函数文件app/common.php统一使用此方式命名; 3、方法的命名使用驼峰法(首字母小写),例如 getUserName; 4、属性的命名使用驼峰法(首字母小写),例如 tableName、instance; 5、特例:以双下划线__打头的函数或方法作为魔术方法,例如 __call 和 __autoload; 6、变量的命名使用驼峰法(首字母小写),例如 $tableName。实例化类的变量和类名同名,大驼峰变量,例如:$User。逻辑类中的变量加后缀,例如:$SmsLogic。 三、常量和配置 1、常量以大写字母和下划线命名,例如 APP_PATH; 2、配置参数以小写字母和下划线命名,例如 url_route_on 和url_convert; 3、环境变量定义使用大写字母和下划线命名,例如APP_DEBUG; 四、数据库表说明 1、数据库表采用 innodb引擎; 2、utf8mb4字符集; 3、带自增主键; 4、有默认值(text这类类型除外); 5、字符串类型的一定要有默认值,不要用NULL; 6、创建表一定要有字段说明; 7、日期存时间戳,所以日期类型用int(11); 8、价格相关数据用 decimal(10,2),有的可能需要更高的精度decimal(10,5); 9、适当添加索引,参考数据库表索引建立; 10、数据库里不使用存储过程、视图、函数、触发器、事件(否则维护麻烦); 11、数据表和字段采用小写加下划线方式命名,并注意字段名不要以下划线开头,例如 idcsmart_accounts表和 amount_out字段,不建议使用驼峰和中文作为数据表及字段命名。 12、数据库表不使用外键; 13、数据库用5.7,开启严格模式。 14、表与表关联的ID要带表名。例如:product_id。 15、表或字段读取不需要写as,例如client c。 16、搜索参数名$keywords。分页:$page 条数:$limit 排序:$orderby 升序降序:$sort desc asc ; 17、 五、智简魔方代码规范 1、控制器方法中尽量只写传参,验证、json返回,业务逻辑写在model里,或者逻辑类里; 2、控制器里只有接口方法,不要写多余的方法在控制器文件中,其他方法、逻辑写model里或者逻辑类里、或者公共函数里; 3、除接口返回json格式外,其他函数方法一律返回单个值,或者数组; 4、更改框架核心代码、基类控制器时,一定要商量,并写好更改的文档,做好记录; 5、函数超过两个参数,采用数组方式传入;(讨论:这个涉及到后面可能会不断的增加传入参数) 6、公共函数里 尽量不使用数据库操作,用use 引用模型类; 7、不要实例化控制器; 8、变量赋值运算前后添加空格。例如:$td .= ''; 9、类,函数名后面的花括号紧跟后面,换行写。例如:class CartController extends CommonController { 10、注释格式 ①api接口和类里面方法的注释格式 /** * @title title * @desc desc * @author author * @version version * @url url * @method method * @namespace namespace * @param type name default desc validate * @return type name default desc */ 如果当前default没有的话可以用 - 占位,validate没有的话可以不写 return的参数如果仅返回单个数据并无变量名称是type之后的参数可以不填 方法的param如果有顺序的话需要按顺序写 param和return后面的参数以空格隔开,参数的内容之中不能存在空格 例如 /** * @title 节点分组列表 * @desc 节点分组列表 * @author hh * @version v1 * @url node_groups * @method GET * @param int $page 1 页数 * @param int $per_page 20 每页条数 * @param string $orderby id 排序(id,name) * @param string $sort desc 排序方向 * @param string $search - 搜索 * @param string $list_type page 获取类型(all,page),all会忽略页数直接返回所有 * @return int $data[].id - 节点分组ID * @return string $data[].name - 节点分组名称 * @return string $data[].description - 节点分组名称 * @return string $data[].create_time - 创建时间 * @return int $data[].node[].id - 使用节点ID * @return string $data[].node[].name - 使用节点名称 * @return int $meta.total - 总条数 * @return int $meta.total_page - 总页数 * @return int $meta.page - 当前页 * @return int $meta.per_page - 每页条数 */ ②公共方法的注释格式 /** * @title title * @desc desc * @author author * @version version * @param type name default desc validate * @return type name default desc */ 如果当前default没有的话可以用 - 占位,validate没有的话可以不写 return的参数如果仅返回单个数据并无变量名称是type之后的参数可以不填 方法的param如果有顺序的话需要按顺序写 param和return后面的参数以空格隔开,参数的内容之中不能存在空格 /** * @title 获取客户端IP地址 * @desc 获取客户端IP地址 * @author hh * @version v1 * @param integer $type 返回类型0返回IP地址1返回IPV4地址数字 * @param boolean $adv 是否进行高级模式获取(有可能被伪装) * @return string */ 六、其他 1、前端传值用json,后端统一返回json格式数据; 2、返回数组一律转化为对象; 3、所有函数都需要写清楚文档; 4、状态码:200返回正确 400返回错误 302重定向 500系统错误,401登录失效,404无权限 5、数据返回格式: { “status”:200/400/302/500, "msg":"success message", "data":{ } } 6、控制器的函数中不要写参数 8、php使用7.4 9、注意不要使用php 语言结构或函数 来作为方法、变量; 10、公共语言 写在后台的语言文件; 键值 小写+下划线; 11、语言文件写法:success_message => ‘请求成功’ 字段统一 备注字段统一用 notes varchar(1000) 支付字段统一用 gateway 产品id统一用 product_id 用户id统一用 client_id 计费周期字段统一用 billing_cycle