773 lines
		
	
	
		
			19 KiB
		
	
	
	
		
			PHP
		
	
	
			
		
		
	
	
			773 lines
		
	
	
		
			19 KiB
		
	
	
	
		
			PHP
		
	
	
| <?php
 | ||
| 
 | ||
| use app\common\server\UrlServer;
 | ||
| use think\facade\Db;
 | ||
| use app\common\model\user\User;
 | ||
| use app\common\model\goods\Goods;
 | ||
| 
 | ||
| /**
 | ||
|  * Notes: 生成随机长度字符串
 | ||
|  * @param $length
 | ||
|  * @author FZR(2021/1/28 10:36)
 | ||
|  * @return string|null
 | ||
|  */
 | ||
| function getRandChar($length)
 | ||
| {
 | ||
|     $str = null;
 | ||
|     $strPol = "ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789abcdefghijklmnopqrstuvwxyz";
 | ||
|     $max = strlen($strPol) - 1;
 | ||
| 
 | ||
|     for ($i = 0;
 | ||
|          $i < $length;
 | ||
|          $i++) {
 | ||
|         $str .= $strPol[rand(0, $max)];
 | ||
|     }
 | ||
| 
 | ||
|     return $str;
 | ||
| }
 | ||
| 
 | ||
| /**
 | ||
|  * Notes: 生成密码
 | ||
|  * @param $plaintext
 | ||
|  * @param $salt
 | ||
|  * @author FZR(2021/1/28 15:30)
 | ||
|  * @return string
 | ||
|  */
 | ||
| function generatePassword($plaintext, $salt)
 | ||
| {
 | ||
|     $salt = md5('y' . $salt . 'x');
 | ||
|     $salt .= '2021';
 | ||
|     return md5($plaintext . $salt);
 | ||
| }
 | ||
| 
 | ||
| 
 | ||
| /**
 | ||
|  * Notes: 大写字母
 | ||
|  * @author 段誉(2021/4/15 15:55)
 | ||
|  * @return array
 | ||
|  */
 | ||
| function getCapital()
 | ||
| {
 | ||
|     return  range('A','Z');
 | ||
| }
 | ||
| 
 | ||
| /**
 | ||
|  * 线性结构转换成树形结构
 | ||
|  * @param array $data 线性结构数组
 | ||
|  * @param string $sub_key_name 自动生成子数组名
 | ||
|  * @param string $id_name 数组id名
 | ||
|  * @param string $parent_id_name 数组祖先id名
 | ||
|  * @param int $parent_id 此值请勿给参数
 | ||
|  * @return array
 | ||
|  */
 | ||
| function linear_to_tree($data, $sub_key_name = 'sub', $id_name = 'id', $parent_id_name = 'pid', $parent_id = 0)
 | ||
| {
 | ||
|   $tree = [];
 | ||
|   foreach ($data as $row) {
 | ||
|     if ($row[$parent_id_name] == $parent_id) {
 | ||
|       $temp = $row;
 | ||
|       $temp[$sub_key_name] = linear_to_tree($data, $sub_key_name, $id_name, $parent_id_name, $row[$id_name]);
 | ||
|       $tree[] = $temp;
 | ||
|     }
 | ||
|   }
 | ||
|   return $tree;
 | ||
| }
 | ||
| 
 | ||
| /**
 | ||
|  * User: 意象信息科技 lr
 | ||
|  * Desc: 下载文件
 | ||
|  * @param $url 文件url
 | ||
|  * @param $save_dir 保存目录
 | ||
|  * @param $file_name 文件名
 | ||
|  * @return string
 | ||
|  */
 | ||
| function download_file($url, $save_dir, $file_name)
 | ||
| {
 | ||
|     if (!file_exists($save_dir)) {
 | ||
|         mkdir($save_dir, 0775, true);
 | ||
|     }
 | ||
|     $file_src = $save_dir . $file_name;
 | ||
|     file_exists($file_src) && unlink($file_src);
 | ||
|     $ch = curl_init();
 | ||
|     curl_setopt($ch, CURLOPT_URL, $url);
 | ||
|     curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
 | ||
|     curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 30);
 | ||
|     $file = curl_exec($ch);
 | ||
