首页
4K壁纸
直播
统计分析
友情链接
搜索
1
#1031 – TABLE STORAGE ENGINE FOR ” DOESN’T HAVE THIS OPTION解决方法
1,257 阅读
2
让浏览器不显示 https 页面中 http 请求警报 http-equiv=”Content-Security-Policy” content=”upgrade-insecure-requests”
971 阅读
3
报错代码:ERROR 1227 (42000)-解决办法
752 阅读
4
微信个人商户号养号建议
598 阅读
5
解决移动端position:fixed随软键盘移动的问题
575 阅读
Php
Mysql
Linux
Reids
Java
Python
常用笔记
学习
乱七八糟
Search
标签搜索
php
Mysql
千卡云支付
Linux
redis
千卡云
千卡易支付
Nginx
function
JS
session
shell
JSON
跨域
支付宝
CentOS
Apache
支付
composer
Array
蓝科迪梦
累计撰写
107
篇文章
累计收到
0
条评论
首页
栏目
Php
Mysql
Linux
Reids
Java
Python
常用笔记
学习
乱七八糟
页面
4K壁纸
直播
统计分析
友情链接
搜索到
62
篇与
分类 Php 下的内容
2025-07-17
PHP 问题解决:解决 “Maximum execution time exceeded” 错误
PHP 问题解决:解决 “Maximum execution time exceeded” 错误在 PHP 开发过程中,你可能会遇到一个常见的运行时错误:“Fatal error: Maximum execution time of X seconds exceeded”这个错误表示当前脚本执行时间超过了 PHP 配置中允许的最大执行时间(默认为 30 秒)。本文将带你分析该错误的常见原因,并提供多种解决方案。? 错误示例<?php // 模拟长时间执行的脚本 for ($i = 0; $i < 1000000; $i++) { // 做大量计算或数据库操作 } ?>如果这段代码运行超过 max_execution_time 设置的时间限制,就会触发此错误。? 常见原因分析1. 脚本逻辑复杂或存在死循环复杂的算法、大数组处理、递归调用等可能导致执行时间过长。错误的循环条件可能造成无限循环。2. 外部资源响应缓慢数据库查询慢、远程 API 调用超时、文件读写过大等都会导致脚本执行时间增加。3. PHP 默认配置限制默认 max_execution_time = 30 秒。对于某些耗时任务(如导入大数据、图像处理)是不够的。✅ 解决方法✅ 方法一:延长最大执行时间(适用于 CLI 或 Web)修改 php.ini找到你的 php.ini 文件,修改以下配置:max_execution_time = 300 ; 单位为秒,设置为 300 表示 5 分钟⚠️ 注意:修改后需要重启 Web 服务器(如 Apache、Nginx)或 PHP-FPM 才能生效。在运行时动态设置(适用于 Web)set_time_limit(300); // 设置脚本最多可运行 300 秒? 如果你在命令行运行脚本(CLI),set_time_limit() 不起作用,需直接修改 php.ini。✅ 方法二:优化脚本性能使用更高效的算法或数据结构例如避免多层嵌套循环,改用哈希查找或分批次处理。示例:分批次处理大数据$items = getAllItems(); // 获取大量数据 $chunkSize = 1000; foreach (array_chunk($items, $chunkSize) as $chunk) { processChunk($chunk); sleep(1); // 可选:每批之间暂停一下,防止占用过高 }减少不必要的 I/O 操作合并多次数据库查询为一次。将日志记录改为异步方式或批量写入。使用缓存减少重复计算。✅ 方法三:使用 CLI 异步执行耗时任务如果你的应用有后台任务(如导出报表、生成缩略图等),建议将其放到命令行脚本中执行:php /path/to/long_script.phpCLI 模式下默认不限制执行时间(取决于系统配置),适合处理长时间任务。? 你可以结合 Linux 的 cron job 或 supervisor 来管理这些后台任务。✅ 方法四:使用队列系统(高级方案)对于大规模项目,建议引入消息队列系统(如 Redis Queue、RabbitMQ、Beanstalkd)来处理耗时任务:用户请求提交任务到队列。队列由 Worker 进程异步消费。完成后通过回调或通知返回结果。这可以有效提升用户体验和系统稳定性。✅ 方法五:调试脚本瓶颈你可以使用 Xdebug 或 Blackfire.io 对脚本进行性能分析,找出执行最久的函数或代码段。简单调试方法:$start = microtime(true); // 执行某段逻辑 sleep(5); $duration = microtime(true) - $start; echo "执行耗时:{$duration} 秒";? 总结原因解决方案脚本逻辑复杂优化算法、分批次处理外部资源延迟异步处理、使用缓存默认时间限制修改 php.ini 或使用 set_time_limit()需要长时间运行使用 CLI 或队列系统✅ 推荐开发实践实践说明对于 Web 请求尽量控制在 2~5 秒内完成提升用户体验长时间任务使用 CLI 或队列处理提高系统健壮性使用 set_time_limit(0) 要谨慎可能导致服务器资源耗尽使用性能分析工具定位瓶颈快速找到问题根源避免死循环和阻塞操作提前做好异常捕获和中断机制希望这篇文章能帮助你彻底解决 PHP 中 “Maximum execution time exceeded” 的问题!如果你还有其他 PHP 相关问题,也欢迎继续提问。
2025年07月17日
47 阅读
0 评论
0 点赞
2025-07-17
PHP问题解决:处理“Headers already sent”错误
在PHP开发中,我们经常会遇到一个常见的错误提示:“Cannot modify header information – headers already sent”。这个错误通常发生在你试图使用 header() 函数设置HTTP头(例如重定向或设置Cookie)时,但输出已经在脚本中提前发送了。这篇文章将帮助你快速定位并解决这个问题。一、错误原因HTTP头信息必须在页面内容(HTML、空格、换行等)发送之前发送。一旦有内容被输出,PHP 就会认为 HTTP 头信息已经发送完毕,之后调用 header() 函数就会触发错误。以下是常见的几种导致“Headers already sent”错误的原因:1. PHP标签前有空格或换行符 <?php // 前面有空格 header("Location: index.php");2. 使用了 echo、print 或 HTML 输出在 header() 之前echo "Hello"; header("Location: index.php"); // 错误3. 使用 include/require 加载的文件中包含空白或输出比如你引入的配置文件或模板文件,在 <?php 标签前或后存在空白或错误输出。4. UTF-8 BOM 文件头问题有时候你保存的 PHP 文件是 UTF-8 with BOM 编码,会在文件开头插入隐藏的 BOM 字符(\xEF\xBB\xBF),这也会造成输出提前。二、解决方法✅ 方法一:检查输出开始的位置确保你在调用 header()、setcookie()、session_start() 等函数之前,没有任何输出。包括:没有 echo、print、var_dump没有 HTML 标签直接输出没有空白或空行✅ 方法二:移除 BOM 头使用支持查看和修改编码的编辑器(如 VSCode、Notepad++、Sublime Text)打开你的 PHP 文件,另存为 UTF-8 无 BOM 格式。VSCode 示例:打开文件点击右下角显示的编码(如 UTF-8 with BOM)选择“Save with Encoding”选择 UTF-8✅ 方法三:使用输出缓冲使用 ob_start() 在脚本开始处开启输出缓冲,可以延迟输出,确保 header() 能够正常调用。<?php ob_start(); // 其他逻辑代码 echo "Hello World"; header("Location: index.php"); ob_end_flush();⚠️ 注意:输出缓冲虽然可以解决此问题,但不应滥用,因为它会增加内存开销。✅ 方法四:检查引入文件如果你的错误发生在引入了其他文件后,可以检查这些文件是否含有输出内容:<?php // config.php ?> Some content <!-- 这里会导致问题 --> <?php // index.php include 'config.php'; header("Location: home.php"); // 错误触发解决方案是确保引入的文件只有 PHP 代码,并且关闭 ?> 标签(建议 PHP 文件只写 PHP 代码时省略 ?>)。三、排查技巧1. 查看错误提示的文件和行号PHP 通常会提示你“headers already sent by ...”并指出是哪个文件哪一行输出了内容。比如:Warning: Cannot modify header information - headers already sent by (output started at /path/to/file.php:10)前往该文件第10行查看是否有输出或空白。2. 使用 headers_sent() 函数检查在调用 header() 前使用该函数检查头是否已发送:if (!headers_sent()) { header("Location: index.php"); exit; } else { echo "Headers already sent."; }四、最佳实践实践说明避免在 PHP 文件中混合 HTML 输出保持逻辑和输出分离省略 ?> 结束标签减少意外输出风险使用 ob_start() 控制输出流适用于复杂输出流程统一文件编码为 UTF-8 无 BOM防止隐藏字符输出五、总结“Headers already sent” 是 PHP 中非常常见但容易解决的问题。通过以下几点可以有效避免:保持 header() 调用之前无任何输出检查文件编码(避免 BOM)使用输出缓冲控制输出流程检查引入的外部文件内容希望这篇原创文章能帮你彻底解决这个问题!
2025年07月17日
58 阅读
0 评论
0 点赞
2025-07-17
解决PHP“Undefined variable”错误
在PHP开发过程中,我们经常会遇到“Undefined variable”错误。这个错误通常表示你在代码中引用了一个未定义的变量。这篇文章将介绍一些常见的导致这个错误的原因以及解决方法。原因及解决方法1. 变量未初始化最常见的原因是变量在使用前未初始化。例如:echo $myVar; // 报错: Undefined variable: myVar在上面的例子中,$myVar变量在使用前没有被定义。解决方法是确保变量在使用前被正确初始化:$myVar = "Hello World"; echo $myVar; // 正确输出: Hello World2. 变量作用域问题如果你在一个特定的作用域中定义了一个变量,但在另一个作用域中尝试访问它,也会导致错误。例如:function myFunction() { $myVar = "Hello World"; } echo $myVar; // 报错: Undefined variable: myVar在上面的例子中,$myVar变量在函数myFunction()内部定义,但在全局作用域中尝试访问它。解决方法是将变量定义在合适的作用域,或者使用全局变量:function myFunction() { global $myVar; $myVar = "Hello World"; } myFunction(); echo $myVar; // 正确输出: Hello World3. 条件语句中定义变量有时候变量可能在条件语句中定义,但如果条件未满足,变量就不会被定义。例如:if (false) { $myVar = "Hello World"; } echo $myVar; // 报错: Undefined variable: myVar在上面的例子中,由于条件为false,$myVar变量未被定义。解决方法是在条件语句之外初始化变量:$myVar = ""; // 初始化变量 if (true) { $myVar = "Hello World"; } echo $myVar; // 正确输出: Hello World4. 数组键未定义如果你尝试访问数组中不存在的键,也会导致“Undefined variable”错误。例如:$myArray = ["name" => "John"]; echo $myArray["age"]; // 报错: Undefined array key: age在上面的例子中,$myArray中没有age键。解决方法是确保在访问数组键之前检查其是否存在:$myArray = ["name" => "John"]; if (isset($myArray["age"])) { echo $myArray["age"]; } else { echo "Age key not found"; // 正确输出: Age key not found }5. 变量名拼写错误有时候,你可能会因为拼写错误而引用了一个未定义的变量。例如:$myVar = "Hello World"; echo $myVarr; // 拼写错误: myVarr 而不是 myVar在上面的例子中,$myVarr是一个拼写错误,正确的变量名应该是$myVar。解决方法是检查变量名的拼写并更正错误:$myVar = "Hello World"; echo $myVar; // 正确输出: Hello World总结“Undefined variable”错误通常由以下几种原因导致:变量未初始化变量作用域问题条件语句中定义变量数组键未定义变量名拼写错误通过检查这些方面,你应该能够解决大部分“Undefined variable”错误。希望这篇文章能帮助你解决问题!
2025年07月17日
30 阅读
0 评论
0 点赞
2025-07-15
PHP中如何解决“Call to undefined function”错误?
PHP中如何解决“Call to undefined function”错误?在使用PHP开发过程中,我们可能会遇到如下错误:Fatal error: Call to undefined function functionName()这个错误通常表示你试图调用一个不存在的函数。这个问题可能由多种原因引起,以下是一些常见的问题排查与解决方案。1. 确认函数名拼写是否正确示例:fucntion exampleFunction() { // 错误拼写function为fucntion echo "Hello, world!"; } exampleFunction();解决方法:确保 function 关键字拼写正确,以及函数名无错别字或大小写不一致的问题(函数名对大小写不敏感,但建议保持一致性)。2. 检查函数是否定义在调用之前PHP是顺序解析语言,函数必须在调用前定义。示例:exampleFunction(); // 调用未定义的函数 function exampleFunction() { echo "Hello, world!"; }解决方法:确保函数在调用之前已定义:function exampleFunction() { echo "Hello, world!"; } exampleFunction(); // 正确调用3. 确保文件包含正确路径如果你调用的是其他文件中定义的函数,请确认是否正确引入了该文件。示例:// functions.php function exampleFunction() { echo "Hello, world!"; } // index.php exampleFunction(); // 未引入functions.php解决方法:使用 include 或 require 正确引入函数所在的文件:// index.php require 'functions.php'; exampleFunction(); // 正确调用同时请检查引入路径是否正确(相对路径/绝对路径),避免因路径错误导致文件未被正确加载。4. 函数未定义在命名空间中如果你在使用命名空间,请确保函数调用时使用正确的命名空间前缀。示例:// functions.php namespace MyProject; function exampleFunction() { echo "Hello, world!"; } // index.php MyProject\exampleFunction(); // 正确调用如果忘记使用命名空间前缀,则会报错。5. 扩展函数未启用某些函数依赖于特定的PHP扩展,如 mysqli_connect() 依赖 mysqli 扩展。示例:mysqli_connect("localhost", "user", "password", "database"); // 如果mysqli未启用将报错解决方法:检查 php.ini 文件,确保相关扩展已启用,例如:extension=mysqli使用 phpinfo() 函数查看当前启用的扩展列表。6. 函数未正确定义函数定义语法错误也可能导致函数不可用。示例:function exampleFunction { echo "Hello, world!"; }解决方法:确保函数定义格式正确,包括括号和参数列表:function exampleFunction() { echo "Hello, world!"; }总结问题原因解决方案函数名拼写错误检查并修正拼写函数未在调用前定义将函数定义放在调用之前文件未正确引入使用 include 或 require 并检查路径命名空间使用错误使用正确的命名空间调用函数扩展未启用在 php.ini 中启用相关扩展函数定义语法错误检查函数定义格式通过以上步骤,你可以快速定位并解决“Call to undefined function”错误。希望这篇文章对你有所帮助!
2025年07月15日
23 阅读
0 评论
1 点赞
2025-07-15
PHP中解决“Allowed memory size of X bytes exhausted”错误
PHP中解决“Allowed memory size of X bytes exhausted”错误的原创文章在PHP开发过程中,我们有时会遇到如下错误:Fatal error: Allowed memory size of 134217728 bytes exhausted (tried to allocate 20480 bytes) in /path/to/file.php on line N这个错误提示表示脚本尝试使用的内存超出了PHP配置中允许的最大内存限制。下面我们将分析这个问题的原因,并提供几种解决方案。原因分析内存限制设置过低:PHP默认的内存限制是128MB(即134217728字节),对于处理大量数据或复杂运算的应用程序来说可能不够。代码存在内存泄漏:例如无限循环、不必要的变量保留等。大文件或图片处理不当:如一次性加载大文件到内存中。递归调用未正确终止:导致栈溢出或者过度使用内存。解决方案1. 提高内存限制你可以在php.ini文件中修改以下配置来增加内存限制:memory_limit = 256M如果你无法直接修改php.ini文件,可以在脚本开头使用ini_set()函数临时调整:ini_set('memory_limit', '256M');⚠️ 注意:这种方法只对当前脚本有效,重启后会恢复为php.ini中的设置。2. 检查并优化代码逻辑a. 避免无必要的大数组或对象创建如果你在处理大数据集时一次性将所有数据加载到内存中,建议改为分页或流式处理:// 分页读取数据库数据 $limit = 1000; $page = 0; do { $data = fetchData($page++, $limit); process($data); } while (!empty($data)); function fetchData($page, $limit) { // 实现分页查询逻辑 } function process($data) { // 处理每一页的数据 }b. 使用生成器减少内存占用PHP的生成器可以逐条生成数据而不是一次性全部返回,非常适合处理大数据:function getLargeFileLines($filename) { $handle = fopen($filename, 'r'); while (($line = fgets($handle)) !== false) { yield $line; } fclose($handle); } foreach (getLargeFileLines('largefile.txt') as $line) { processLine($line); }3. 及时释放不再使用的变量使用完一个大变量后,及时使用unset()将其销毁以释放内存:$bigData = generateBigData(); process($bigData); unset($bigData); // 释放内存4. 检查递归调用是否合理确保递归调用有明确的终止条件,并避免深度过大的递归操作。如果可能,考虑改用迭代方式实现:function factorial($n) { if ($n <= 1) return 1; return $n * factorial($n - 1); }可以改为迭代方式:function factorial($n) { $result = 1; for ($i = 2; $i <= $n; $i++) { $result *= $i; } return $result; }5. 使用性能分析工具检测内存使用情况使用Xdebug或其他性能分析工具可以帮助你定位内存消耗较大的函数或模块。安装Xdebug后,在php.ini中启用它:zend_extension=/path/to/xdebug.so xdebug.profiler_enable=1 xdebug.profiler_output_dir="/tmp/xdebug"运行脚本后,使用KCacheGrind或WinCacheGrind等工具查看性能报告,找出内存瓶颈。总结“Allowed memory size of X bytes exhausted”是一个常见的PHP内存问题,主要通过以下手段解决:✅ 增加memory_limit设置;✅ 优化代码逻辑,避免一次性加载过多数据;✅ 使用生成器进行流式处理;✅ 及时释放不再使用的变量;✅ 检查递归逻辑,必要时改用迭代;✅ 使用性能分析工具辅助排查。通过这些方法,大多数PHP内存耗尽问题都可以得到有效解决。
2025年07月15日
23 阅读
0 评论
0 点赞
2025-03-10
php二维数组根据指定键值重新排序
/** * @Notes: * 二维数组根据指定键值重新排序 * @Interface arr_sort * @author [MengShuai] [<133814250@qq.com>] */ public static function arr_sort($arr,$field='id',$order='SORT_ASC'){ $sort = array( 'order' => $order, //排序顺序标志 SORT_DESC 降序;SORT_ASC 升序 'field' => $field, //排序字段 ); $arrSort = array(); foreach($arr AS $uniqid => $row){ foreach($row AS $key=>$value){ $arrSort[$key][$uniqid] = $value; } } if($sort['order']){ array_multisort($arrSort[$sort['field']], constant($sort['order']), $arr); } return $arr; } 测试数据: $userdb = array( 0 => array( 'uid' => 100, 'name' => 'Sandra Shush', 'url' => 'urlof100' ), 1 => array( 'uid' => 5465, 'name' => 'Stefanie Mcmohn', 'pic_square' => 'urlof100' ), ); 调用方法: $userdb = arr_sort($userdb,$field='uid',$order='SORT_DESC'); 打印方法: var_export($userdb); 打印结果: array ( 0 => array ( 'uid' => 5465, 'name' => 'Stefanie Mcmohn', 'pic_square' => 'urlof100', ), 1 => array ( 'uid' => 100, 'name' => 'Sandra Shush', 'url' => 'urlof100', ), )
2025年03月10日
123 阅读
0 评论
0 点赞
2025-03-07
PHP中register_shutdown_function函数的基础介绍与用法详解
1. 函数说明 定义:该函数是来注册一个会在PHP中止时执行的函数 参数说明: void register_shutdown_function ( callable $callback [, mixed $parameter [, mixed $... ]] ) 注册一个 callback ,它会在脚本执行完成或者 exit() 后被调用。 callback:待注册的中止回调 parameter:可以通过传入额外的参数来将参数传给中止函数 2. PHP中止的情况 PHP中止的情况有三种: 执行完成 exit/die导致的中止 发生致命错误中止 a. 第一种情况,执行完成 <?php function test() { echo '这个是中止方法test的输出'; } register_shutdown_function('test'); echo 'before' . PHP_EOL; 运行: before 这个是中止方法test的输出 注意:输出的顺序,等执行完成了之后才会去执行register_shutdown_function的中止方法test b. 第二种情况,exit/die导致的中止 <?php function test() { echo '这个是中止方法test的输出'; } register_shutdown_function('test'); echo 'before' . PHP_EOL; exit(); echo 'after' . PHP_EOL; 运行: before 这个是中止方法test的输出 后面的after并没有输出,即exit或者是die方法导致提前中止。 c. 第三种情况,发送致命错误中止 <?php function test() { echo '这个是中止方法test的输出'; } register_shutdown_function('test'); echo 'before' . PHP_EOL; // 这里会发生致命错误 $a = new a(); echo 'after' . PHP_EOL; 运行: before Fatal error: Uncaught Error: Class 'a' not found in D:\laragon\www\php_book\test.php on line 12 Error: Class 'a' not found in D:\laragon\www\php_book\test.php on line 12 Call Stack: 0.0020 360760 1. {main}() D:\laragon\www\php_book\test.php:0 这个是中止方法test的输出 后面的after也是没有输出,致命错误导致提前中止了。 3. 参数 第一个参数支持以数组的形式来调用类中的方法,第二个以及后面的参数都是可以当做额外的参数传给中止方法。 <?php class Shutdown { public function stop() { echo "这个是stop方法的输出"; } } // 当PHP终止的时候(执行完成或者是遇到致命错误中止的时候)会调用new Shutdown的stop方法 register_shutdown_function([new Shutdown(), 'stop']); // 将因为致命错误而中止 $a = new a(); // 这一句并没有执行,也没有输出 echo '必须终止'; 也可以在类中执行: <?php class TestDemo { public function __construct() { register_shutdown_function([$this, "f"], "hello"); } public function f($str) { echo "class TestDemo->f():" . $str; } } $demo = new TestDemo(); echo 'before' . PHP_EOL; /** 运行: before class TestDemo->f():hello */ 4. 同时调用多个 可以多次调用 register_shutdown_function,这些被注册的回调会按照他们注册时的顺序被依次调用。 不过注意的是,如果在第一个注册的中止方法里面调用exit方法或者是die方法的话,那么其他注册的中止回调也不会被调用。 代码: <?php /** * 可以多次调用 register_shutdown_function,这些被注册的回调会按照他们注册时的顺序被依次调用。 * 注意:如果你在f方法(第一个注册的方法)里面调用exit方法或者是die方法的话,那么其他注册的中止回调也不会被调用 */ /** * @param $str */ function f($str) { echo $str . PHP_EOL; // 如果下面调用exit方法或者是die方法的话,其他注册的中止回调不会被调用 // exit(); } // 注册第一个中止回调f方法 register_shutdown_function("f", "hello"); class TestDemo { public function __construct() { register_shutdown_function([$this, "f"], "hello"); } public function f($str) { echo "class TestDemo->f():" . $str; } } $demo = new TestDemo(); echo 'before' . PHP_EOL; /** 运行: before hello class TestDemo->f():hello 注意:如果f方法里面调用了exit或者是die的话,那么最后的class TestDemo->f():hello不会输出 */ 5. 用处 该函数的作用: 析构函数:在PHP4的时候,由于类不支持析构函数,所以这个函数经常用来模拟实现析构函数 致命错误的处理:使用该函数可以用来捕获致命错误并且在发生致命错误后恢复流程处理 代码如下: <?php /** * register_shutdown_function,注册一个会在php中止时执行的函数,中止的情况包括发生致命错误、die之后、exit之后、执行完成之后都会调用register_shutdown_function里面的函数 * Created by PhpStorm. * User: Administrator * Date: 2017/7/15 * Time: 17:41 */ class Shutdown { public function stop() { echo 'Begin.' . PHP_EOL; // 如果有发生错误(所有的错误,包括致命和非致命)的话,获取最后发生的错误 if (error_get_last()) { print_r(error_get_last()); } // ToDo:发生致命错误后恢复流程处理 // 中止后面的所有处理 die('Stop.'); } } // 当PHP终止的时候(执行完成或者是遇到致命错误中止的时候)会调用new Shutdown的stop方法 register_shutdown_function([new Shutdown(), 'stop']); // 将因为致命错误而中止 $a = new a(); // 这一句并没有执行,也没有输出 echo '必须终止'; 运行: Fatal error: Uncaught Error: Class 'a' not found in D:\laragon\www\php_book\1_23_register_shutdown.php on line 31 Error: Class 'a' not found in D:\laragon\www\php_book\1_23_register_shutdown.php on line 31 Call Stack: 0.0060 362712 1. {main}() D:\laragon\www\php_book\1_23_register_shutdown.php:0 Begin. Array ( [type] => 1 [message] => Uncaught Error: Class 'a' not found in D:\laragon\www\php_book\1_23_register_shutdown.php:31 Stack trace: #0 {main} thrown [file] => D:\laragon\www\php_book\1_23_register_shutdown.php [line] => 31 ) Stop. 注意:PHP7中新增了Throwable异常类,这个类可以捕获致命错误,即可以使用try...catch(Throwable $e)来捕获致命错误,代码如下: <?php try { // 将因为致命错误而中止 $a = new a(); // 这一句并没有执行,也没有输出 echo 'end'; } catch (Throwable $e) { print_r($e); echo $e->getMessage(); } 运行: Error Object ( [message:protected] => Class 'a' not found [string:Error:private] => [code:protected] => 0 [file:protected] => C:\laragon\www\php_book\throwable.php [line:protected] => 5 [trace:Error:private] => Array ( ) [previous:Error:private] => [xdebug_message] => Error: Class 'a' not found in C:\laragon\www\php_book\throwable.php on line 5 Call Stack: 0.0000 349856 1. {main}() C:\laragon\www\php_book\throwable.php:0 ) Class 'a' not found 这样的话,PHP7中使用Throwable来捕获的话比使用register_shutdown_function这个函数来得更方便,也更推荐Throwable。 注意:Error类也是可以捕获到致命错误,不过Error只能捕获致命错误,不能捕获异常Exception,而Throwable是可以捕获到错误和异常的,所以更推荐。 6.巧用register_shutdown_function判断php程序是否执行完 还有一种应用场景就是:要做一个消费队列,因为某条有问题的数据导致致命错误,如果这条数据不处理掉,那么整个队列都会导致瘫痪的状态,这样可以用以下方法来解决。即:如果捕获到有问题的数据导致错误,则在回调函数中将这条数据处理掉就可以了。 php范例参考与解析: <?php register_shutdown_function('myFun'); //放到最上面,不然如果下面有致命错误,就不会调用myFun了。 $execDone = false; //程序是否成功执行完(默认为false) /** ********************* 业务逻辑区************************* */ $tas = 3; if($tas == 3) { new daixiaorui(); } /** ********************* 业务逻辑结束************************* */ $execDone = true; //由于程序由上至下执行,因此当执行到此后,则证明逻辑没有出现致命的错误。 function myFun() { global $execDone; if($execDone === false) { file_put_contents("E:/myMsg.txt", date("Y-m-d H:i:s")."---error: 程序执行出错。\r\n", FILE_APPEND); /******** 以下可以做一些处理 ********/ } } 总结 register_shutdown_function这个函数主要是用在处理致命错误的后续处理上(PHP7更推荐使用Throwable来处理致命错误),不过缺点也很明显,只能处理致命错误Fatal error,其他的错误包括最高错误Parse error也是没办法处理的。
2025年03月07日
102 阅读
0 评论
0 点赞
2024-12-31
解决PHP连接Redis报read error on connection错误
背景 项目由于并发很高,所以将之前连接redis使用短连接改成了长连接,结果导致出现了抛出了read error on connection 出现原因 php有一个配置项default_socket_timeout表示一个socket连接的超时时间,默认是60s,而phpredis这个扩展的底层连接redis是使用的socket,所以当一个连接在60秒内没有被使用的时候,下次连接就会抛出这个异常。 解决方案 方案1 修改php.ini(不推荐) 在php.ini中设置default_socket_timeout = -1,然后重启php-fpm 方案2 程序中设置 使用ini_set函数 ini_set('default_socket_timeout', -1); // 不超时 方案3 使用redis的option 在连接redis时setOption $this->redis->setOption(Redis::OPT_READ_TIMEOUT, -1); 注意设置没有超时时间都要设置成-1 而不是0
2024年12月31日
142 阅读
0 评论
0 点赞
2024-10-22
PHP中 HTTP_HOST 和 SERVER_NAME 的区别
最近在开发站群软件,用到了根据访问域名判断子站点的相关问题。PHP获取当前域名有两个变量 HTTP_HOST 和 SERVER_NAME,我想知道两者的区别以及哪个更加可靠。 首先我想说,百度上那些转来转去的文章都是扯淡! 有说相同的,有说不同的,都没说明原因,没经过验证就互相转来转去的,浪费观众时间。 下面说说本人经过亲自验证 + 查阅官方文档 + 官方BUG列表 + 官方邮件列表 + sitepoint + webmasterworld + google的总结: 相同点: 当满足以下三个条件时,两者会输出相同信息。 1. 服务器为80端口 2. apache的conf中ServerName设置正确 3. HTTP/1.1协议规范 不同点: 1. 通常情况: $_SERVER[“HTTP_HOST”] 在HTTP/1.1协议规范下,会根据客户端的HTTP请求输出信息。 $_SERVER[“SERVER_NAME”] 默认情况下直接输出apache的配置文件httpd.conf中的ServerName值。 2. 当服务器为非80端口时: $_SERVER[“HTTP_HOST”] 会输出端口号,例如:mimiz.cn:8080 $_SERVER[“SERVER_NAME”] 会直接输出ServerName值 因此在这种情况下,可以理解为:HTTP_HOST = SERVER_NAME : SERVER_PORT 3. 当配置文件httpd.conf中的ServerName与HTTP/1.0请求的域名不一致时: httpd.conf配置如下: <virtualhost *> ServerName mimiz.cn ServerAlias www.mimiz.cn </virtualhost> 客户端访问域名www.mimiz.cn $_SERVER[“HTTP_HOST”] 输出 www.mimiz.cn $_SERVER[“SERVER_NAME”] 输出 mimiz.cn 所以,在实际程序中,应尽量使用_SERVER[“HTTP_HOST”] ,比较保险和可靠。
2024年10月22日
88 阅读
0 评论
0 点赞
2024-10-22
fas_openvpn进程守护
/var/www/html/目录下新建monitor.php,开启755权限 原来的守护脚本for循环里加一句:cd /var/www/html/;php monitor.php &>/dev/null monitor.php如下: <?php require('system.php'); $overtime = 10; $time = time(); $path_log = R.'/monitor.txt'; //log大于3MB则清空 if(filesize($path_log) > 1024*1024*3){ file_put_contents($path_log, ""); } if(strstr(end(file($path_log)), date('Y-m-d H:i:s')) != false){ exit('已经监控过啦'); } $files[0]["file"] = "openvpn_api/online_1194.txt"; $files[0]["telnet"] = "systemctl stop openvpn@server1194;systemctl start openvpn@server1194"; $files[1]["file"] = "openvpn_api/online_1195.txt"; $files[1]["telnet"] = "systemctl stop openvpn@server1195;systemctl start openvpn@server1195"; $files[2]["file"] = "openvpn_api/online_1196.txt"; $files[2]["telnet"] = "systemctl stop openvpn@server1196;systemctl start openvpn@server1196"; $files[3]["file"] = "openvpn_api/online_1197.txt"; $files[3]["telnet"] = "systemctl stop openvpn@server1197;systemctl start openvpn@server1197"; $files[4]["file"] = "openvpn_api/user-status-udp.txt"; $files[4]["telnet"] = "systemctl stop openvpn@server-udp;systemctl start openvpn@server-udp"; $msg = ''; foreach ($files as $k => $v){ $arr = [ 'file' => $v['file'], 'uptime' => date("Y-m-d H:i:s",filemtime($v['file'])), 'nowtime' => date("Y-m-d H:i:s",time()), ]; // var_export($arr); if((filemtime($v['file'])+$overtime) < $time){ $msg .= $v['file']; systemi("{$v['telnet']}"); file_put_contents($path_log,date('Y-m-d H:i:s').' 异常重启项:'.json_encode($arr)."\r\n",FILE_APPEND); } } if($msg == '') { echo "暂无异常"; file_put_contents($path_log,date('Y-m-d H:i:s').' 暂无异常。'."\r\n",FILE_APPEND); }else{ echo "异常项已重启:{$msg}"; }
2024年10月22日
108 阅读
0 评论
0 点赞
2024-10-22
PHP中register_shutdown_function函数的基础介绍与用法详解
1. 函数说明 定义:该函数是来注册一个会在PHP中止时执行的函数 参数说明: void register_shutdown_function ( callable $callback [, mixed $parameter [, mixed $... ]] ) 注册一个 callback ,它会在脚本执行完成或者 exit() 后被调用。 callback:待注册的中止回调 parameter:可以通过传入额外的参数来将参数传给中止函数 2. PHP中止的情况 PHP中止的情况有三种: 执行完成 exit/die导致的中止 发生致命错误中止 a. 第一种情况,执行完成 <?php function test() { echo '这个是中止方法test的输出'; } register_shutdown_function('test'); echo 'before' . PHP_EOL; 运行: before 这个是中止方法test的输出 注意:输出的顺序,等执行完成了之后才会去执行register_shutdown_function的中止方法test b. 第二种情况,exit/die导致的中止 <?php function test() { echo '这个是中止方法test的输出'; } register_shutdown_function('test'); echo 'before' . PHP_EOL; exit(); echo 'after' . PHP_EOL; 运行: before 这个是中止方法test的输出 后面的after并没有输出,即exit或者是die方法导致提前中止。 c. 第三种情况,发送致命错误中止 <?php function test() { echo '这个是中止方法test的输出'; } register_shutdown_function('test'); echo 'before' . PHP_EOL; // 这里会发生致命错误 $a = new a(); echo 'after' . PHP_EOL; 运行: before Fatal error: Uncaught Error: Class 'a' not found in D:\laragon\www\php_book\test.php on line 12 Error: Class 'a' not found in D:\laragon\www\php_book\test.php on line 12 Call Stack: 0.0020 360760 1. {main}() D:\laragon\www\php_book\test.php:0 这个是中止方法test的输出 后面的after也是没有输出,致命错误导致提前中止了。 3. 参数 第一个参数支持以数组的形式来调用类中的方法,第二个以及后面的参数都是可以当做额外的参数传给中止方法。 <?php class Shutdown { public function stop() { echo "这个是stop方法的输出"; } } // 当PHP终止的时候(执行完成或者是遇到致命错误中止的时候)会调用new Shutdown的stop方法 register_shutdown_function([new Shutdown(), 'stop']); // 将因为致命错误而中止 $a = new a(); // 这一句并没有执行,也没有输出 echo '必须终止'; 也可以在类中执行: <?php class TestDemo { public function __construct() { register_shutdown_function([$this, "f"], "hello"); } public function f($str) { echo "class TestDemo->f():" . $str; } } $demo = new TestDemo(); echo 'before' . PHP_EOL; /** 运行: before class TestDemo->f():hello */ 4. 同时调用多个 可以多次调用 register_shutdown_function,这些被注册的回调会按照他们注册时的顺序被依次调用。 不过注意的是,如果在第一个注册的中止方法里面调用exit方法或者是die方法的话,那么其他注册的中止回调也不会被调用。 代码: <?php /** * 可以多次调用 register_shutdown_function,这些被注册的回调会按照他们注册时的顺序被依次调用。 * 注意:如果你在f方法(第一个注册的方法)里面调用exit方法或者是die方法的话,那么其他注册的中止回调也不会被调用 */ /** * @param $str */ function f($str) { echo $str . PHP_EOL; // 如果下面调用exit方法或者是die方法的话,其他注册的中止回调不会被调用 // exit(); } // 注册第一个中止回调f方法 register_shutdown_function("f", "hello"); class TestDemo { public function __construct() { register_shutdown_function([$this, "f"], "hello"); } public function f($str) { echo "class TestDemo->f():" . $str; } } $demo = new TestDemo(); echo 'before' . PHP_EOL; /** 运行: before hello class TestDemo->f():hello 注意:如果f方法里面调用了exit或者是die的话,那么最后的class TestDemo->f():hello不会输出 */ 5. 用处 该函数的作用: 析构函数:在PHP4的时候,由于类不支持析构函数,所以这个函数经常用来模拟实现析构函数 致命错误的处理:使用该函数可以用来捕获致命错误并且在发生致命错误后恢复流程处理 代码如下: <?php /** * register_shutdown_function,注册一个会在php中止时执行的函数,中止的情况包括发生致命错误、die之后、exit之后、执行完成之后都会调用register_shutdown_function里面的函数 * Created by PhpStorm. * User: Administrator * Date: 2017/7/15 * Time: 17:41 */ class Shutdown { public function stop() { echo 'Begin.' . PHP_EOL; // 如果有发生错误(所有的错误,包括致命和非致命)的话,获取最后发生的错误 if (error_get_last()) { print_r(error_get_last()); } // ToDo:发生致命错误后恢复流程处理 // 中止后面的所有处理 die('Stop.'); } } // 当PHP终止的时候(执行完成或者是遇到致命错误中止的时候)会调用new Shutdown的stop方法 register_shutdown_function([new Shutdown(), 'stop']); // 将因为致命错误而中止 $a = new a(); // 这一句并没有执行,也没有输出 echo '必须终止'; 运行: Fatal error: Uncaught Error: Class 'a' not found in D:\laragon\www\php_book\1_23_register_shutdown.php on line 31 Error: Class 'a' not found in D:\laragon\www\php_book\1_23_register_shutdown.php on line 31 Call Stack: 0.0060 362712 1. {main}() D:\laragon\www\php_book\1_23_register_shutdown.php:0 Begin. Array ( [type] => 1 [message] => Uncaught Error: Class 'a' not found in D:\laragon\www\php_book\1_23_register_shutdown.php:31 Stack trace: #0 {main} thrown [file] => D:\laragon\www\php_book\1_23_register_shutdown.php [line] => 31 ) Stop. 注意:PHP7中新增了Throwable异常类,这个类可以捕获致命错误,即可以使用try...catch(Throwable $e)来捕获致命错误,代码如下: <?php try { // 将因为致命错误而中止 $a = new a(); // 这一句并没有执行,也没有输出 echo 'end'; } catch (Throwable $e) { print_r($e); echo $e->getMessage(); } 运行: Error Object ( [message:protected] => Class 'a' not found [string:Error:private] => [code:protected] => 0 [file:protected] => C:\laragon\www\php_book\throwable.php [line:protected] => 5 [trace:Error:private] => Array ( ) [previous:Error:private] => [xdebug_message] => Error: Class 'a' not found in C:\laragon\www\php_book\throwable.php on line 5 Call Stack: 0.0000 349856 1. {main}() C:\laragon\www\php_book\throwable.php:0 ) Class 'a' not found 这样的话,PHP7中使用Throwable来捕获的话比使用register_shutdown_function这个函数来得更方便,也更推荐Throwable。 注意:Error类也是可以捕获到致命错误,不过Error只能捕获致命错误,不能捕获异常Exception,而Throwable是可以捕获到错误和异常的,所以更推荐。 6.巧用register_shutdown_function判断php程序是否执行完 还有一种应用场景就是:要做一个消费队列,因为某条有问题的数据导致致命错误,如果这条数据不处理掉,那么整个队列都会导致瘫痪的状态,这样可以用以下方法来解决。即:如果捕获到有问题的数据导致错误,则在回调函数中将这条数据处理掉就可以了。 php范例参考与解析: <?php register_shutdown_function('myFun'); //放到最上面,不然如果下面有致命错误,就不会调用myFun了。 $execDone = false; //程序是否成功执行完(默认为false) /** ********************* 业务逻辑区************************* */ $tas = 3; if($tas == 3) { new daixiaorui(); } /** ********************* 业务逻辑结束************************* */ $execDone = true; //由于程序由上至下执行,因此当执行到此后,则证明逻辑没有出现致命的错误。 function myFun() { global $execDone; if($execDone === false) { file_put_contents("E:/myMsg.txt", date("Y-m-d H:i:s")."---error: 程序执行出错。\r\n", FILE_APPEND); /******** 以下可以做一些处理 ********/ } } 总结 register_shutdown_function这个函数主要是用在处理致命错误的后续处理上(PHP7更推荐使用Throwable来处理致命错误),不过缺点也很明显,只能处理致命错误Fatal error,其他的错误包括最高错误Parse error也是没办法处理的。
2024年10月22日
120 阅读
0 评论
0 点赞
2024-10-22
fastadmin基层库类修改历史
添加生成选强项框额外生成id类,并将[]转为_ /extend/fast/Form/select(),407行 $id = str_replace(['[',']'],"_",$name); return "<select id='".$id."' {$options}>{$list}</select>"; 假设$name=row[type_id],则最终js调用方法为 $(function(){ $("#row_type_id_").change(function(){ //要触发的事件 console.log('111') }); });
2024年10月22日
132 阅读
0 评论
0 点赞
2024-10-13
ss-panel-v3-mod_Uim修改笔记
为了方便后期维护,做个记录吧,自己用着舒服 码云地址:https://gitee.com/bufanyun/ss-panel-v3-mod_Uim 1.简化用户操作,隐藏ss、ssr教程和下载 \resources\views\material\user\index.tpl \resources\views\material\user\tutorial.tpl 修改内容不再贴出 都是html 2.加入slimphp自带的debug \config\routes.php $debug = true; $configuration = [ 'settings' => [ 'debug' => $debug, 'whoops.editor' => 'sublime', 'displayErrorDetails' => $debug ] ]; //error_reporting(E_ALL); //set_error_handler(function ($severity, $message, $file, $line) { // if (error_reporting() & $severity) { // throw new \ErrorException($message, 0, $severity, $file, $line); // } //}); 3.增加易支付模块 \config\.config.php 加入新的支付配置参数 $System_Config['payment_system']='epay'; #epay易支付 #鼎云支付:http://pay.xianweicm.com $System_Config['epay_partner']= ''; //商户ID $System_Config['epay_key']= ''; //商户KEY $System_Config['epay_apiurl'] = ''; //支付API地址 \config\routes.php //加入新的路由 $app->group('/user', function () { //支付跳转 131行 $this->get('/code/epay', App\Services\Payment::class . ':purchase'); } $app->group('/payment', function () { //异步回调加入get请求支持 161行 $this->get('/notify', App\Services\Payment::class . ':notify'); }); \app\Services\Payment.php 引用新的类 use App\Services\Gateway\Epay getClient(){方法 21行,加入新的指针对象 switch ($method) { case ('epay'): return new Epay(); } \app\Services\Gateway\Epay.php \\增加完整的模块操作 \extra\epay\require.php \\上传易支付sdk包 sdk包下载地址: https://gitee.com/bufanyun/pay/tree/master/SDK/lib 4.取消360浏览拦截 \public\assets\js\fuck.js 隐藏底部判断方法 5.修改composer中 Illuminate database底层 \vendor\esdeathlove\datatables\src\Datatables.php 方法generate() 213行,解决一个php7的报错 if(count((array)$this->edit) > 0) // if (count($this->edit) > 0)
2024年10月13日
121 阅读
0 评论
0 点赞
2024-10-13
使用illuminate database查询构造器进行数据库操作
Illuminate database是一个非常强大非常优秀的ORM类库,也是一个非常实用的数据库操作组件。使用它可以轻松对数据库进行查询、插入、更新、删除等操作,支持MySQL,Postgres,SQL Server,SQLlite等。它还是Laravel框架的数据库组件。 本文单独将illuminate database拿出来,脱离框架,主要讲讲使用illuminate database查询构造器进行数据库操作。 安装 使用 composer 安装,直接在项目根目录的命令行里,执行 composer require illuminate/database 建议PHP版本使用PHP^7.2。 建立配置 创建一个Capsule管理实例来配置数据库连接参数。 <?php $capsule = new \Illuminate\Database\Capsule\Manager; // 创建链接 $capsule->addConnection([ 'driver' => 'mysql', 'host' => 'localhost', 'database' => 'demo', 'username' => 'root', 'password' => '', 'charset' => 'utf8mb4', 'port' => 3306, 'collation' => 'utf8mb4_general_ci', 'prefix' => 'web_', ]); // 设置全局静态可访问DB $capsule->setAsGlobal(); // 启动Eloquent (如果只使用查询构造器,这个可以注释) $capsule->bootEloquent(); 将配置文件保存为database.php。再新建文件index.php,代码如下: <?php date_default_timezone_set("PRC"); require 'vendor/autoload.php'; require 'database.php'; use Illuminate\Database\Capsule\Manager as DB; 自行准备好数据库表,现在,可以直接在index.php后面写数据库操作语句了。 获取结果集 从一张表中获取一行/一列 如果我们只是想要从数据表中获取一行数据,可以使用first 方法,该方法将会返回单个StdClass对象: $article = DB::table('article')->where('author', '月光光')->first(); echo $article->title; 如果我们不需要完整的一行,可以使用value 方法从结果中获取单个值,该方法会直接返回指定列的值: $title = DB::table('article')->where('author', '月光光')->value('title'); 获取数据列值列表 如果只要查询表中的某一列值,可使用pluck方法。 $titles = DB::table('article')->where('author', '月光光')->pluck('title'); foreach ($titles as $title) { echo $title; } 如果要获取一个表中的其中几个字段列的结果,可以使用select和get方法。 $list = DB::table('article')->select('id', 'title')->get(); $list = DB::table('article')->get(['id', 'title']); 两条语句返回的结果是一样的。要获取结果,需要遍历$list: foreach ($list as $key => $val) { echo $val->id; echo $val->title; } 强制不重复 distinct方法允许你强制查询返回不重复的结果集 $list = DB::table('article')->distinct()->get(); Where查询 简单 Where 子句 使用查询构建器上的where方法可以添加where子句到查询中,调用where最基本的方式需要传递三个参数,第一个参数是列名,第二个参数是任意一个数据库系统支持的操作符,第三个参数是该列要比较的值。 如,查询id值为100的记录。 $row = DB::table('article')->where('id', '=', '100')->get(); 当要查询的列值和给定数组相等时,可以将等号省略。上面的语句可以这样写: DB::table('article')->where('id', '100')->get(); 除了等号,还有>=,<=,<>,like DB::table('article')->where('title', 'like', 'php%')->get(); Where数组 还可以传递条件数组到where函数: $list = DB::table('article')->where([ ['id', '>', '100'], ['source', '=', 'helloweba.com'] ])->get(); or 语句 我们可以通过方法链将多个where约束链接到一起,也可以添加 or 子句到查询,orWhere方法和 where 方法接收参数一样: $list = DB::table('article') ->where('source', 'helloweba.com') ->orWhere('hits', '<', '1000') ->get(['id', 'title', 'hits']); whereIn语句 whereIn方法验证给定列的值是否在给定数组中。whereNotIn方法验证给定列的值不在给定数组中。 $list = DB::table('article')->whereIn('id', [10,100,200])->get(['id', 'title']); whereBeteen语句 whereBetween方法验证列值是否在给定值之间,whereNotBetween方法验证列值不在给定值之间。 $list = DB::table('article') ->whereBetween('hits', [1, 1000])->get(['id', 'title', 'hits']); whereNull语句 whereNull方法验证给定列的值为NULL,whereNotNull方法验证给定列的值不是 NULL。 $list = DB::table('article') ->whereNull('updated_at') ->get(); whereDate语句 如果我们要查询创建日期在2019-08-29的文章记录,可以使用whereDate。 $list = DB::table('article')->whereDate('created_at', '2019-08-29')->get(['id', 'title', 'created_at']); whereMonth语句 如果我们要查询创建月份在10月份的所有文章记录,可以使用whereMonth。 $list = DB::table('article')->whereMonth('created_at', '10')->get(['id', 'title', 'created_at']); whereDay语句 如果要查询创建日期在1号的所有文章,可以使用whereDay。 $list = DB::table('article')->whereDay('created_at', '1')->get(['id', 'title', 'created_at']); whereYear语句 如果要查询创建年份是2016年的所有文章,可以使用whereYear。 $list = DB::table('article')->whereYear('created_at', '2016')->get(['id', 'title', 'created_at']); whereTime语句 如果要查询创建时间在10:20的所有文章,可以使用whereTime。 $list = DB::table('article')->whereTime('created_at', '10:20')->get(['id', 'title', 'created_at']); whereColumn语句 如果要查询文章表中创建时间和更新时间相等的所有文章,可以使用whereColumn。 $list = DB::table('article')->whereColumn('created_at', '=', 'updated_at')->get(['id', 'title', 'created_at']); 聚合查询 查询构建器还提供了多个聚合方法,如总记录数: count, 最大值: max, 最小值:min,平均数:avg 和总和: sum,我们可以在构造查询之后调用这些方法。 $count = DB::table('article')->count(); //总记录数 $max = DB::table('article')->max('hits'); //点击量最大 判断记录是否存在 除了通过 count 方法来判断匹配查询条件的结果是否存在外,还可以使用exists 或doesntExist 方法: $exists = DB::table('article')->where('author', '月光光')->exists(); 返回的是true和false。 排序、分组与限定 orderBy 我们要对查询的记录进行顺序asc和倒序desc排序,可以使用orderBy。 $list = DB::table('article')->orderBy('id', 'desc')->get(['id', 'title']); latest / oldest 我们可以使用latest和oldest对日期字段created_at。 $list = DB::table('article')->latest()->first(); inRandomOrder 如果我们要从文章表中随机排序,查询一条随机记录,可以使用inRandomOrder。 $list = DB::table('article')->inRandomOrder()->first(); groupBy / having 如果要对结果集进行分组,可以使用groupBy方法和having方法。 DB::table('article')->groupBy('cate')-having('id', '>', 100)->get(); skip / take 如果要对结果集进行跳过给定的数目结果,可以使用skip和take方法,该方法常用于数据分页。 $list = DB::table('article')->skip(10)->take(5)->get(['id', 'title']); 以上语句等价于: $list = DB::table('article')->offset(10)->limit(5)->get(['id', 'title']); 连接Join 查询构建器还可以用于编写join连接语句,常见的几种连接类型有:join、leftJoin、rightJoin等。 $list = DB::table('mark') ->join('user', 'mark.user_id', '=', 'user.id') ->join('article', 'mark.article_id', '=', 'article.id') ->get(['article.id','article.title','user.username','user.nickname']); 插入数据 查询构建器还提供了insert方法用于插入记录到数据表。insert方法接收数组形式的字段名和字段值进行插入操作 DB::table('article')->insert( ['title' => 'PDO操作数据库', 'author' => '月光光'] ); 支持批量插入: DB::table('article')->insert( ['title' => 'PDO操作数据库', 'author' => '月光光'], ['title' => 'PDO那些事', 'author' => '想吃鱼的猫'], ); 自增ID 使用insertGetId方法来插入记录并返回ID值,如果表中的id为自增长ID,则返回的即为自增ID。 $id = DB::table('article')->insertGetId( ['title' => 'PDO操作数据库', 'author' => '月光光'], ); 更新数据 使用update方法可以更新对应的字段。 DB::table('article')->where('id', 1)->update('author', '月光光'); 增减数字 我们可以使用increment和decrement方法增减某个列值,比如增加点击量。 DB::table('article')->increment('hits'); //点击量+1 DB::table('article')->increment('hits', 5); //点击量+5 DB::table('article')->decrement('hits'); //点击量-1 DB::table('article')->decrement('hits', 5); //点击量-5 删除数据 使用delete方法可以从表中删除记录。 DB::table('article')->where('id', 10)->delete(); 如果我们要清空一张表,将自增长id归0,可以使用truncate方法。 DB::table('article')->truncate(); 打印sql日志 有时我们需要调试sql语句,查看最后一次执行的原生的sql语句,可以使用以下方法: DB::connection()->enableQueryLog(); $list = DB::table('article')->skip(10)->take(5)->get(['id', 'title']); print_r(DB::getQueryLog()); 2019-11-17补充: 事务 想要在一个数据库事务中运行一连串操作,可以使用 DB 门面的transaction 方法,使用transaction方法时不需要手动回滚或提交:如果事务闭包中抛出异常,事务将会自动回滚;如果闭包执行成功,事务将会自动提交: DB::transaction(function () { DB::table('users')->update(['votes' => 1]); DB::table('posts')->delete(); }); 当然我们也可以使用手动控制事务,从而对回滚和提交有更好的控制,可以使用 DB 门面的 beginTransaction方法: DB::beginTransaction(); 可以通过rollBack方法回滚事务: DB::rollBack(); 最后,我们可以通过commit方法提交事务: DB::commit(); 小结 Illuminate database提供的查询构造器可以轻松实现对数据库的操作,能满足我们日常开发需求,当然,在框架中使用的时候更多的使用ORM进行数据操作,后面我们会有文章介绍Illuminate database的ORM功能,彻底摆脱sql语句的束缚。
2024年10月13日
68 阅读
0 评论
0 点赞
2024-10-13
fastadmin:模板文件不存在
`正常tp5中: 配置:'view_path' => '.\view\\' 报错信息:模板文件不存在:.\view\index\index.html 模板文件实际是存在的,试了下,只有写绝对路径才能正确找到模板文件 return $this->fetch('D:/Program Files/php/Apache24/htdocs/match/application/view/index/index.html'); 模板路径拼接问题,将配置改为 'view_path' => '../application/view/' 就可以了。 但是!在fastadmin中,每个默认生成控制器下回携带一个参数 protected $layout = 'default'; 由于二开项目修改了默认的渲染 所以导致不管怎么改路径都不行,最后突然发现了这个,注释掉即可!万恶啊!浪费好久时间! 后续 注释掉 protected $layout = 'default';仍然不行! 查看报错后发现了这个,去检查目录发现这个文件确实不存在,找到原因了,修改路径即可
2024年10月13日
183 阅读
0 评论
0 点赞
1
2
3
4
5