首页
友情链接
精美壁纸
给我留言
更多
关于我
Search
1
uniapp Click点击事件冲突解决
4,558 阅读
2
【插件】UNI APP 实现商米打印机功能支持T1,T2,V2机型
3,871 阅读
3
【测试可用】个人码免签支付系统源码/免签支付系统/微信支付平台
1,974 阅读
4
Java Validation参数校验注解使用
1,230 阅读
5
windows10下docker:给已存在的容器添加端口映射的方法
1,219 阅读
Java
Spring Boot
Spring Mvc
Java基础
进阶知识
前端
uniapp
小程序/公众号
JavaScript
HTML/CSS
Vue
PHP
开源软件
商城
营销工具
开发工具
视频/教程
Discuz主题/插件
typecho主题/插件
SEO杂谈
数据库
MongoDB
MySQL
Redis
单片机
概念说明
电路相关
Python
devops
docker
k8s
linux
职场杂谈
登录
/
注册
Search
标签搜索
python
mysql
人人商城
php
java
docker
typecho
插件
微擎
seo
spring boot
discuz
队列
uni-app
phpcms
教程视频
开源系统
源码
工具
css
哈根达斯
累计撰写
100
篇文章
累计收到
154
条评论
首页
栏目
Java
Spring Boot
Spring Mvc
Java基础
进阶知识
前端
uniapp
小程序/公众号
JavaScript
HTML/CSS
Vue
PHP
开源软件
商城
营销工具
开发工具
视频/教程
Discuz主题/插件
typecho主题/插件
SEO杂谈
数据库
MongoDB
MySQL
Redis
单片机
概念说明
电路相关
Python
devops
docker
k8s
linux
职场杂谈
页面
友情链接
精美壁纸
给我留言
关于我
搜索到
7
篇与
PHP
的结果
2021-06-28
Typecho控制台日志打印 实现Typecho系统二次开发log日志打印查看
本文主要讲解如何实现typecho博客系统实现控制台日志打印功能,方便开发者可以查看日志输入,便于开发者定位问题,并解决使用日志需要日志目录有可写权限。一、编写日志文件Logger.php作者已经在网上找了一个人家写好的日志文件类,感觉使用还是不错的,大家复制使用即可,如果喜欢复制的,可以在文章末尾下载本php日志类文件文件放置var/目录下,即var/Logger.php<?php /* * Logger 日志类 * @date 2016/12/21 * @author 300js * 简单快捷debug类 * 优点:少配置或零配置,支持任何格式数据记录,支持数G数据存储.支持在浏览或linux环境查看 * 配置: * 可以在外部更改的常量: * 支持html便捷浏览模式或纯txt查看,值html|txt defined('MINI_DEBUG_TYPE') or define('MINI_DEBUG_TYPE', 'html'); 调试模式,1可写,0不可写 defined('MINI_DEBUG_FLAG') or define('MINI_DEBUG_FLAG', 1); jquery 地址 defined('MINI_DEBUG_JSPAHT') or define('MINI_DEBUG_JSPAHT', 'http://cdn.bootcss.com/jquery/1.8.3/jquery.js'); debug 可写的目录设置,结尾一定要加 保证有可写权限 defined('MINI_DEBUG_PATH') or define('MINI_DEBUG_PATH', __DIR__ . DIRECTORY_SEPARATOR); * * 更改存储目录: define('MINI_DEBUG_PATH', __DIR__ . '/');//必须后面加斜杆 / Logger::log('err', 'myFlag'); * 存储不同的文件名: define('MINI_DEBUG_PATH', __DIR__ . '/'); Logger::setCacheFile(date('Y-m-di'));//无需设置文件后缀 Logger::log('err', 'myFlag'); * 更改存储格式: define('MINI_DEBUG_PATH', __DIR__ . '/'); define('MINI_DEBUG_TYPE', 'txt');//默认为html Logger::log('err', 'myFlag'); * 覆盖文件,相当将之前的数据删除,写入新的数据,可做清空数据用 define('MINI_DEBUG_PATH', __DIR__ . '/'); Logger::log(1, 'myFlag', false); */ class Logger { private static $config = array( 'isSetFixx' => false,//是否已追加后缀标识 'cacheFile' => 'debug',//缓存的文件名,无需设置后缀 ); private static $_cacheFile = ''; /** * 设置日志文件,可文件名,可加相对路径,无需设置后缀名称 * @param string $cacheFile */ final public static function setCacheFile($cacheFile) { self::$config['cacheFile'] = $cacheFile; } /** * 记录日志 * @param mix $data 数据 * @param string $memo 标识 * @param boolean $isPush 是否追加,默认true * @param string $titleStr title * @return boolean 成功与否 */ final public static function log($data, $memo = 'None', $isPush = true, $titleStr = '日志记录') { self::_setBaseParam(); return self::_baseLog($data, $memo, $isPush, $titleStr); } /** * 获取当前的缓存文件 * @return type */ final public static function getCacheFile() { return self::$_cacheFile; } /** * 基础的日志方法 * @param mix $data 内容 * @param string $memo 标识 * @param boolean $isPush 是否追求,默认true * @param string $titleStr Title * @return boolean|int */ private static function _baseLog($data, $memo, $isPush = true, $titleStr = '日志记录') { if(!MINI_DEBUG_FLAG) return false; $cacheFile = MINI_DEBUG_PATH . self::$config['cacheFile']; if(!$isPush) unlink ($cacheFile); switch (strtolower(MINI_DEBUG_TYPE)) { case 'txt': $str = self::_setFormatTxt($data, $memo); break; default: $str = self::_setFormatHtml($data, $memo, $cacheFile, $titleStr); break; } self::$_cacheFile = $cacheFile; try{ if($isPush) file_put_contents($cacheFile, $str, 8); else file_put_contents($cacheFile, $str); } catch (Exception $ex) { } return true; } /** * 设置html格式,可以浏览器上方便查看 * @param type $data 数据 * @param type $memo 标识 * @param type $cacheFile 缓存文件 * @param type $titleStr * @return string */ private static function _setFormatHtml($data, $memo, $cacheFile, $titleStr){ $DebugFilePath = $_SERVER["PHP_SELF"];//当前处理页面 $timespan = microtime(true);//时间戳 $sBlockHTML = "\n\n\n<div class='block' _k='".md5($memo)."' _l='".$memo."'><span style='display:none'><------orderIndex-------></span>"; /*判断是否存在头信息*/ $baseHtml = ''; if(!is_file($cacheFile)) { $baseHtml = self::_getBaseHtml(MINI_DEBUG_JSPAHT, $titleStr); } $str = ''; $str .= $baseHtml; $str .= $sBlockHTML; $str .= "<span class='no' style='color:blue;'>NO</span>:\n\n"; $str .= "<br/><span style='color:blue;'>Date</span>:\t".date("Y-m-d H:i:s")."\n"; $str .= "<br/><span style='color:blue;'>File</span>:\t".$DebugFilePath."\n"; $str .= "<br/><span class='memo' style='color:blue;'>Memo</span>:\t".$memo."<br>\n"; // $str .= "<span style='color:blue;'>Action:</span>:\t".$_SERVER['QUERY_STRING']."<br>\n"; $str .= "----------------------------------------<span class='infoswitch'><a href='javascript:void(0)' >展开/收起</a></span>\n<div class='info'>"; ob_start(); if(is_array($data)) print_r($data); elseif(is_string($data)) echo $data; else var_dump($data); $a = ob_get_contents(); ob_end_clean(); $str .= "<xmp>"; $str .= $a; $str .= "</xmp>"; $str .= "</div>\n<hr></div>\n\n\n"; return $str; } /** * 设置txt纯文本格式 * @param type $data * @param type $memo * @return type */ private static function _setFormatTxt($data, $memo) { $DebugFilePath = $_SERVER["PHP_SELF"];//当前处理页面 $str = ''; $str .= 'Memo:' . $memo; $str .= ' Time:' . date('Y-m-d H:i:s'); $str .= ' File:' . $DebugFilePath; $str .= PHP_EOL; ob_start(); if(is_array($data)) print_r($data); elseif(is_string($data)) echo $data; else var_dump ($data); $a = ob_get_contents(); ob_end_clean(); $str .= $a; $str .= PHP_EOL; return $str; } /** * 获取处理的js html * @param type $jsPath * @param type $titleStr * @return type */ private static function _getBaseHtml($jsPath, $titleStr) { $baseHtml = <<<___html <!doctype html><html><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><title>{$titleStr}</title><script src="{$jsPath}" type="text/javascript"></script><style type="text/css"> body { margin: 0px; padding: 0px; height: 100%; } body, th, td { font-family: Tahoma, Verdana, Arial, Helvetica, sans-serif; font-size: 12px; color: #333; } </style></head><body><div id="tabs"></div></body></html> <script> $(function() { var _oMemo = {all:{label:'all', total:$("div.block").length}}; var j=1; $("div.block").each(function(){ if(typeof _oMemo[$(this).attr('_k')] == 'undefined') { _oMemo[$(this).attr('_k')] = {}; } if(typeof _oMemo[$(this).attr('_k')]['total'] == 'undefined'){ _oMemo[$(this).attr('_k')]['total'] = 1; _oMemo[$(this).attr('_k')]['label'] = $(this).attr('_l'); $(this).find(".no").html("NO:" + j); }else { _oMemo[$(this).attr('_k')]['total'] += 1; $(this).find(".no").html("NO:" + j); } j++; }); var sUl = ""; for(var k in _oMemo){ sUl += '<li><a _k="'+k+'" href="javascript:void(0)" >'+_oMemo[k]['label']+'('+_oMemo[k]['total']+')</a></li>'; } $('div#tabs').html("<ul>"+sUl+"</ul><div style=\"position:absolute;top:10px;right:20px;\" class='allinfoSwith'><a href='javascript:void(0)' >全部 展开/收起</a></div>"); $('div#tabs li a').click(function(){ var _showK = $(this).attr('_k'); if(_showK == 'all'){ var i = 1; $("div.block").each(function(){ $(this).find(".no").html("NO:" + i); i++; }); $('div.block').show(); }else{ $('div.block').hide(); $('div.block[_k="'+_showK+'"]').show(); var p = 1; $('div.block[_k="'+_showK+'"]').each(function(){ $(this).find('.no').html("NO:"+p); p++; }); } }); $('div.block span.infoswitch a').click(function(){ var _o = $(this).parents('div.block').find('div.info').eq(0); _o.toggle(); }); var allinfoSwithIndex = 0; $('div.allinfoSwith a').click(function(){ allinfoSwithIndex%2==0 ? $('div.info').hide() : $('div.info').show(); allinfoSwithIndex++; }); }); </script> ___html; return $baseHtml; } /** * 初使常量及判断 */ private static function _setBaseParam(){ /**支持html便捷浏览模式或纯txt查看,值html|txt*/ defined('MINI_DEBUG_TYPE') or define('MINI_DEBUG_TYPE', 'html'); /**调试模式,1可写,0不可写*/ defined('MINI_DEBUG_FLAG') or define('MINI_DEBUG_FLAG', 1); /**jquery 地址*/ defined('MINI_DEBUG_JSPAHT') or define('MINI_DEBUG_JSPAHT', 'http://cdn.bootcss.com/jquery/1.8.3/jquery.js'); /**debug 可写的目录设置,结尾一定要加 / */ defined('MINI_DEBUG_PATH') or define('MINI_DEBUG_PATH', __DIR__ . DIRECTORY_SEPARATOR); self::_setFileFixx(); } /** * 设置文件后缀 * @param type $cacheFile */ private static function _setFileFixx() { $_default_name = '_log'; if(stripos(self::$config['cacheFile'], 'debug') !== false) { $_default_name = ''; } $baseName = pathinfo(self::$config['cacheFile'], PATHINFO_BASENAME); if(strpos($baseName, '.') !== false && self::$config['isSetFixx'] == true) { return; } switch (strtolower(MINI_DEBUG_TYPE)) { case 'txt': self::$config['cacheFile'] .= $_default_name . '.txt'; self::$config['isSetFixx'] = true; break; default: self::$config['cacheFile'] .= $_default_name . '.html'; self::$config['isSetFixx'] = true; break; } } } 二、 include日志文件因默认框架不会自动加载文件需要在config.inc.php配置文件中加载文件日志,并定义相关配置常量1. 配置修改修改配置文件核心代码// 在24行出添加 // 定义日志文件类型:txt文本,html网页,建议开发使用网页,便于查看 define('MINI_DEBUG_TYPE', 'html'); // 定义日志文件目录 define('MINI_DEBUG_PATH', __TYPECHO_ROOT_DIR__ . '/logs/'); //在35行后添加 require_once 'Logger.php'; 三、日志使用可以在你需要输入日志的地方,使用日志// 参数1:日志内容,参数2:日志业务TAG Logger::log('测试日志','baidu'); //支持数组形式输出 Logger::log(array('url'=>'测试1','name'=>'淘宝'),'taobao'); 四、查看日志在浏览器中访问http://测试域名/logs/debug.html 即可查看日志内容五、 常见问题debug.html文件未生成答:需要检查logs日志目录是否存在需要开发者自己建目录,检查logs目录是否有读写权限六、 文件下载logger类文件下载地址{cloud title="Logger文件下载" type="bd" url="https://pan.baidu.com/s/1kex_meyPkca0dIEyuvBuQQ" password="8qpm"/}
2021年06月28日
392 阅读
0 评论
0 点赞
2021-06-26
【实战篇】人人商城如何开发一个新功能【六】
本章节为大家讲解微擎框架下人人商城开发一个新功能。不管学习什么东西,动手实际会让大家更深入了解它,那我们今天就来动手亲自实现一个简单的功能,通过此功能你将了解如下几个知识点。人人商城控制器人人商城路由人人商城权限控制学习前提条件(TODO配图)已经学会php基本语法和mysql基本操作,并本地安装完成已经成本安装微擎框架及人人商城系统一、新增功能业务员信息门店收集,业务员可通过手机网页,录入门店信息。主要使用技术点:新建手机网页端信息收集后台可查询门店信息记录二、代码编写1. 新建业务表 CREATE TABLE `ims_ewei_shop_businesser` ( `id` int(10) NOT NULL AUTO_INCREMENT, `uniacid` int(10) DEFAULT NULL, `businesser_name` varchar(64) DEFAULT NULL COMMENT '业务员姓名', `businesser_phone` varchar(12) DEFAULT NULL COMMENT '业务员电话', `status` int(2) DEFAULT '1' COMMENT '状态1启用0禁用', `remark` varchar(255) DEFAULT NULL COMMENT '备注', `create_time` int(11) DEFAULT NULL COMMENT '创建时间', `openid` varchar(64) DEFAULT NULL, PRIMARY KEY (`id`) USING BTREE ) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8 ROW_FORMAT=COMPACT COMMENT='业务员表';2. 新建模型手机端控制器Controller公众号端控制器需继承MobilePage 控制器手机端访问路由:host.com/app/index.php?i=2&c=entry&m=ewei_shopv2&do=mobile&r=goods.detail&id=2 class Businesser_EweiShopV2Page extends MobilePage { //主页面 public function main(){ //业务逻辑代码 global $_W; global $_GPC; } //查询业务员门店信息 public function store_list(){ //业务逻辑代码 global $_W; global $_GPC; } } Web控制器ControllerPC运营后台端控制器需继承WebPage 控制器访问控制器:host.com/web/index.php?c=site&a=entry&m=ewei_shopv2&do=web&r=store.businesser class Businesser_EweiShopV2Page extends WebPage { //查询业务员列表 public function main(){ //业务逻辑代码 global $_W; global $_GPC; // 根据实际业务进行chax } } 三、菜单与权限运营后台需要设置菜单与权限ammin外的用户才能进行访问1. 菜单设置菜单设置addons\ewei_shopv2\core\model\system.php中684行代码左右开始,设置成功后可查看代码页面是否已经显示菜单。 array( 'title' => '业务员管理', 'route' => 'businesser' ) 2. 权限设置权限设置在文件addons\ewei_shopv2\core\com\perm.php中347行代码左右,设置成功后可查看权限列表是否以有权限'businesser' => array( 'text' => '业务员管理', 'main' => '查看列表', 'add' => '添加-log', 'edit' => '修改-log', 'view' => '查看', 'delete' => '删除-log' ),总结到这里我们就完成了简单人人商城功能新增。
2021年06月26日
270 阅读
0 评论
0 点赞
1
2