首页
4K壁纸
直播
统计分析
友情链接
搜索
1
#1031 – TABLE STORAGE ENGINE FOR ” DOESN’T HAVE THIS OPTION解决方法
1,252 阅读
2
让浏览器不显示 https 页面中 http 请求警报 http-equiv=”Content-Security-Policy” content=”upgrade-insecure-requests”
965 阅读
3
报错代码:ERROR 1227 (42000)-解决办法
750 阅读
4
微信个人商户号养号建议
592 阅读
5
解决移动端position:fixed随软键盘移动的问题
570 阅读
Php
Mysql
Linux
Reids
Java
Python
常用笔记
学习
乱七八糟
Search
标签搜索
php
Mysql
千卡云支付
Linux
redis
千卡云
千卡易支付
Nginx
function
JS
session
shell
JSON
跨域
支付宝
CentOS
Apache
支付
composer
Array
蓝科迪梦
累计撰写
106
篇文章
累计收到
0
条评论
首页
栏目
Php
Mysql
Linux
Reids
Java
Python
常用笔记
学习
乱七八糟
页面
4K壁纸
直播
统计分析
友情链接
搜索到
106
篇与
蓝科迪梦 发布的内容
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日
56 阅读
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日
29 阅读
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日
22 阅读
0 评论
0 点赞
2025-06-25
which is not functionally dependent on columns in GROUP BY clause
报错信息:which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by 在对连接表进行select查找时出现以上报错信息。 打开【my.ini】文件 添加如下代码在【mysqld】中 sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION 保存,重启mysql即可
2025年06月25日
115 阅读
0 评论
0 点赞
2025-05-20
pnpm install出现:ERR_PNPM_PEER_DEP_ISSUES Unmet peer dependencies
使用 pnpm install 安装项目依赖时出现:ERR_PNPM_PEER_DEP_ISSUES Unmet peer dependencies 解决方法: 第一种: 在项目的 package.json 中配置 peerDependencyRules 忽略对应的警告提示: { "pnpm": { "peerDependencyRules": { "ignoreMissing": ["react"] } } } 第二种: 在 .npmrc 配置文件中添加 strict-peer-dependencies=false ,这意味着将关闭严格的对等依赖模式。操作命令如下: npm config set strict-peer-dependencies=false 无论从事什么行业,只要做好两件事就够了,一个是你的专业、一个是你的人品,专业决定了你的存在,人品决定了你的人脉,剩下的就是坚持,用善良專業和真诚赢取更多的信任。
2025年05月20日
37 阅读
0 评论
0 点赞
2025-04-07
intellij idea常用快捷键
常用快捷键 Alt+回车 导入包,自动修正 Ctrl+N 查找类 Ctrl+Shift+N 查找文件 Ctrl+Alt+L 格式化代码 Ctrl+Alt+O 优化导入的类和包 Alt+Insert 生成代码(如get,set方法,构造函数等) Ctrl+X 删除行 Ctrl+D 复制行 Ctrl+/ 或 Ctrl+Shift+/ 注释(// 或者 ) Ctrl+J 自动代码 Ctrl+P 方法参数提示 psvm main() souf system.out.pringln() Ctrl+b 或 F4 查看源代码 Ctrl+Alt+T try{}catch(){}finally{} CTRL+ALT+I 自动缩进 CTRL+ALT+O 优化导入的类和包 CIRL+U 大小写切换
2025年04月07日
46 阅读
0 评论
0 点赞
2025-03-29
mysql中 for update 使用方法
for update是在数据库中上锁用的,可以为数据库中的行上一个排它锁。当一个事务的操作未完成时候,其他事务可以读取但是不能写入或更新。 例子: 比如一张表三个字段 , id(商品id), name(商品名字) , count(数量) 当商品抢购时候会显示剩余商品件数,如果并发量大的时候,商品自减的值可能不准确。所以当我们在一个事务中对count字段进行修改的时候,其他事务应该只能读取指定id的count,而不能进行update等操作。这个时候就需要用到for update. sql语句: start transaction ; select * from table_name where id =1 for update ; update table_name set count = count - 1 where id= 1; 此时如果另一个事务也想执行类似的操作: start transaction ; select * from table_name where id =1 for update ; //下面的这行sql会等待,直到上面的事务回滚或者commit才得到执行。 update table_name set count = count - 1 where id= 1; *注:当选中某一个行的时候,如果是通过主键id选中的。那么这个时候是行级锁。 其他的行还是可以直接insert 或者update的。如果是通过其他的方式选中行,或者选中的条件不明确包含主键。这个时候会锁表。其他的事务对该表的任意一行记录都无法进行插入或者更新操作。只能读取。* 那是一种行级锁,一旦用户对某个行施加了行级加锁,则该用户可以查询也可以更新被加锁的数据行,其它用户只能查询但不能更新被加锁的数据行.如果其它用户想更新该表中的数据行,则也必须对该表施加行级锁.即使多个用户对一个表均使用了共享更新,但也不允许两个事务同时对一个表进行更新,真正对表进行更新时,是以独占方式锁表,一直到提交或复原该事务为止。行锁永远是独占方式锁。 只有当出现如下之一的条件,便释放共享更新锁: (1)、执行提交(COMMIT)语句; (2)、退出数据库(LOG OFF) (3)、程序停止运行。 那么,什么时候需要使用for update?就是那些需要业务层面数据独占时,可以考虑使用for update。场景上,比如火车票订票,在屏幕上显示邮票,而真正进行出票时,需要重新确定一下这个数据没有被其他客户端修改。所以,在这个确认过程中,可以使用for update。这是统一的解决方案方案问题,需要前期有所准备
2025年03月29日
33 阅读
0 评论
0 点赞
2025-03-26
phpMyAdmin登录时指定服务器ip和端口的方法
1、打开phpMyAdmin目录, 在此目录下是否有config.sample.inc.php文件,如果存在,那么将其改名为config.inc.php;为避免修改失误所造成的损失,强烈建议先备份 config.sample.inc.php 文件为 config.sample.inc.php.bak; 2、在phpMyAdmin的配置文件 config.inc.php 中加上一个配置项 $cfg['AllowArbitraryServer'] = true; /* 允许自定义服务器,默认为false */ 设置多选服务器 $i++; $cfg['Servers'][$i]['auth_type'] = 'cookie'; /* Server parameters */ $cfg['Servers'][$i]['host'] = '172.22.0.16'; $cfg['Servers'][$i]['compress'] = false; $cfg['Servers'][$i]['AllowNoPassword'] = false;
2025年03月26日
30 阅读
0 评论
0 点赞
2025-03-18
/usr/sbin/mysqld: Can't open file: '**.frm'(errno: 24 - Too many open files)
kangle主机开的主机多了mysql就容易挂,每次都要重启mysql才能解决,今天抽空查了下日志,看到大量这个报错: /usr/sbin/mysqld: Can't open file: '**.frm'(errno: 24 - Too many open files) 主要原因: lock tables时候文件打开句柄太多导致,可以适当调大文件打开数句柄。 解决方法: 在 /etc/mysql/my.conf 中,你需要增加MySQLs内部 open_files_limit。 所以暂时将这个添加到配置并重启 MySQL。 [mysqld] open_files_limit = 100000 /bin/systemctl restart mysqld.service ============================ 因为kangle主机有很多的小白用户,发现存在很多死进程,为了保证稳定性和长期免维护,又在定时任务中加了定期重启mysql 配置crond服务启动计划需要编辑etc目录下的crontab文件内容,直接用Vim编辑它: vim /etc/crontab vim编辑命令不熟的可以搜索一下,不难,添加一行,比如我要每天凌晨2:30自动重启一次mysql就添加下面这样一行: 30 2 * * * root /bin/systemctl restart mysqld.service 保存重启下crontabs就可以了. /bin/systemctl restart crond.service
2025年03月18日
96 阅读
0 评论
0 点赞
2025-03-18
mysql查询json字段
一张openvpn表里存了一个stop字段是json类型的 表名:openvpn 字段:id int(11) , stop json(255) 假如stop的数据: { "surplus": 119, "opentime": 0 } 1.查询该stop里status这个字段数据: SELECT id,JSON_EXTRACT(stop,'$.status') as status FROM `openvpn` 2.查询该stop里status这个字段为0的数据: SELECT id,JSON_EXTRACT(stop,'$.status') as status FROM `openvpn` WHERE JSON_EXTRACT(stop,'$.status') = 0 3.查询该stop里status这个字段不为1且id大于10000的数据: SELECT id,JSON_EXTRACT(stop,'$.status') as status FROM `openvpn` WHERE JSON_EXTRACT(stop,'$.status') != 1 AND `id` > 10000 备注:通过json_extract函数,获取到了json对象的特定key的值
2025年03月18日
57 阅读
0 评论
0 点赞
2025-03-18
which is not functionally dependent on columns in GROUP BY clause
报错信息:which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by 在对连接表进行select查找时出现以上报错信息。 打开【my.ini】文件 添加如下代码在【mysqld】中 sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION 保存,重启mysql即可
2025年03月18日
66 阅读
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-10
中兴F7015TV3光猫相关命令
1、普通用户提权为 admin sendcmd 1 DB set DevAuthInfo 1 Level 1 sendcmd 1 DB save Bash 2、修改超级用户名和密码: sendcmd 1 DB set DevAuthInfo 0 User XXXXXX #(改超级用户名xxxxx) sendcmd 1 DB set DevAuthInfo 0 Pass XXXXXX #(改超级密码xxxxx) Bash 3、修改用户限制: sendcmd 1 DB p CltLmt sendcmd 1 DB set CltLmt 8 Max 20 #(修改最大用户数为20,可以改成其他数目,最大数目不超过255) sendcmd 1 DB set CltLmt 8 Enable 0 sendcmd 1 DB save Bash 4、关闭 TR069 与定时上报(不懂的用户慎操作): sendcmd 1 DB p MgtServer #查看一下当前的电信远程控制 sendcmd 1 DB set MgtServer 0 URL http://127.0.0.1 #把服务器 URL 改掉 sendcmd 1 DB set MgtServer 0 Tr069Enable 0 sendcmd 1 DB set MgtServer 0 PeriodicInformEnable 0 sendcmd 1 DB save Bash 5、劫持 ITMS 注册(不懂的用户慎操作): sendcmd 1 DB set PDTCTUSERINFO 0 Status 0 sendcmd 1 DB set PDTCTUSERINFO 0 Result 1 sendcmd 1 DB save Bash 6、恢复 TR069 与定时上报功能(以甘肃电信为例,每个省份的上报服务器应该不一样) sendcmd 1 DB p MgtServer #查看一下当前的电信远程控制 sendcmd 1 DB set MgtServer 0 URL http://devacs.edatahome.com:9090/ACS-server/ACS sendcmd 1 DB set MgtServer 0 Tr069Enable 1 sendcmd 1 DB set MgtServer 0 PeriodicInformEnable 1 sendcmd 1 DB save Bash 7、关闭开启指示灯 sendcmd 1 DB p WLCInfo #查看 sendcmd 1 DB set WLCInfo 0 WLCStatus 1 #关闭 sendcmd 1 DB set WLCInfo 0 WLCStatus 0 #开启 sendcmd 1 DB save #保存 reboot #重启之后会生效 Bash 8、开永久 telnet(密码 Zte521) sendcmd 1 DB p TelnetCfg sendcmd 1 DB set TelnetCfg 0 Lan_Enable 1 sendcmd 1 DB set TelnetCfg 0 TS_UName root sendcmd 1 DB set TelnetCfg 0 TSLan_UName root sendcmd 1 DB set TelnetCfg 0 TS_UPwd Zte521 sendcmd 1 DB set TelnetCfg 0 TSLan_UPwd Zte521 sendcmd 1 DB set TelnetCfg 0 Max_Con_Num 99 sendcmd 1 DB set TelnetCfg 0 ExitTime 999999 sendcmd 1 DB set TelnetCfg 0 InitSecLvl 3 sendcmd 1 DB set TelnetCfg 0 CloseServerTime 9999999 sendcmd 1 DB set TelnetCfg 0 Lan_EnableAfterOlt 1 sendcmd 1 DB save Bash 9、删除 WiFi 前缀 sendcmd 1 DB set WLANCfg 0 ESSIDPrefix #(设置2.4G的ssid前缀为空) sendcmd 1 DB set WLANCfg 4 ESSIDPrefix #(设置5G的ssid前缀为空) sendcmd 1 DB save Bash 10、查询 / 切换区域码命令 cat /etc/init.d/regioncode #查询 upgradetest sdefconf 226 #切换 (甘肃) Bash 11、查看系统参数 / 修改 PonMac setmac show2 #查看系统参数 setmac 1 32769 EEEEEEEE #修改PonMac Bash 12、其他命令 #禁用TR069远程控制 sendcmd 1 DB set MgtServer 0 PeriodicInformEnable 0 #关闭防火墙; sendcmd 1 DB set FWLevel 0 Level 0 #关闭防火墙并发连接数最大限制 sendcmd 1 DB set FWBase 0 FwConnMaxEnable 0 #改最大并发连接数 sendcmd 1 DB set FWBase 0 ConntrackMax 65535 #允许切换双模 setmac 3 40962 #查看CPU占用率 cat /proc/cpuusage #查看温度 cat /proc/tempsensor #关闭下行GPON光口和WiFi— ip link set mini-olt down rmmod optical rmmod mtlk rmmod mtlkroot
2025年03月10日
36 阅读
0 评论
0 点赞
1
2
3
4
...
8