|     curl_close($ch);
 | ||
|     $resource = fopen($file_src, 'a');
 | ||
|     fwrite($resource, $file);
 | ||
|     fclose($resource);
 | ||
|     if (filesize($file_src) == 0) {
 | ||
|         unlink($file_src);
 | ||
|         return '';
 | ||
|     }
 | ||
|     return $file_src;
 | ||
| }
 | ||
| 
 | ||
| /**
 | ||
|  * 生成会员码
 | ||
|  * @return 会员码
 | ||
|  */
 | ||
| function create_user_sn($prefix = '', $length = 8)
 | ||
| {
 | ||
|     $rand_str = '';
 | ||
|     for ($i = 0; $i < $length; $i++) {
 | ||
|         $rand_str .= mt_rand(0, 9);
 | ||
|     }
 | ||
|     $sn = $prefix . $rand_str;
 | ||
|     $user = User::where(['sn' => $sn])->findOrEmpty();
 | ||
|     if (!$user->isEmpty()) {
 | ||
|         return create_user_sn($prefix, $length);
 | ||
|     }
 | ||
|     return $sn;
 | ||
| }
 | ||
| 
 | ||
| //生成用户邀请码
 | ||
| function generate_invite_code()
 | ||
| {
 | ||
|     $letter_all = range('A', 'Z');
 | ||
|     shuffle($letter_all);
 | ||
|     //排除I、O字母
 | ||
|     $letter_array = array_diff($letter_all, ['I', 'O', 'D']);
 | ||
|     //排除1、0
 | ||
|     $num_array = range('2', '9');
 | ||
|     shuffle($num_array);
 | ||
| 
 | ||
|     $pattern = array_merge($num_array, $letter_array, $num_array);
 | ||
|     shuffle($pattern);
 | ||
|     $pattern = array_values($pattern);
 | ||
| 
 | ||
|     $code = '';
 | ||
|     for ($i = 0; $i < 6; $i++) {
 | ||
|         $code .= $pattern[mt_rand(0, count($pattern) - 1)];
 | ||
|     }
 | ||
| 
 | ||
|     $code = strtoupper($code);
 | ||
|     $check = User::where('distribution_code', $code)->findOrEmpty();
 | ||
|     if (!$check->isEmpty()) {
 | ||
|         return generate_invite_code();
 | ||
|     }
 | ||
|     return $code;
 | ||
| }
 | ||
| 
 | ||
| /**
 | ||
|  * User: 意象信息科技 lr
 | ||
|  * Desc: 数组成功拼装
 | ||
|  * @param string $msg
 | ||
|  * @param array $data
 | ||
|  * @param int $code
 | ||
|  * @param int $show
 | ||
|  * @return array
 | ||
|  */
 | ||
| function data_success($msg = '', $data = [], $code = 1, $show = 1)
 | ||
| {
 | ||
|     $result = [
 | ||
|         'code' => $code,
 | ||
|         'msg' => $msg,
 | ||
|         'data' => $data,
 | ||
|         'show' => $show,
 | ||
|     ];
 | ||
|     return $result;
 | ||
| }
 | ||
| 
 | ||
| /**
 | ||
|  * User: 意象信息科技 lr
 | ||
|  * Desc: 组装失败数据
 | ||
|  * @param string $msg
 | ||
|  * @param array $data
 | ||
|  * @param int $code
 | ||
|  * @param int $show
 | ||
|  * @return array
 | ||
|  */
 | ||
| function data_error($msg = '', $data = [], $code = 0, $show = 1)
 | ||
| {
 | ||
|     $result = [
 | ||
|         'code' => $code,
 | ||
|         'msg' => $msg,
 | ||
|         'data' => $data,
 | ||
|         'show' => $show,
 | ||
|     ];
 | ||
|     return $result;
 | ||
| }
 | ||
| 
 | ||
| /**
 | ||
|  * User: 意象信息科技 cjh
 | ||
|  * Desc: 返回是否有下一页
 | ||
|  * @param $count (总记录数)
 | ||
|  * @param $page (当前页码)
 | ||
|  * @param $size (每页记录数)
 | ||
|  * @return int
 | ||
|  */
 | ||
