首页
登录
搜索
登录
搜索
千古互动
QQ:54505339
累计撰写
45
篇文章
累计收到
1
条评论
首页
栏目
首页
登录
作者 【1】 的文章
2024-5-5
宝塔面板对接模块安装使用说明 对接 魔方
在财务后台-应用商店安装完模块后,在后台-商品-接口设置中先创建新的分组,模块选择宝塔面板对接模块,名字自拟 添加新接口,分组就选择刚创建好的那个分组,IP地址和主机名填写宝塔的域名或IP,然后将下方的hash填入宝塔面板上设置的API接口-接口密钥,记得添加白名单IP为你的财务系统服务器IP,若有SSL就打开SSL,端口填写宝塔面板的端口。 接着访问,你的域名/api/exec_module_func?module_name=btpanel&module_func=webftpsync 当显示WEBFTP同步完毕时,我们来看下一步 添加商品,在接口设置中完成各项的填写,然后创建两个自定义字段,字段名1:域名,类型:文本框,设置订单可见、必填;字段名2:hostid,类型:文本框,设置仅管理员可见。 开启弹性模式的情况下请在产品设置-产品配置中增加,配置项名称: hostspace|虚拟主机容量 dbspace|数据库容量 domainums|域名数量 backnums|可创建的备份数量 flow|月可用流量 虚拟主机容量/数据库容量的子项添加按照100|100M,这个格式来填,100是容量,100M是给用户看的,若无限制就0|不限制 域名数量的子项按照1|1个。这样来填,1是数量,1个是给用户看的,若不限制就0|不限制域名数量 可创建的备份数量的子项按照1|1个。这样来填,1是数量,1个是给用户看的,若不限制就0|不限制备份数量 月流量的子项按照100|100M,这个格式来填,100是容量,100M是给用户看的,若无限制就0|不限制 这样就完成了我们在财务系统中的设置操作,还需要注意的是:虚拟主机容量、数据库容量、流量限制需要配合财务系统中的计划任务,请检查财务系统的计划任务是否正常运行。 流量限制需安装宝塔面板应用商店的网站监控报表插件,否则限制是无效的。 首先在应用商品中下载安装 宝塔面板对接模块 弹性配置 如下 虚拟主机容量 配置选项名称 hostspace|虚拟主机容量 子项名称 500| 500M 数据库容量 配置选项名称 dbspace|数据库容量 子项名称 500| 500M 域名数量 配置选项名称 domainums|绑定域名数量 子项名称 3| 3个 可创建备份数 配置选项名称 backnums|可创建的备份数量 子项名称 1| 1个 月可用流量 配置选项名称 flow|月可用流量 子项名称 1024| 1G 实现在魔方财务销售宝塔面板虚拟主机,并将宝塔面板的基础功能集成到了财务上方便了用户的日常管理~ 安装使用说明见帮助文档,戳这里访问帮助文档 为确保安全,开通的所有虚拟主机均默认开启防跨站,请将安装的所有PHP版本都安装上PHP扩展:bt_safe,进一步确保安全。 支持限制虚拟主机容量、数据库容量、域名绑定数量、流量 支持在线FTP等功能 支持一键申请Let's Encrypt免费SSL证书 支持创建网站、数据库备份并支持下载备份 更多功能等你来挖掘~ 请务必在宝塔应用商店的网站监控报表插件,否则流量限制无法使用! V2.1.5版本更新 更新内容: 修正财务某些版本可能出现的样式丢失问题 V2.1.0版本更新 更新内容: 1、修复某些玄学情况下按钮样式丢失的问题 2、修复在线FTP不能用的问题 [切记!更新至此版本后需访问 您的域名/api/exec_module_func?module_name=btpanel&module_func=webftpsync 进行同步!!!] V2.0.2版本更新 更新内容: 1、修复弹性模式下备份个数不受限制的BUG V2.0.1版本更新 更新内容: 1、修复当FTP不创建的情况下前台数据库功能无法使用的BUG V2.0.0版本更新 更新内容: 1、重构模块 2、修复旧版本存在的BUG 3、适配魔方财务最新版本 1.1.4版本更新 更新内容: 修复产品参数配置页面PHP版本、分类无法自动获取的BUG 开通、暂停、解除暂停、删除等操作细化逻辑判断,避免操作执行失败仍返回成功的问题 1.1.3版本更新 更新内容: 后台产品参数项优化,分类、PHP版本自动获取,直接选择无需填写。 优化在数据库未开通情况下的前台显示 开通逻辑优化 本版本更新后请检查自己产品中的参数配置,本次更新修改了部分参数。 1.1.2版本更新 更新内容: 前台新增404公益功能[需在宝塔应用商店安装404公益插件] 前台新增网站加速功能[需在宝塔应用商店安装堡塔网站加速插件] 新增流量限制功能[需在宝塔应用商店安装网站监控报表插件] 弹性新增流量限制(具体见帮助文档) 前台SSL证书、伪静态内容框优化 兼容支持PHP8 其他功能逻辑优化 本版本更新后请检查自己产品中的参数配置,本次更新修改了部分参数。 1.1.1版本更新 更新内容: 紧急修复了1.0.9[1.1.0合并]版本在弹性模式下域名绑定功能可能无法正常绑定的BUG 1.0.9(1.1.0)版本更新 更新内容: 前台强制HTTPS功能优化 前台FTP功能页面细微调整 前台样式细微调整 主机详情页面新增域名绑定数量、网站备份、数据库备份数量情况 新增数据库备份中心,可创建、恢复、删除备份 后台可限制备份数量和是否开启一键部署 弹性功能新增可创建备份数量 一键部署功能优化 部分功能逻辑优化 本版本更新后请检查自己产品中的参数配置,本次更新修改了部分参数。 1.0.8版本更新 更新内容: 紧急修复了一个逻辑错误 1.0.7版本更新 更新内容: 修复了SSL证书提交显示报错的问题 支持了伪静态内容在线修改提交 修正了一键部署中当前PHP版本框不显示5.6以下版本的问题 增加了关闭SSL功能,优化了部分逻辑。 1.0.6版本更新 更新内容: 紧急修复了前台点击在线FTP跳出修改FTP密码的BUG 1.0.4版本更新 更新内容: 增加了弹性功能,如何添加见帮助文档 优化了开通逻辑,当密码为空时自动随机生成密码,否则使用产品上的密码。 前台UI美化,更轻、更快、更好看 修复了使用CDN后前台显示异常的问题 前台产品详情显示使用情况美化,更改为进度条。 部分功能逻辑优化 本版本更新后请检查自己产品中的参数配置,本次更新修改了部分参数。 1.0.2版本更新 更新内容: 修复了伪静态无法保存问题 修复了部分逻辑错误问题 本版本更新后请检查自己产品中的参数配置,本次更新修改了部分参数。 1.0.1版本发布 更新内容: 修复了前台无法修改FTP密码的BUG 修复了在线FTP无法使用的问题 增加了自行选择暂停时是否连同FTP一起暂停 增加了防盗链功能 优化了开通逻辑 增加了容量设置为0[无限制]时的逻辑 优化了容量设置为无限制时的前台显示 1.0.0初始版本发布
2024年-5月-5日
1615 阅读
0 评论
未分类
2024-5-5
模板对接教程
模板对接教程 Bty3支持首页模板(Bty3.4)、ep模板多模板设置,让自己也能做模板 大家可以尝试先对接首页模板 由于EP模板文件设计复杂,及功能居多,有能力的可以尝试对接 模板对接完成后可以在后台中添加并启用该模板(请符合格式进行填写,否则不能被正确使用) 安装模版 假如我们的主题叫做 BtyTemp 上传模版静态文件到 /public/static/BtyTemp 上传模版文件到对应模版的路径 网站首页模版 /application/index/view/BtyTemp/ 用户中心模版 /application/user/view/BtyTemp/ 控制中心模版 /application/vhost/view/BtyTemp/ Bty后台 -> 模版管理 -> 新增 -> 主题名:BtyTemp(这个可以自定义);主题模版:BtyTemp(注意区分大小写);主题类别:(请事先确定该模版的类型) -> 新增 系统设置 -> 找到下面的主题设置 -> 选择相对应添加的模版 BtyTemp 即可 目录介绍 application\index\view\ 网站首页 defalut 网站首页模板名 article.html 文章列表页面 article_list.html 文章详情页面 error.html 404页面 index.html 首页文件 public.html 公共模板文件 application\vhost\view\ kangle ep模板名 太多…… 不一一列举 light ep模板名 太多…… 不一一列举 模板对接参数 全局参数 网站名 -- {$Think.const.WEB_NAME} 网站域名 -- {$Think.const.WEB_DOMAIN} 网站关键词 -- {$Think.const.WEB_KEY} 网站描述 -- {$Think.const.WEB_DES} 网站LOGO图(地址) -- {$Think.const.WEB_LOGO} 站长QQ -- {$Think.const.WEB_QQ} 站长邮箱 -- {$Think.const.WEB_EMAIL} ICP备案号 -- {$Think.const.WEB_ICP} 站点统计代码 -- {$Think.const.WEB_TONGJI} 站点公告 -- {$Think.const.WEB_NOTICE} 管理员登录状态(0->未登录;1->已登录) -- {$Think.const.WEB_ADMIN} 用户登录状态(0->未登录;1->已登录)-- {$Think.const.WEB_USER} 文件路径地址 STATIC/ 等于路径 /public/static/ 调用公共文件模板 {extend name="default/public" /} default是你模板文件夹名 public是公共模板文件名 设置不同的标题 {block name="title"}这是标题{/block} 公共文件调用路径 jQuery v2.1.4 -- STATIC/js/jquery.min.js jQuery Cookie v1.4.1 -- STATIC/js/jquery.cookie.js Bootstrap v3.3.7 -- STATIC/js/bootstrap.min.js STATIC/css/bootstrap.min.css layer弹出层 v3.1.1 -- STATIC/js/layer/layer.js Ps:更多文件请在 /public/static 目录下寻找 首页模板 首页主机列表 {volist name="hostList" id="host" offset="0" length='10'} {$host.name} {/volist} 登录状态 {if condition="$UserInfo"} 会员中心 {else /} 登入 注册 {/if} 友情链接 {volist name="links" id="l"} {$l.name} {/volist} 文章列表模板 帮助文章列表 {volist name="list" id="article"} {$article.title|substr=0,30} -- {$article.time|date="Y-m-d",###} {/volist} 文章列表分页 {$list->render()} 文章内容页 文章标题 {$info.title} 文章内容 {$info.content} 文章作者(统一为管理员) {$info.author} 文章发布时间 {$info.time|date="Y-m-d",###}
2024年-5月-5日
1508 阅读
0 评论
未分类
2024-5-5
CentOS7.x数据盘合并至根目录系统盘扩容
使用命令df -TH查看当前系统挂载的情况 df-TH.png 然后通过命令fdisk -l查看全部硬盘信息 可以看到 当前 只有系统磁盘 fdisk-l1.png 现在我 装了一块 120GB 磁盘 fdisk-l2.png 注意!注意!注意! fdisk /dev/盘符路径 根据自己的 路劲修改 、我的是 SDB 你的也可以是SDA SDC 等等... 注意!注意!注意! fdisk /dev/盘符路径 根据自己的 路劲修改、 我的是 SDB 你的也可以是SDA SDC 等等... 注意!注意!注意! fdisk /dev/盘符路径 根据自己的 路劲修改、 我的是 SDB 你的也可以是SDA SDC 等等... 现在开始 执行挂载 数据磁盘 执行命令 fdisk /dev/sdb,进入fdisk模式,开始对新增数据盘执行分区操作 fdisk.dev.sdb.png 接下来输入 n n.png p p.png 1 分一个盘 然后 回车2次 11.png 接着输入 w 保存,将分区结果写入分区表中。 w.png 如回显信息如下,则说明分区成功: The partition table has been altered! Calling ioctl() to re-read partition table. Syncing disks. 执行命令 partprobe 将新的分区表变更同步至操作系统。 partprobe.png 执行以下命令,将新建分区文件系统设为系统所需格式。 mkfs -t ext4 /dev/sdb 在输入 y 回车 确定 yyy.png 输入完后 等待 完成 5、新建的一个挂载点,即目录,如果目录不存在要提前新建好,否则开机将可能失败 也可以根据自己需求 设置新建挂载目录。本处默认 WWW mkdir /www 这个命令为: 新建一个 www 目录 bt-www.png mount /dev/sdb /www 这个命令为: 将 /dev/sdb 挂载到 /www 目录 mount.dev.sdb.www.png 编辑开机启动项目 命令 如下: vi /etc/fstab 进入后按 i 使用键盘方向键 将光标移动到 最后一行 结尾 也就是 0 的后面 在按一下 回车 就跳到下一行了 , i.png /dev/sdb /www ext4 defaults 1 2 在把 数据盘 添加上去 设置为开机挂载 宝塔 挂盘.png 输入完 按 键盘 左上角 Esc 后 在输入 在输入 :wq 回车 ,保存退出 wq.png 使用 df -h 命令 查看下 挂载情况 数据盘已经挂上.png 最后 reboot 重启 reboot.png 等待 重启 完成 查看 是否 挂载成功 可以看到 已经开机 自动 将数据盘挂载成功 重启 开机挂载成功.png fdisk 常用命令: n:创建新分区 d:删除已有分区 t:修改分区类型 l:查看所有支持的类型 p:显示现有分区信息 w:保存并退出 q:不保存并退出 m:查看帮助信息 vi /etc/fstab 快速移动 连续 回车 可移动到 最后一行 在按 shift +$ 移动到 结尾最后一个字符 , 在 按 i 在按一次 方向键 右 在按 回车既可 跳转到新空白行 如果不习惯 请 直接 按 i 进入 编辑 yum -y install wget;wget http://kangle.cccyun.cn/start;sh star
2024年-5月-5日
1722 阅读
0 评论
未分类
2024-5-5
PHP如何批量更新MYSQL中的数据
PHP如何批量更新MYSQL中的数据 最近项目需要用到批量更新数据库里的数据,在网上找了一下这方面的例子,觉得这个还不错,分享给大家。 在这个业务里里面涉及到了更新两张数据表,那么大家是不是会想到非常简单,马上上代码 $sql = "update newhouse_clicks set clicks=6,type=1,update_time=time() where is=$value['id']"; 其中数据表名为newhouse_clicks,有四个字段,主键id,type(类型-整型)字段,clicks(点击量-整型)字段,update_time(整型)字段 这样做确实没有问题吗?比如说批量更新当前城市下的所有楼盘,比如说北京,打个比方1000条数据,那么在业务里面是不是就要这样写 $data = array(id=>1,id=>2,..........id=>1000);//省略数据 foreach($data as $key=>$value) { $sql = "update newhouse_clicks set clicks=6,type=1,update_time=time() where is=$value['id']"; } 这样在涉及到多张表*1000条数据,那么会不会有很大的延时呢? 结果是的,她这样写确实是导致了服务器的超时! 大家如果熟悉JAVA等语言应该知道,JAVA会内部提供了批量更新sql的功能,那么作为世界上做好的语言PHP能不能做到呢?答案是可以滴! 那么我们学习一下批量更新的sql语句。 UPDATE newhouse_clicks SET clicks = CASE id WHEN 1 THEN 1000 WHEN 2 THEN 2000 WHEN 3 THEN 3000 END WHERE id IN (1,2,3) 稍安勿躁,咱们详解一下这条sql语句的意思: 更新newhouse_clicks数据表中的clicks字段,当id=1是设置值为1000,当id=2时设置值为2000,当id=3时设置值为3000 那么更新多个字段能不能做到呢?当然可以,贴代码: UPDATE newhouse_clicks SET clicks = CASE id WHEN 1 THEN 1000 WHEN 2 THEN 2000 WHEN 3 THEN 3000 END, type = CASE id WHEN 1 THEN 1 WHEN 2 THEN 6 WHEN 3 THEN 8 END WHERE id IN (1,2,3) 这条sql语句的含义就是更新newhouse_clicks数据表中的clicks字段,当id=1是设置值为1000,当id=2时设置值为2000,当id=3时设置值为3000,更新type字段,当id=1时更新为type字段为1,当id=2时更新type字段为6,当id=3时,更新type字段为8。 那么,世界上最好的语言PHP不就可以拼出来sql了吗? //查询数据库返回的数据格式 $newhouse_clicks = array( 1 => 2, 2 => 3, 3 => 8, 4 => 9, ); $ids = implode(',', array_keys($newhouse_clicks )); $sql = "UPDATE newhouse_clicks SET clicks = CASE id "; foreach ( $newhouse_clicks as $key => $value) { $sql .= sprintf("WHEN %d THEN %d ", $key, $value); } $sql .= "END WHERE id IN ($ids)"; echo $sql; 大家查看一下是不是和咱们上面的sql语句是一样的呀! 那么,咱们真是的数据是不是要比这复杂呀?肯定的,看题,咱们通常在数据库里面取出来的数据格式是不是都是这样的。 //查询数据库返回的数据格式 $newhouse_clicks = array( 1 => array('clicks'=>1,'type'=>1,'update_time'=>time()), 2 => array('clicks'=>2,'type'=>2,'update_time'=>time()), 3 => array('clicks'=>3,'type'=>3,'update_time'=>time()), 4 => array('clicks'=>4,'type'=>4,'update_time'=>time()), ); ?> 那么,这种情况怎么办? <?php //查询数据库返回的数据格式 $newhouse_clicks = array( 1 => array('clicks'=>1,'type'=>1,'update_time'=>time()), 2 => array('clicks'=>2,'type'=>2,'update_time'=>time()), 3 => array('clicks'=>3,'type'=>3,'update_time'=>time()), 4 => array('clicks'=>4,'type'=>4,'update_time'=>time()), ); //获取所有的id $newhouse_clicks_keys = array_keys($newhouse_clicks); //拼接批量更新sql语句 $sql = "UPDATE newhouse_clicks SET "; //合成sql语句 foreach ($newhouse_clicks[1] as $key => $value) { $sql .= "{$key} = CASE id "; foreach ($newhouse_clicks as $newhouse_clicks_key=>$newhouse_clicks_value) { $sql .= sprintf("WHEN %d THEN %d ", $newhouse_clicks_key, $newhouse_clicks_value[$key]); } $sql .= "END, "; } //把最后一个,去掉 $sql = substr($sql, 0, strrpos($sql,',')); //合并所有id $ids = implode(',', $newhouse_clicks_keys); //拼接sql $sql .= " WHERE ID IN ({$ids})"; echo $sql; 其实,写了这么一大堆,是不是就是为了拼装成mysql语句呀。 大功告成!速度是不是像丝般顺滑! 老多程序员特别是初学者,很容易进入一个误区,把在sql中取数据套在for循环里面。这样写导致一个问题,就是严重的阻塞,现实生活中就有这样一个例子: 比如说,你在12层办公,这是快递员给你打电话让你去楼下取快递(总共12件),你去取快递有两种方式: 1.拿到第一件快递,跑回12层,放好后,接着去领取下一件快递,放好12层后再接着去取下一件快递。 2.一次性把所有的快递都拿到12层。 大家一定都会选第二个方案吧,没人会傻不拉几的去跑12次才能拿完快递的。 计算机就是上述原理,在for循环里面去资源取数据,就是类似第一种方案。批量取数据就是类似于第二种方案。(PS一下:不要以为在mysql中取数据有这种问题,redis也会 有这种问题,要不然怎么会有pipeline取批量数据呢
2024年-5月-5日
1657 阅读
0 评论
未分类
2024-5-5
获取input框输入值,添加到div里
<body> <input type="text" id="ipt"> <input type="button" id="btn" value="button"> <div id="div1"></div> <script> function myFun(){ var ipt = document.getElementById("ipt"); var btn = document.getElementById("btn"); var div1 = document.getElementById("div1"); btn.onclick = function(){ div1.innerHTML = ipt.value; } } myFun(); </script> </body>
2024年-5月-5日
1427 阅读
0 评论
未分类
3
4
5