322 lines
14 KiB
PHP
322 lines
14 KiB
PHP
<?php
|
||
|
||
namespace app\KitchenScale\controller\app;
|
||
|
||
use think\Controller;
|
||
use think\Db;
|
||
use think\Cache;
|
||
use think\Log;
|
||
use PHPMailer\PHPMailer\PHPMailer;
|
||
|
||
class Base extends Controller{
|
||
|
||
protected $base_use_db_name = [
|
||
'1'=>'app_data_log',
|
||
'2'=>'app_card_data',
|
||
'3'=>'app_user_data',
|
||
'4'=>'pc_vitalcapacity_standard',
|
||
'5'=>'admin_estimate',
|
||
'6'=>'app_account_number'
|
||
];
|
||
protected $token_time = 30;//30天的秒数
|
||
protected $file_size = 5*1024*1024;
|
||
protected $return_data_all = [
|
||
'10001'=>'关键参数缺失',
|
||
'10002'=>'操作失败',
|
||
'10003'=>'信息核实错误',
|
||
'10004'=>'未找到有效数据',
|
||
'10005'=>'参数格式错误',
|
||
'10006'=>'参数不能为空',
|
||
'10007'=>'参数错误',
|
||
'10008'=>'',
|
||
'10009'=>'',
|
||
'10010'=>'自定义信息',
|
||
'20001'=>'登录失效',
|
||
'99999'=>'网络异常,请稍后重试',
|
||
];
|
||
// 加 bcadd(,,20)
|
||
// 减 bcsub(,,20)
|
||
// 乘 bcmul(,,20)
|
||
// 除 bcdiv(,,20)
|
||
################################################################接口################################################################
|
||
################################################################接口################################################################
|
||
################################################################接口################################################################
|
||
// 接口记录
|
||
public function record_api_log($params, $error = null, $response = null){
|
||
$logContent = "接口请求参数:" . json_encode($params, JSON_UNESCAPED_UNICODE) . PHP_EOL;
|
||
if ($error) {
|
||
$logContent .= "错误信息:" . $error['all_content'] . PHP_EOL;
|
||
if(!cache($error['flie']."_".$error['line'])){
|
||
cache($error['flie']."_".$error['line'],"API错误",3600);
|
||
$this->send_email_api_error(["tsf3920322@126.com"],['title'=>'接口报错','from_user_name'=>'厨房秤(后台)','content'=>$logContent]);
|
||
}
|
||
}
|
||
if ($response) {
|
||
$logContent .= "返回信息:" . json_encode($response, JSON_UNESCAPED_UNICODE) . PHP_EOL;
|
||
}
|
||
// 使用ThinkPHP的日志记录方法
|
||
Log::record($logContent, 'api_log');
|
||
|
||
}
|
||
|
||
// 判断token是否过期
|
||
public function token_time_validate($token){
|
||
// 591b70e0d80b5fa6d77e6e1384453ab9
|
||
if(is_string($token)){
|
||
$length = strlen($token);
|
||
if ($length < 10 ) {
|
||
Log::record('用户尝试更新token时间,token:' . $token.',但是更新token失败,字符串长度小于10', 'token_log');
|
||
return false;
|
||
}
|
||
}else{
|
||
Log::record('用户尝试更新token时间,token:' . $token.',但是更新token失败,不是字符串', 'token_log');
|
||
return false;
|
||
}
|
||
|
||
$user_login = Db::table($this->base_use_db_name['6'])->where(['token'=>$token])->field('id,login_time')->find();
|
||
if(!$user_login){
|
||
Log::record('用户尝试更新token时间,token:' . $token.',但是更新token失败,未找到用户token', 'token_log');
|
||
return false;
|
||
}
|
||
|
||
// 创建 DateTime 对象来表示指定的日期和时间
|
||
$specifiedDateTime = new \DateTime($user_login['login_time']);
|
||
|
||
// 获取当前时间的 DateTime 对象
|
||
$currentDateTime = new \DateTime();
|
||
|
||
// 计算两个日期之间的差异(以秒为单位)
|
||
$interval = $currentDateTime->diff($specifiedDateTime);
|
||
|
||
// 将差异转换为天数(注意:这里的天数可能不是整数,因为差异可能包括小时、分钟等)
|
||
$daysDifference = $interval->days;
|
||
|
||
// 如果需要更精确的计算(包括小时、分钟等转换成的天数),可以使用以下方式:
|
||
// $totalSecondsDifference = $interval->format('%a') * 86400 + $interval->format('%h') * 3600 + $interval->format('%i') * 60 + $interval->format('%s');
|
||
// $daysDifference = floor($totalSecondsDifference / 86400); // 将总秒数转换为天数并取整
|
||
|
||
// 判断差异是否超过指定的天数
|
||
if ($daysDifference > $this->token_time) {
|
||
// echo "超过 {$specifiedDays} 天";
|
||
Log::record('用户尝试更新token时间,token:' . $token.',但是更新token失败,原因没有找到该token,或该token已经超过30天', 'token_log');
|
||
return false;
|
||
} else {
|
||
// echo "未超过 {$specifiedDays} 天";
|
||
$user_login = Db::table($this->base_use_db_name['6'])->where(['token'=>$token])->update(['login_time'=>date('Y-m-d H:i:s')]);
|
||
if($user_login){
|
||
Log::record('用户尝试更新token时间,token:' . $token.',记录成功,最新的时间为'.date('Y-m-d H:i:s'), 'token_log');
|
||
return true;
|
||
}else{
|
||
Log::record('用户尝试更新token时间,token:' . $token.',但是更新token失败,数据库更新时间未成功', 'token_log');
|
||
return true;
|
||
}
|
||
|
||
}
|
||
}
|
||
/* 接口说明(发邮件)
|
||
* $address(收件人的邮箱地址) 数组 格式: ['460834639@qq.com','460834639@qq.com'.......]
|
||
* $content(邮件的主题数据信息) 数组 格式:['title'=>'123','from_user_name'=>'123','content'=>'123']
|
||
* $annex(附件路径信息) 字符串
|
||
*/
|
||
public function send_email_api_error($address,$content,$annex=''){
|
||
// $ad = '460834639@qq.com';
|
||
$ad1 = '295155911@qq.com';
|
||
$mail = new PHPMailer(); //实例化
|
||
$mail->IsSMTP(); // 启用SMTP
|
||
$mail->Host = "smtp.126.com"; //SMTP服务器 163邮箱例子
|
||
$mail->Port = 465; //邮件发送端口
|
||
$mail->SMTPAuth = true; //启用SMTP认证
|
||
$mail->SMTPSecure = 'ssl';
|
||
$mail->CharSet = "UTF-8"; //字符集
|
||
$mail->Encoding = "base64"; //编码方式
|
||
$mail->Username = "tsf3920322@126.com"; //你的邮箱
|
||
$mail->Password = "HLWXNRPUCTHJFIIX"; //你的密码(邮箱后台的授权密码)
|
||
$mail->From = "tsf3920322@126.com"; //发件人地址(也就是你的邮箱)
|
||
|
||
// $mail->Subject = "微盟测试邮件"; //邮件标题
|
||
$mail->Subject = $content['title']; //邮件标题
|
||
|
||
// $mail->FromName = "微盟体测中心"; //发件人姓名
|
||
$mail->FromName = $content['from_user_name']; //发件人姓名
|
||
|
||
|
||
for ($i=0; $i < count($address); $i++) {
|
||
$mail->AddAddress($address[$i], ""); //添加收件人(地址,昵称)
|
||
}
|
||
|
||
if($annex != ''){
|
||
// $url = ROOT_PATH. 'public' . DS . 'tsf' . DS .'demoooo.jpg';
|
||
$mail->AddAttachment($annex,''); // 添加附件,并指定名称
|
||
}
|
||
|
||
$mail->IsHTML(true); //支持html格式内容
|
||
|
||
$neirong = $content['content'];
|
||
|
||
$mail->Body = $neirong; //邮件主体内容
|
||
//发送
|
||
if (!$mail->Send()) {
|
||
|
||
return ['code' => 10003,'msg'=>$mail->ErrorInfo];
|
||
// return $mail->ErrorInfo;
|
||
} else {
|
||
return ['code' => 0];
|
||
// return 'success';
|
||
}
|
||
}
|
||
|
||
|
||
// 验证
|
||
public function verify_data_is_ok($data = 2,$type){
|
||
if($type == 'str'){
|
||
if (is_string($data)) {
|
||
return true;
|
||
} else {
|
||
$this->record_api_log($data, null, ['code'=>10005,'msg'=>'校验参数不为字符串',[]]);
|
||
return false;
|
||
}
|
||
}else if($type == 'num'){
|
||
if (is_numeric($data)) {
|
||
return true;
|
||
} else {
|
||
$this->record_api_log($data, null, ['code'=>10005,'msg'=>'校验参数不为数字',[]]);
|
||
return false;
|
||
}
|
||
}else if($type == 'intnum'){
|
||
$pattern = '/^\d+$/';
|
||
// dump($data);
|
||
if (preg_match($pattern, $data)) {
|
||
return true; // 匹配成功,返回 true
|
||
} else {
|
||
$this->record_api_log($data, null, ['code'=>10005,'msg'=>'校验参数不为整数数字',[]]);
|
||
return false; // 匹配失败,返回 false
|
||
}
|
||
}else if($type == 'datetime'){
|
||
$formats = ['Y-m-d','Y-m-d H:i:s'];
|
||
foreach ($formats as $format) {
|
||
$dateTime = \DateTime::createFromFormat($format, $data);
|
||
// 检查时间字符串是否成功解析,并且解析后的日期时间与原始字符串表示的时间一致
|
||
if ($dateTime && $dateTime->format($format) === $data) {
|
||
return true;
|
||
}
|
||
}
|
||
// 如果所有格式都解析失败,则返回 false
|
||
$this->record_api_log($data, null, ['code'=>10005,'msg'=>'校验参数不为日期格式',[]]);
|
||
return false;
|
||
}else if($type == 'other'){
|
||
|
||
}
|
||
|
||
}
|
||
####################################################图片选择上传start##############################################################
|
||
public function pic_chose_list($page = 1) {
|
||
$data = input();
|
||
$page_num = 20;
|
||
if(!array_key_exists('token',$data)){
|
||
return $this->msg(10001,'token is miss');
|
||
}
|
||
if(array_key_exists('page',$data)){
|
||
$page = $data['page'];
|
||
}
|
||
$parameter_data = [
|
||
'user_token'=>$data['token'],
|
||
'is_del'=>0
|
||
];
|
||
|
||
$cfc = Db::connect('cfc_db');
|
||
|
||
$num = $cfc->table('app_user_upload_img')->where($parameter_data)->count();
|
||
$result = $cfc->table('app_user_upload_img')->where($parameter_data)->order('id desc')->page($page,$page_num)->field('id,pic_name,pic_url')->select();
|
||
$return_result['page_total'] = $page_total = ceil($num/$page_num);
|
||
$return_result['page_now'] = $page;
|
||
$return_result['result'] = $result;
|
||
return $this->msg($return_result);
|
||
}
|
||
public function pic_upload_action(){
|
||
$insert_data = [];
|
||
$temporary_data = [];
|
||
$miss_data = 0;
|
||
$cfc = Db::connect('cfc_db');
|
||
$files = request()->file('images');
|
||
$token = request()->param('token');
|
||
if(!$token){
|
||
return $this->msg(10001,'token is miss');
|
||
}
|
||
if(count($files)>5){
|
||
return $this->msg(10001,'单次最多上传5张图片');
|
||
}
|
||
if($files){
|
||
foreach($files as $file){
|
||
$name = $file->getInfo()['name'];
|
||
// 使用 pathinfo() 函数获取文件名的扩展名
|
||
$pathinfo = pathinfo($name);
|
||
$extension = strtolower($pathinfo['extension']); // 转换为小写以进行不区分大小写的比较
|
||
$file_name = $pathinfo['filename'];
|
||
// 判断扩展名是否不是 .png 或 .gif
|
||
if ($extension !== 'png' && $extension !== 'gif') {
|
||
// 修改文件名,将扩展名改为 .jpg
|
||
$new_filename = time().$this->generateRandomString(). '.jpg';
|
||
} else {
|
||
$new_filename = time().$this->generateRandomString(). '.' . $extension;
|
||
}
|
||
$info = $file->validate(['size'=>$this->file_size,'ext'=>'jpg,png,gif'])->move(ROOT_PATH . 'public' . DS . 'kitchenscale_all' . DS . 'user_upload',$new_filename);
|
||
if($info){
|
||
$temporary_data = [
|
||
'user_token'=>$token,
|
||
'pic_name'=>$new_filename,
|
||
'pic_url'=>"https://tc.pcxbc.com/kitchenscale_all/user_upload/".$new_filename,
|
||
'create_time'=>date('Y-m-d H:i:s'),
|
||
];
|
||
$pic_id = $cfc->table('app_user_upload_img')->insertGetId($temporary_data);
|
||
if($pic_id){
|
||
$temporary_data['id'] = $pic_id;
|
||
unset($temporary_data['create_time']);
|
||
unset($temporary_data['user_token']);
|
||
array_push($insert_data,$temporary_data);
|
||
}else{
|
||
$miss_data = $miss_data+1;
|
||
}
|
||
}else{
|
||
$miss_data = $miss_data+1;
|
||
}
|
||
}
|
||
|
||
return $this->msg(['error_num'=>$miss_data,'insert_data'=>$insert_data]);
|
||
|
||
}else{
|
||
return $this->msg(10001,'未选择图片');
|
||
}
|
||
}
|
||
|
||
|
||
public function msg($data,$str='',$result = []){
|
||
if(is_array($data)){
|
||
if($str != ''){
|
||
return json(['code'=>0,'msg'=>$str,'data'=>$data]);
|
||
}else{
|
||
return json(['code'=>0,'msg'=>'操作成功','data'=>$data]);
|
||
}
|
||
}else{
|
||
if($str != ''){
|
||
return json(['code'=>$data,'msg'=>$str,'data'=>$result]);
|
||
}
|
||
return json(['code'=>$data,'msg'=>$this->return_data_all[$data],'data'=>$result]);
|
||
}
|
||
}
|
||
|
||
public function generateRandomString($length = 10) {
|
||
$characters = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789';
|
||
$charactersLength = strlen($characters);
|
||
$randomString = '';
|
||
for ($i = 0; $i < $length; $i++) {
|
||
$randomString .= $characters[rand(0, $charactersLength - 1)];
|
||
}
|
||
return $randomString;
|
||
}
|
||
|
||
public function ceshi(){
|
||
echo 'hello';
|
||
}
|
||
|
||
|
||
} |