| function is_more($count, $page, $size)
 | ||
| {
 | ||
|     $more = 0;
 | ||
| 
 | ||
|     $last_page = ceil($count / $size);      //总页数、也是最后一页
 | ||
| 
 | ||
|     if ($last_page && $last_page > $page) {
 | ||
|         $more = 1;
 | ||
|     }
 | ||
|     return $more;
 | ||
| }
 | ||
| 
 | ||
| /**
 | ||
|  * User: 意象信息科技 lr
 | ||
|  * Desc:生成密码密文
 | ||
|  * @param $plaintext string 明文
 | ||
|  * @param $salt string 密码盐
 | ||
|  * @return string
 | ||
|  */
 | ||
| function create_password($plaintext, $salt)
 | ||
| {
 | ||
|     $salt = md5('y' . $salt . 'x');
 | ||
|     $salt .= '2021';
 | ||
|     return md5($plaintext . $salt);
 | ||
| }
 | ||
| 
 | ||
| /**
 | ||
|  * User: 意象信息科技 mjf
 | ||
|  * Desc: 用时间生成订单编号
 | ||
|  * @param $table
 | ||
|  * @param $field
 | ||
|  * @param string $prefix
 | ||
|  * @param int $rand_suffix_length
 | ||
|  * @param array $pool
 | ||
|  * @return string
 | ||
|  * @throws \think\db\exception\DataNotFoundException
 | ||
|  * @throws \think\db\exception\DbException
 | ||
|  * @throws \think\db\exception\ModelNotFoundException
 | ||
|  */
 | ||
| function createSn($table, $field, $prefix = '', $rand_suffix_length = 4, $pool = [])
 | ||
| {
 | ||
|     $suffix = '';
 | ||
|     for ($i = 0; $i < $rand_suffix_length; $i++) {
 | ||
|         if (empty($pool)) {
 | ||
|             $suffix .= rand(0, 9);
 | ||
|         } else {
 | ||
|             $suffix .= $pool[array_rand($pool)];
 | ||
|         }
 | ||
|     }
 | ||
|     $sn = $prefix . date('YmdHis') . $suffix;
 | ||
|     if (Db::name($table)->where($field, $sn)->find()) {
 | ||
|         return createSn($table, $field, $prefix, $rand_suffix_length, $pool);
 | ||
|     }
 | ||
|     return $sn;
 | ||
| }
 | ||
| 
 | ||
| /**
 | ||
|  * User: 意象信息科技 lr
 | ||
|  * Desc: 表单多维数据转换
 | ||
|  * 例:
 | ||
|  * 转换前:{"x":0,"a":[1,2,3],"b":[11,22,33],"c":[111,222,3333,444],"d":[1111,2222,3333]}
 | ||
|  * 转换为:[{"a":1,"b":11,"c":111,"d":1111},{"a":2,"b":22,"c":222,"d":2222},{"a":3,"b":33,"c":3333,"d":3333}]
 | ||
|  * @param $arr array 表单二维数组
 | ||
|  * @param $fill boolean fill为false,返回数据长度取最短,反之取最长,空值自动补充
 | ||
|  * @return array
 | ||
|  */
 | ||
| function form_to_linear($arr, $fill = false)
 | ||
| {
 | ||
|     $keys = [];
 | ||
|     $count = $fill ? 0 : PHP_INT_MAX;
 | ||
|     foreach ($arr as $k => $v) {
 | ||
|         if (is_array($v)) {
 | ||
|             $keys[] = $k;
 | ||
|             $count = $fill ? max($count, count($v)) : min($count, count($v));
 | ||
|         }
 | ||
|     }
 | ||
|     if (empty($keys)) {
 | ||
|         return [];
 | ||
|     }
 | ||
|     $data = [];
 | ||
|     for ($i = 0; $i < $count; $i++) {
 | ||
|         foreach ($keys as $v) {
 | ||
|             $data[$i][$v] = isset($arr[$v][$i]) ? $arr[$v][$i] : null;
 | ||
|         }
 | ||
|     }
 | ||
|     return $data;
 | ||
| }
 | ||
| 
 | ||
