joyo 发布的文章
屏蔽某宝登陆提示
rm -rf /www/server/panel/data/bind.pl
sed -i "s|if (bind_user == 'True') {|if (bind_user == 'REMOVED') {|g" /www/server/panel/BTPanel/static/js/index.js
Lnmp FTP相应命令
PureFTPd状态管理: /etc/init.d/pureftpd {start|stop|restart|kill|status}
《XX洗车平台》
【后台应用】
【商户中心】
cURL error 60: SSL certificate problem: unable to get local issuer certificate 解决思路
原因是curl没有https协议 该协议需要证书。可以用以下方法解决:
1.打开 https://curl.se/docs/caextract.html 下载【cacert.pem】
2.打开php所在的版本位置,找到php.ini 配置证书,比如我的路径在:E:phpstudy_proExtensionsphpphp7.3.4nts
3.php.ini 查找CTRL+F 【curl.cainfo】 将签名的;去掉注释,并将【cacert.pem】的绝对路径填上
curl.cainfo = E:\phpstudy_pro\Extensions\cacert.pem;
重启Apache、php服务即可
php 计算两日期之间相减
代码片段
$now=time()#代表当前
$expire_time = 1640864585;#2021-12-30 19:43:05
$day=floor(abs(($expire_time-$now)/86400));
tp5 解决重复下单(并发)的问题
在实际的开发中,因为缺乏对下单并发场景的认识,后端逻辑没有对重复请求进行过滤,就会出现重复订单(严重的业务漏洞)、产生经济损失和退单的售后成本。所以我们十分有必要进行对重复订单进行处理。
常见的方法有以下几种:
【锁-机制】
在数据库中建立锁表
CREATE TABLE `TradeLock` (
`id` int(11) unsigned NOT NULL AUTO_INCREMENT,
`type` int(11) NOT NULL COMMENT '锁类型',
`lockId` int(11) NOT NULL DEFAULT '0' COMMENT '业务ID',
`status` int(11) NOT NULL DEFAULT '0' COMMENT '锁状态',
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8 COMMENT='Trade锁机制';
每次request进来则往表里面插入数据:
成功--获得锁--继续操作
失败-->返回错误
在应对高并发场景,频繁请求数据不是明智的方法,这里我们就想到用redis做队列控制。
原理:入队---扣库存--执行(在原队列有逻辑没处理完成即返回库存不足!)
【计数器】
每次请求+1 利用cache缓存、设定失效时间30s(具有根据业务场景)。假如里面有请求则返回不要重复下单。以下是利用tp5里面的redis的cache驱动做计数器。
use thinkCache;
#缓存计数器 解决并发重复订单问题
$request =Cache('request_'.$user_id);
$request =$request+1;
Cache('request_'.$user_id,$request,30);
if($request>1){
$response['code'] =0;
$response['msg'] ='请勿重复操作';
$response['data']='';
return json($response);
}