| /**
 | ||
|  * note 生成验证码
 | ||
|  * @param int $length 验证码长度
 | ||
|  * @return string
 | ||
|  */
 | ||
| function create_sms_code($length = 4)
 | ||
| {
 | ||
|     $code = '';
 | ||
|     for ($i = 0; $i < $length; $i++) {
 | ||
|         $code .= rand(0, 9);
 | ||
|     }
 | ||
|     return $code;
 | ||
| }
 | ||
| 
 | ||
| /**
 | ||
|  * 生成商品编码
 | ||
|  * 8位
 | ||
|  */
 | ||
| function create_goods_code($shop_id)
 | ||
| {
 | ||
|     $code =  mt_rand(10000000, 99999999);
 | ||
|     $goods = Goods::where([
 | ||
|         'code' => $code,
 | ||
|         'shop_id' => $shop_id,
 | ||
|         'del' => 0
 | ||
|     ])->findOrEmpty();
 | ||
|     if($goods->isEmpty()) {
 | ||
|         return $code;
 | ||
|     }
 | ||
|     create_goods_code();
 | ||
| }
 | ||
| 
 | ||
| /**
 | ||
|  * 图片去除域名
 | ||
|  */
 | ||
| function clearDomain($x)
 | ||
| {
 | ||
|     if(is_array($x)) {
 | ||
|         $newX = [];
 | ||
|         foreach($x as $v) {
 | ||
|             $newX[] = trim(UrlServer::setFileUrl($v));
 | ||
|         }
 | ||
|         return $newX;
 | ||
|     }
 | ||
|     return  trim(UrlServer::setFileUrl($x));
 | ||
| }
 | ||
| 
 | ||
| /*
 | ||
|  * 生成优惠券码 排除1、0、I、O相似的数字和字母
 | ||
|  */
 | ||
| function create_coupon_code()
 | ||
| {
 | ||
|     $letter_all = range('A', 'Z');
 | ||
|     shuffle($letter_all);
 | ||
|     //排除I、O字母
 | ||
|     $letter_array = array_diff($letter_all, ['I', 'O']);
 | ||
|     //随机获取四位字母
 | ||
|     $letter = array_rand(array_flip($letter_array), 4);
 | ||
|     //排除1、0
 | ||
|     $num_array = range('2', '9');
 | ||
|     shuffle($num_array);
 | ||
|     //获取随机六位数字
 | ||
|     $num = array_rand(array_flip($num_array), 6);
 | ||
|     $code = implode('', array_merge($letter, $num));
 | ||
|     do {
 | ||
|         $exist_code =\app\common\model\coupon\CouponList::where(['del' => 0, 'coupon_code' => $code])->find();
 | ||
|     } while ($exist_code);
 | ||
|     return $code;
 | ||
| }
 | ||
| 
 | ||
| /**
 | ||
|  * 浮点数去除无效的0
 | ||
|  */
 | ||
| function clearZero($float)
 | ||
| {
 | ||
|     if($float == intval($float)) {
 | ||
|         return intval($float);
 | ||
|     }else if($float == sprintf('%.1f', $float)) {
 | ||
|         return sprintf('%.1f', $float);
 | ||
|     }
 | ||
|     return $float;
 | ||
| }
 | ||
| /**
 | ||
|  * 是否在cli模式
 | ||
|  */
 | ||
| if (!function_exists('is_cli')) {
 | ||
|     function is_cli()
 | ||
|     {
 | ||
|         return preg_match("/cli/i", php_sapi_name()) ? true : false;
 | ||
|     }
 | ||
| }
 | ||
| 
 | ||
| function real_path()
 | ||
| {
 | ||
|     if (substr(strtolower(PHP_OS), 0, 3) == 'win') {
 | ||
|         $ini = ini_get_all();
 | ||
|         $path = $ini['extension_dir']['local_value'];
 | ||
|         $php_path = str_replace('\\', '/', $path);
 | ||
|         $php_path = str_replace(array('/ext/', '/ext'), array('/', '/'), $php_path);
 | ||
|         $real_path = $php_path . 'php.exe';
 | ||
|     } else {
 | ||
|         $real_path = PHP_BINDIR . '/php';
 | ||
|     }
 | ||
|     if (strpos($real_path, 'ephp.exe') !== FALSE) {
 | ||
|         $real_path = str_replace('ephp.exe', 'php.exe', $real_path);
 | ||
|     }
 | ||
|     return $real_path;
 | ||
| }
 | ||
| 
 | ||
| /**
 | ||
|  * 是否为移动端
 | ||
|  */
 | ||
| function is_mobile()
 | ||
| {
 | ||
|     if (isset($_SERVER['HTTP_X_WAP_PROFILE'])) {
 | ||
|         return true;
 | ||
|     }
 | ||
|     if (isset($_SERVER['HTTP_VIA'])) {
 | ||
|         return stristr($_SERVER['HTTP_VIA'], "wap") ? true : false;
 | ||
|     }
 | ||
|     if (isset($_SERVER['HTTP_USER_AGENT'])) {
 | ||
|         $clientkeywords = array('nokia', 'sony', 'ericsson', 'mot', 'samsung', 'htc', 'sgh', 'lg', 'sharp', 'sie-', 'philips', 'panasonic', 'alcatel', 'lenovo', 'iphone', 'ipod', 'blackberry', 'meizu', 'android', 'netfront', 'symbian', 'ucweb', 'windowsce', 'palm', 'operamini', 'operamobi', 'openwave', 'nexusone', 'cldc', 'midp', 'wap', 'mobile');
 | ||
|         if (preg_match("/(" . implode('|', $clientkeywords) . ")/i", strtolower($_SERVER['HTTP_USER_AGENT']))) {
 | ||
|             return true;
 | ||
|         }
 | ||
|     }
 | ||
|     if (isset($_SERVER['HTTP_ACCEPT'])) {
 | ||
|         if ((strpos($_SERVER['HTTP_ACCEPT'], 'vnd.wap.wml') !== false) && (strpos($_SERVER['HTTP_ACCEPT'], 'textml') === false || (strpos($_SERVER['HTTP_ACCEPT'], 'vnd.wap.wml') < strpos($_SERVER['HTTP_ACCEPT'], 'textml')))) {
 | ||
|             return true;
 | ||
|         }
 | ||
|     }
 | ||
|     return false;
 | ||
| }
 | ||
| 
 | ||
| /**
 | ||
|  * Notes:判断文件是否存在(远程和本地文件)
 | ||
|  * @param $file string 完整的文件链接
 | ||
|  * @return bool
 | ||
|  */
 | ||
| function check_file_exists($file)
 | ||
| {
 | ||
|     //远程文件
 | ||
|     if ('http' == strtolower(substr($file, 0, 4))) {
 | ||
| 
 | ||
|         $header = get_headers($file, true);
 | ||
| 
 | ||
|         return isset($header[0]) && (strpos($header[0], '200') || strpos($header[0], '304'));
 | ||
| 
 | ||
|     } else {
 | ||
| 
 | ||
|         return file_exists($file);
 | ||
|     }
 | ||
| }
 | ||
| 
 | ||
| /**
 | ||
|  * 将图片切成圆角
 | ||
|  */
 | ||
| function rounded_corner($src_img)
 | ||
| {
 | ||
|     $w = imagesx($src_img);//微信头像宽度 正方形的
 | ||
|     $h = imagesy($src_img);//微信头像宽度 正方形的
 | ||
|     $w = min($w, $h);
 | ||
|     $h = $w;
 | ||
|     $img = imagecreatetruecolor($w, $h);
 | ||
|     //这一句一定要有
 | ||
|     imagesavealpha($img, true);
 | ||
|     //拾取一个完全透明的颜色,最后一个参数127为全透明
 | ||
|     $bg = imagecolorallocatealpha($img, 255, 255, 255, 127);
 | ||
|     imagefill($img, 0, 0, $bg);
 | ||
|     $r = $w / 2; //圆半径
 | ||
| //    $y_x = $r; //圆心X坐标
 | ||
| //    $y_y = $r; //圆心Y坐标
 | ||
|     for ($x = 0; $x < $w; $x++) {
 | ||
|         for ($y = 0; $y < $h; $y++) {
 | ||
|             $rgbColor = imagecolorat($src_img, $x, $y);
 | ||
|             if (((($x - $r) * ($x - $r) + ($y - $r) * ($y - $r)) < ($r * $r))) {
 | ||
|                 imagesetpixel($img, $x, $y, $rgbColor);
 | ||
|             }
 | ||
|         }
 | ||
|     }
 | ||
|     unset($src_img);
 | ||
|     return $img;
 | ||
| }
 | ||
| 
 | ||
| /**
 | ||
|  * Notes:去掉名称中的表情
 | ||
|  * @param $str
 | ||
|  * @return string|string[]|null
 | ||
|  * @author: cjhao 2021/3/29 15:56
 | ||
|  */
 | ||
| function filterEmoji($str)
 | ||
| {
 | ||
|     $str = preg_replace_callback(
 | ||
|         '/./u',
 | ||
|         function (array $match) {
 | ||
|             return strlen($match[0]) >= 4 ? '' : $match[0];
 | ||
|         },
 | ||
|         $str);
 | ||
|     return $str;
 | ||
| }
 | ||
| 
 | ||
| /***
 | ||
|  * 生成海报自动适应标题
 | ||
|  * @param $size
 | ||
|  * @param int $angle
 | ||
|  * @param $fontfile
 | ||
|  * @param $string
 | ||
|  * @param $width
 | ||
|  * @param $height
 | ||
|  * @param $bg_height
 | ||
|  * @return string
 | ||
|  */
 | ||
| function auto_adapt($size, $angle = 0, $fontfile, $string, $width, $height, $bg_height)
 | ||
| {
 | ||
|     $content = "";
 | ||
|     // 将字符串拆分成一个个单字 保存到数组 letter 中
 | ||
|     for ($i = 0; $i < mb_strlen($string); $i++) {
 | ||
|         $letters[] = mb_substr($string, $i, 1);
 | ||
|     }
 | ||
| 
 | ||
|     foreach ($letters as $letter) {
 | ||
|         $str = $content . " " . $letter;
 | ||
|         $box = imagettfbbox($size, $angle, $fontfile, $str);
 | ||
| 
 | ||
|         $total_height = $box[1] + $height;
 | ||
|         if ($bg_height[1] - $total_height < $size) {
 | ||
|             break;
 | ||
|         }
 | ||
|         //右下角X位置,判断拼接后的字符串是否超过预设的宽度
 | ||
|         if (($box[2] > $width) && ($content !== "")) {
 | ||
|             if ($bg_height[1] - $total_height < $size * 2) {
 | ||
|                 break;
 | ||
|             }
 | ||
|             $content .= "\n";
 | ||
|         }
 | ||
|         $content .= $letter;
 | ||
|     }
 | ||
|     return $content;
 | ||
| }
 | ||
| 
 | ||
| /**
 | ||
|  * Notes:生成一个范围内的随机浮点数
 | ||
|  * @param int $min 最小值
 | ||
|  * @param int $max 最大值
 | ||
|  * @return float|int 返回随机数
 | ||
|  */
 | ||
| function random_float($min = 0, $max = 1)
 | ||
| {
 | ||
|     return $min + mt_rand() / mt_getrandmax() * ($max - $min);
 | ||
| }
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| /**
 | ||
|  * Notes: 获取文件扩展名
 | ||
|  * @param $file
 | ||
|  * @author 段誉(2021/7/7 18:03)
 | ||
|  * @return mixed
 | ||
|  */
 | ||
| if (!function_exists('get_extension')) {
 | ||
|     function get_extension($file)
 | ||
|     {
 | ||
|         return pathinfo($file, PATHINFO_EXTENSION);
 | ||
|     }
 | ||
| }
 | ||
| 
 | ||
| 
 | ||
| /**
 | ||
|  * Notes: 遍历指定目录下的文件(目标目录,排除文件)
 | ||
|  * @param $dir 目标文件
 | ||
|  * @param string $exclude_file 要排除的文件
 | ||
|  * @param string $target_suffix 指定后缀
 | ||
|  * @author 段誉(2021/7/7 18:04)
 | ||
|  * @return array|bool
 | ||
|  */
 | ||
| 
 | ||
| if (!function_exists('get_scandir')) {
 | ||
|     function get_scandir($dir, $exclude_file = '', $target_suffix = '')
 | ||
|     {
 | ||
|         if (!file_exists($dir)) {
 | ||
|             return [];
 | ||
|         }
 | ||
| 
 | ||
|         if (empty(trim($dir))) {
 | ||
|             return false;
 | ||
|         }
 | ||
| 
 | ||
|         $files = scandir($dir);
 | ||
|         $res = [];
 | ||
|         foreach ($files as $item) {
 | ||
|             if ($item == "." || $item == ".." || $item == $exclude_file) {
 | ||
|                 continue;
 | ||
|             }
 | ||
|             if (!empty($target_suffix)) {
 | ||
|                 if (get_extension($item) == $target_suffix) {
 | ||
|                     $res[] = $item;
 | ||
|                 }
 | ||
|             } else {
 | ||
|                 $res[] = $item;
 | ||
|             }
 | ||
|         }
 | ||
| 
 | ||
|         if (empty($item)) {
 | ||
|             return false;
 | ||
|         }
 | ||
|         return $res;
 | ||
|     }
 | ||
| }
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| /**
 | ||
|  * Notes: 解压压缩包
 | ||
|  * @param $file 压缩包路径
 | ||
|  * @param $save_dir 保存路径
 | ||
|  * @author 段誉(2021/7/7 18:11)
 | ||
|  * @return bool
 | ||
|  */
 | ||
| if (!function_exists('unzip')) {
 | ||
|     function unzip($file, $save_dir)
 | ||
|     {
 | ||
|         if (!file_exists($file)) {
 | ||
|             return false;
 | ||
|         }
 | ||
|         $zip = new \ZipArchive();
 | ||
|         if ($zip->open($file) !== TRUE) {//中文文件名要使用ANSI编码的文件格式
 | ||
|             return false;
 | ||
|         }
 | ||
|         $zip->extractTo($save_dir);
 | ||
|         $zip->close();
 | ||
|         return true;
 | ||
|     }
 | ||
| }
 | ||
| 
 | ||
| 
 | ||
| 
 | ||
| /**
 | ||
|  * Notes: 删除目标目录
 | ||
|  * @param $path
 | ||
|  * @param $delDir
 | ||
|  * @author 段誉(2021/7/7 18:19)
 | ||
|  * @return bool
 | ||
|  */
 | ||
| if (!function_exists('del_target_dir')) {
 | ||
|     function del_target_dir($path, $delDir)
 | ||
|     {
 | ||
|         //没找到,不处理
 | ||
|         if (!file_exists($path)) {
 | ||
|             return false;
 | ||
|         }
 | ||
| 
 | ||
|         $handle = opendir($path);
 | ||
|         if ($handle) {
 | ||
|             while (false !== ($item = readdir($handle))) {
 | ||
|                 if ($item != "." && $item != "..") {
 | ||
|                     if (is_dir("$path/$item")) {
 | ||
|                         del_target_dir("$path/$item", $delDir);
 | ||
|                     } else {
 | ||
|                         unlink("$path/$item");
 | ||
|                     }
 | ||
|                 }
 | ||
|             }
 | ||
|             closedir($handle);
 | ||
|             if ($delDir) {
 | ||
|                 return rmdir($path);
 | ||
|             }
 | ||
|         } else {
 | ||
|             if (file_exists($path)) {
 | ||
|                 return unlink($path);
 | ||
|             }
 | ||
|             return false;
 | ||
|         }
 | ||
|     }
 | ||
| }
 | ||
| 
 | ||
| 
 | ||
| /**
 | ||
|  * Notes: 获取本地版本数据
 | ||
|  * @return mixed
 | ||
|  * @author 段誉(2021/7/7 18:18)
 | ||
|  */
 | ||
| if (!function_exists('local_version')) {
 | ||
|     function local_version()
 | ||
|     {
 | ||
|         if(!file_exists('./upgrade/')) {
 | ||
|             // 若文件夹不存在,先创建文件夹
 | ||
|             mkdir('./upgrade/', 0777, true);
 | ||
|         }
 | ||
|         if(!file_exists('./upgrade/version.json')) {
 | ||
|             // 获取本地版本号
 | ||
|             $version = config('project.version');
 | ||
|             $data = ['version' => $version];
 | ||
|             $src = './upgrade/version.json';
 | ||
|             // 新建文件
 | ||
|             file_put_contents($src, json_encode($data, JSON_UNESCAPED_UNICODE));
 | ||
|         }
 | ||
| 
 | ||
|         $json_string = file_get_contents('./upgrade/version.json');
 | ||
|         // 用参数true把JSON字符串强制转成PHP数组
 | ||
|         $data = json_decode($json_string, true);
 | ||
|         return $data;
 | ||
|     }
 | ||
| }
 | ||
| 
 | ||
| 
 | ||
| /**
 | ||
|  * Notes: 获取ip
 | ||
|  * @author 段誉(2021/7/9 10:19)
 | ||
|  * @return array|false|mixed|string
 | ||
|  */
 | ||
| if (!function_exists('get_client_ip')) {
 | ||
|     function get_client_ip()
 | ||
|     {
 | ||
|         if (!isset($_SERVER)) {
 | ||
|             return getenv('SERVER_ADDR');
 | ||
|         }
 | ||
| 
 | ||
|         if($_SERVER['SERVER_ADDR']) {
 | ||
|             return $_SERVER['SERVER_ADDR'];
 | ||
|         }
 | ||
| 
 | ||
|         return $_SERVER['LOCAL_ADDR'];
 | ||
|     }
 | ||
| }
 | ||
| 
 | ||
| 
 | ||
| /**
 | ||
|  * @notes 友好时间提示
 | ||
|  * @param $time
 | ||
|  * @return false|string
 | ||
|  * @author 段誉
 | ||
|  * @date 2022/5/6 9:45
 | ||
|  */
 | ||
| function friend_date($time)
 | ||
| {
 | ||
|     if (empty($time)) {
 | ||
|         return false;
 | ||
|     }
 | ||
| 
 | ||
|     $d = time() - intval($time);
 | ||
|     $ld = $time - mktime(0, 0, 0, 0, 0, date('Y'));  //年
 | ||
|     $md = $time - mktime(0, 0, 0, date('m'), 0, date('Y'));  //月
 | ||
|     $byd = $time - mktime(0, 0, 0, date('m'), date('d') - 2, date('Y'));  //前天
 | ||
|     $yd = $time - mktime(0, 0, 0, date('m'), date('d') - 1, date('Y'));  //昨天
 | ||
|     $dd = $time - mktime(0, 0, 0, date('m'), date('d'), date('Y'));  //今天
 | ||
|     $td = $time - mktime(0, 0, 0, date('m'), date('d') + 1, date('Y'));  //明天
 | ||
| 
 | ||
|     if (0 == $d) {
 | ||
|         return '刚刚';
 | ||
|     }
 | ||
| 
 | ||
|     switch ($d) {
 | ||
|         case $d < $td :
 | ||
|             $fdate = '后天' . date('H:i', $time);
 | ||
|             break;
 | ||
|         case  $d < 0:
 | ||
|             $fdate = '明天' . date('H:i', $time);
 | ||
|             break;
 | ||
|         case  $d < 60:
 | ||
|             $fdate = $d . '秒前';
 | ||
|             break;
 | ||
|         case  $d < 3600:
 | ||
|             $fdate = floor($d / 60) . '分钟前';
 | ||
|             break;
 | ||
|         case  $d < $dd :
 | ||
|             $fdate = floor($d / 3600) . '小时前';
 | ||
|             break;
 | ||
|         case  $d < $yd :
 | ||
|             $fdate = '昨天' . date('H:i', $time);
 | ||
|             break;
 | ||
|         case  $d < $byd :
 | ||
|             $fdate = '前天' . date('H:i', $time);
 | ||
|             break;
 | ||
|         case  $d < $md :
 | ||
|             $fdate = date('m月d日 H:i', $time);
 | ||
|             break;
 | ||
|         case  $d < $ld :
 | ||
|             $fdate = date('m月d日', $time);
 | ||
|             break;
 | ||
|         default :
 | ||
|             $fdate = date('Y年m月d日', $time);
 | ||
|             break;
 | ||
|     }
 | ||
|     return $fdate;
 | ||
| } |