PHP

我的一些常用的PHP函数

2874992246
2025-03-27 / 0 评论 / 3 阅读 / 正在检测是否收录...
温馨提示:
本文最后更新于2025年03月27日,已超过272天没有更新,若内容或图片失效,请留言反馈。
<?php
// 应用公共文件,内置主要的数据处理方法
use Jenssegers\Agent\Agent;
use think\facade\Cache;
use think\facade\Config;
use think\facade\Db;
use think\facade\Request;

function error_page_data()
{
    return array(
        'site_title' => get_system_config('site_title'),
        'site_keywords' => get_system_config('site_keywords'),
        'site_description' => get_system_config('site_description'),
        'site_mail' => get_system_config('site_mail'),
        'site_qq' => get_system_config('site_qq'),
        'site_beian' => get_system_config('site_beian'),
        'site_copyright' => get_system_config('site_copyright'),
        'title' => "页面错误"
    );
}

/*
 * 随机生成订单号
 */
function get_orderid()
{
    return date('YmdHis') . rand(10000000, 99999999);
}

/*
 * 随机字符串,默认长度10
 * $num 长度
 */
function get_string($num = 10)
{
    $str = 'qwertyuiopasdfghjklzxcvbnmQWERTYUIOPASDFGHJKLZXCVBNM1234567890';
    $salt = substr(str_shuffle($str), 10, $num);
    return $salt;
}

/*
 * 判断访客是否是蜘蛛
 */
function is_robot($except = '')
{
    $ua = strtolower($_SERVER ['HTTP_USER_AGENT']);
    $botchar = "/(baidu|google|spider|soso|yahoo|sohu-search|yodao|robozilla|AhrefsBot)/i";
    $except ? $botchar = str_replace($except . '|', '', $botchar) : '';
    if (preg_match($botchar, $ua)) {
        return true;
    }
    return false;
}

/*
 * 判断是否是手机浏览器
 */
function is_mobile()
{
    if (isset($_SERVER['HTTP_VIA']) && stristr($_SERVER['HTTP_VIA'], "wap")) {
        return true;
    } elseif (isset($_SERVER['HTTP_ACCEPT']) && strpos(strtoupper($_SERVER['HTTP_ACCEPT']), "VND.WAP.WML")) {
        return true;
    } elseif (isset($_SERVER['HTTP_X_WAP_PROFILE']) || isset($_SERVER['HTTP_PROFILE'])) {
        return true;
    } elseif (isset($_SERVER['HTTP_USER_AGENT']) && preg_match('/(blackberry|configuration\/cldc|hp |hp-|htc |htc_|htc-|iemobile|kindle|midp|mmp|motorola|mobile|nokia|opera mini|opera |Googlebot-Mobile|YahooSeeker\/M1A1-R2D2|android|iphone|ipod|mobi|palm|palmos|pocket|portalmmm|ppc;|smartphone|sonyericsson|sqh|spv|symbian|treo|up.browser|up.link|vodafone|windows ce|xda |xda_)/i', $_SERVER['HTTP_USER_AGENT'])) {
        return true;
    } else {
        return false;
    }
}

/**
 * @param $email
 * @return bool
 */
function is_email($email)
{
    $chars = "/^([a-z0-9+_]|-|\\.)+@(([a-z0-9_]|-)+\\.)+[a-z]{2,6}\$/i";
    if (strpos($email, '@') !== false && strpos($email, '.') !== false) {
        if (preg_match($chars, $email)) {
            return true;
        } else {
            return false;
        }
    } else {
        return false;
    }
}

/**
 * @param $phone
 * @return bool
 */
function is_phone($phone)
{
    $chars = "/^13[0-9]{1}[0-9]{8}$|15[0-9]{1}[0-9]{8}$|18[0-9]{1}[0-9]{8}$|17[0-9]{1}[0-9]{8}$/";
    if (preg_match($chars, $phone)) {
        return true;
    }
    return false;
}

/**
 * @param $ip
 * @return false|mixed|string
 * 获取IP的详细地址
 */
function get_ip_city($ip)
{
    /*
    http://opendata.baidu.com/api.php?query=116.179.32.80&co=&resource_id=6006&oe=utf8
    https://sp0.baidu.com/8aQDcjqpAAV3otqbppnN2DJv/api.php?query=116.179.32.80&co=&resource_id=6006&oe=utf8
    */
    $url = 'https://whois.pconline.com.cn/ipJson.jsp?json=true&ip=';
    $city = get_curl($url . $ip);
    $city = mb_convert_encoding($city, "UTF-8", "GB2312");
    $city = json_decode($city, true);
    $location = $city['city'] ? $city['pro'] . $city['city'] : $city['pro'];
    return $location ?: $city['addr'];
}

//设置缓存
function set_cache($key, $value, $date = 86400)
{
    Cache::set($key, $value, $date);
}

//读取缓存
function get_cache($key)
{
    return Cache::get($key);
}


function clear_cache($key)
{
    Cache::clear($key);
}


function get_system_config($name)
{
    $content = '';
    $type = Db::name('config')->where('name', $name)->value('type');
    if ($type) {
        // 如果存在缓存则优先读取缓存
        if (get_cache('system_config_' . $type)) {
            $array = get_cache('system_config_' . $type);
        } else {
            $array = Db::name('config')->field('name,content')->where('type', $type)->order('id asc')->select()->toArray();
            set_cache('system_config_' . $type, $array);
        }
        foreach ($array as $value) {
            if ($value['name'] == $name) {
                $content = $value['content'];
                break;
            }
        }
        if ($content) {
            return $content;
        } else {
            return '';
        }
    } else {
        return '';
    }
}

//生成一个不会重复的字符串
function make_token($type = 1)
{
    $str = md5(uniqid(md5(microtime(true)), true));
    $str = sha1($str); //加密
    if ($type == 1) {
        $str = strtoupper($str);
    }
    return $str;
}

/**
 * 将字符部分加密并输出
 * @param unknown $str
 * @param unknown $start 从第几个位置开始加密(从1开始)
 * @param unknown $length 连续加密多少位
 * @return string
 */
function encrypt_show($str, $start, $length)
{
    $end = $start - 1 + $length;
    $array = str_split($str);
    foreach ($array as $k => $v) {
        if ($k >= $start - 1 && $k < $end) {
            $array[$k] = '*';
        }
    }
    return implode('', $array);
}

/**
 * 加密函数
 * @param string $txt 需要加密的字符串
 * @param string $key 密钥
 * @return string 返回加密结果
 */
function ds_encrypt($txt, $key = '')
{
    if (empty($txt))
        return $txt;
    if (empty($key))
        $key = md5(config('ds_config.setup_date'));
    $chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_.";
    $ikey = "-x6g6ZWm2G9g_vr0Bo.pOq3kRIxsZ6rm";
    $nh1 = rand(0, 64);
    $nh2 = rand(0, 64);
    $nh3 = rand(0, 64);
    $ch1 = $chars{$nh1};
    $ch2 = $chars{$nh2};
    $ch3 = $chars{$nh3};
    $nhnum = $nh1 + $nh2 + $nh3;
    $knum = 0;
    $i = 0;
    while (isset($key{$i}))
        $knum += ord($key{$i++});
    $mdKey = substr(md5(md5(md5($key . $ch1) . $ch2 . $ikey) . $ch3), $nhnum % 8, $knum % 8 + 16);
    $txt = base64_encode(TIMESTAMP . '_' . $txt);
    $txt = str_replace(array('+', '/', '='), array('-', '_', '.'), $txt);
    $tmp = '';
    $j = 0;
    $k = 0;
    $tlen = strlen($txt);
    $klen = strlen($mdKey);
    for ($i = 0; $i < $tlen; $i++) {
        $k = $k == $klen ? 0 : $k;
        $j = ($nhnum + strpos($chars, $txt{$i}) + ord($mdKey{$k++})) % 64;
        $tmp .= $chars{$j};
    }
    $tmplen = strlen($tmp);
    $tmp = substr_replace($tmp, $ch3, $nh2 % ++$tmplen, 0);
    $tmp = substr_replace($tmp, $ch2, $nh1 % ++$tmplen, 0);
    $tmp = substr_replace($tmp, $ch1, $knum % ++$tmplen, 0);
    return $tmp;
}

/**
 * 解密函数
 * @param string $txt 需要解密的字符串
 * @param string $key 密匙
 * @return string 字符串类型的返回结果
 */
function ds_decrypt($txt, $key = '', $ttl = 0)
{
    if (empty($txt))
        return $txt;
    if (empty($key))
        $key = md5(config('ds_config.setup_date'));

    $chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_.";
    $ikey = "-x6g6ZWm2G9g_vr0Bo.pOq3kRIxsZ6rm";
    $knum = 0;
    $i = 0;
    $tlen = @strlen($txt);
    while (isset($key{$i}))
        $knum += ord($key{$i++});
    $ch1 = @$txt{$knum % $tlen};
    $nh1 = strpos($chars, $ch1);
    $txt = @substr_replace($txt, '', $knum % $tlen--, 1);
    $ch2 = @$txt{$nh1 % $tlen};
    $nh2 = @strpos($chars, $ch2);
    $txt = @substr_replace($txt, '', $nh1 % $tlen--, 1);
    $ch3 = @$txt{$nh2 % $tlen};
    $nh3 = @strpos($chars, $ch3);
    $txt = @substr_replace($txt, '', $nh2 % $tlen--, 1);
    $nhnum = $nh1 + $nh2 + $nh3;
    $mdKey = substr(md5(md5(md5($key . $ch1) . $ch2 . $ikey) . $ch3), $nhnum % 8, $knum % 8 + 16);
    $tmp = '';
    $j = 0;
    $k = 0;
    $tlen = @strlen($txt);
    $klen = @strlen($mdKey);
    for ($i = 0; $i < $tlen; $i++) {
        $k = $k == $klen ? 0 : $k;
        $j = strpos($chars, $txt{$i}) - $nhnum - ord($mdKey{$k++});
        while ($j < 0)
            $j += 64;
        $tmp .= $chars{$j};
    }
    $tmp = str_replace(array('-', '_', '.'), array('+', '/', '='), $tmp);
    $tmp = trim(base64_decode($tmp));

    if (preg_match("/\d{10}_/s", substr($tmp, 0, 11))) {
        if ($ttl > 0 && (TIMESTAMP - (int)substr($tmp, 0, 11) > $ttl)) {
            $tmp = null;
        } else {
            $tmp = substr($tmp, 11);
        }
    }
    return $tmp;
}

/**
 * 生成密码hash值
 * @param string $password
 * @return string
 */
function encryption_hash(string $password): string
{
    return password_hash($password, PASSWORD_DEFAULT);
}

/**
 * 获取runtime根目录路径
 * @return string
 */
function runtime_root_path(): string
{
    return dirname(runtime_path()) . DIRECTORY_SEPARATOR;
}

/**
 * 写入日志 (使用tp自带驱动记录到runtime目录中)
 * @param mixed $value
 * @param string $type
 */
function log_record($value, string $type = 'info')
{
    $content = is_string($value) ? $value : print_r($value, true);
    Log::record($content, $type);
}

/**
 * 隐藏手机号中间四位 13012345678 -> 130****5678
 * @param string $mobile 手机号
 * @return string
 */

function hide_mobile(string $mobile): string
{
    return substr_replace($mobile, '****', 3, 4);
}

/**
 * 获取当前系统版本号
 * @return string
 * @throws BaseException
 */
function get_version(): string
{
    return Auth_Version;
}

//读取文件配置
function get_config($key)
{
    return Config::get($key);
}

function get_ip()
{
    return request()->ip();
}

/**
 * 获取当前请求的变量,并进行安全过滤,防止xss注入攻击
 * @param string $key
 * @return mixed
 */
function get_params(string $key = "", $default = '', $filter = 'htmlspecialchars')
{
    return Request::param($key, $default, $filter);
}

/**
 * 转义经过安全过滤后的值
 * @param $content
 * @return string
 */
function safe_decode($content): string
{
    return htmlspecialchars_decode($content);
}

//判断程序是否完成安装
function is_installed()
{
    static $isInstalled;
    if (empty($isInstalled)) {
        $isInstalled = file_exists(Auth_Root . 'app/install/install.lock');
    }
    return $isInstalled;
}


/**
 * @param int $type 1获取时间,2获取时间戳
 * @return false|int|string
 */
function get_date(int $type = 1)
{
    if ($type == 1) {
        $res = date('Y-m-d H:i:s');
    } elseif ($type == 2) {
        $res = time();
    }
    return $res;
}

function get_agent($type = '')
{
    $agent = new Agent();

    $data = array(
        // 获取操作系统。(Ubuntu,Windows,OS X等)
        'browser' => $agent->browser(),
        // 获取设备名称(如果是移动设备)。(iPhone,Nexus,华硕平板电脑等)
        'device' => $agent->device(),
        // 获取操作系统。(Ubuntu,Windows,OS X等)
        'platform' => $agent->platform(),
        // 获取浏览器的接受语言
        'languages' => $agent->languages()
    );
    if ($type) {
        return $data[$type];
    } else {
        return $data;
    }
}

/**
 * @return int
 */
function get_code(): int
{
    return rand(111111, 999999);
}

function Ping($Url, $length = 4): string
{
    $start = microtime(true);
    $curl = curl_init();
    curl_setopt($curl, CURLOPT_URL, $Url);
    curl_setopt($curl, CURLOPT_HEADER, 1);
    curl_setopt($curl, CURLOPT_NOBODY, 1);
    curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, 0);
    curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, 0);
    curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
    $result = curl_exec($curl);
    curl_close($curl);
    $end = microtime(true);
    if (!empty($result)) {
        return round(number_format($end - $start, 10, '.', ''), $length) . '秒';
    }
    return '域名[ ' . $Url . ' ]无法访问';
}


/*
 * Action     网页请求操作
 * $url       需要请求的地址
 * $post      需要POST提交的数据
 * $referer   在HTTP请求头中"Referer: "的内容
 * $cookie    需要附带的cookie
 * $header    将头文件的信息作为数据流输出
 * $ua        在HTTP请求中包含一个"User-Agent: "头的字符串
 * $nobody    启用时将不对HTML中的BODY部分进行输出
 * $addheader 设置HTTP头字段的数组
 */
function get_curl($url, $post = 0, $referer = 0, $cookie = 0, $header = 0, $ua = 0, $nobaody = 0, $addheader = 0)
{
    $ch = curl_init();
    curl_setopt($ch, CURLOPT_URL, $url);
    curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
    curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false);
    $httpheader[] = "Accept: */*";
    $httpheader[] = "Accept-Encoding: gzip,deflate,sdch";
    $httpheader[] = "Accept-Language: zh-CN,zh;q=0.8";
    $httpheader[] = "Connection: close";
    if ($addheader) {
        $httpheader = array_merge($httpheader, $addheader);
    }
    curl_setopt($ch, CURLOPT_TIMEOUT, 30);
    if ($post) {
        curl_setopt($ch, CURLOPT_POST, 1);
        curl_setopt($ch, CURLOPT_POSTFIELDS, $post);
    }
    curl_setopt($ch, CURLOPT_HTTPHEADER, $httpheader);
    if ($header) {
        curl_setopt($ch, CURLOPT_HEADER, TRUE);
    }
    if ($cookie) {
        curl_setopt($ch, CURLOPT_COOKIE, $cookie);
    }
    if ($referer) {
        if ($referer == 1) {
            curl_setopt($ch, CURLOPT_REFERER, 'http://m.qzone.com/infocenter?g_f=');
        } else {
            curl_setopt($ch, CURLOPT_REFERER, $referer);
        }
    }
    if ($ua) {
        curl_setopt($ch, CURLOPT_USERAGENT, $ua);
    } else {
        curl_setopt($ch, CURLOPT_USERAGENT, 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/55.0.2883.87 Safari/537.36');
    }
    if ($nobaody) {
        curl_setopt($ch, CURLOPT_NOBODY, 1);
    }
    curl_setopt($ch, CURLOPT_ENCODING, "gzip");
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
    $ret = curl_exec($ch);
    curl_close($ch);
    return $ret;
}


/*
 * $to        收件人邮箱
 * $subject   邮件标题
 * $content   邮件内容
 * 发送邮件函数
 */
function send_email($to, $subject = '', $content = '')
{
    $mail = new PHPMailer\PHPMailer\PHPMailer();
    try {
        //设定邮件编码
        $mail->CharSet = "UTF-8";
        // 调试模式输出
        $mail->SMTPDebug = 0;
        // 使用SMTP
        $mail->isSMTP();
        // SMTP服务器
        $mail->Host = get_system_config('mail_smtp');
        // 允许 SMTP 认证
        $mail->SMTPAuth = true;
        // SMTP 用户名  即邮箱的用户名
        $mail->Username = get_system_config('mail_user');
        // SMTP 密码  部分邮箱是授权码(例如163邮箱)
        $mail->Password = get_system_config('mail_pass');
        // 允许 TLS 或者 ssl协议
        if (get_system_config('mail_encrypt')) {
            $mail->SMTPSecure = get_system_config('mail_encrypt');
        }
        //端口 - likely to be 25, 465 or 587,具体要看邮箱服务器支持
        $mail->Port = get_system_config('mail_port');
        //发件人
        $mail->setFrom(get_system_config('mail_user'), get_system_config('mail_name'));
        //接收邮件方
        if (is_array($to)) {
            foreach ($to as $v) {
                $mail->addAddress($v);
            }
        } else {
            $mail->addAddress($to);
        }

        //回复的时候回复给哪个邮箱 建议和发件人一致
        //$mail->addReplyTo(get_system_config('mail_user'));
        //抄送
        //$mail->addCC('cc@example.com');
        //密送
        //$mail->addBCC('bcc@example.com');
        // 添加附件
        //$mail->addAttachment('../../'.$mail_file);
        // 发送附件并且重命名
        // $mail->addAttachment('../thumb-1.jpg', 'new.jpg');

        // 是否以HTML文档格式发送  发送后客户端可直接显示对应HTML内容
        $mail->isHTML(true);
        // 邮件标题
        $mail->Subject = get_system_config('site_title') . ' - ' . $subject;
        // 邮件HTML内容
        $mail->Body = mail_view($content);
        // 邮件纯文本内容
        $mail->AltBody = $content;
        // 发送
        $mail->send();
        return true;
    } catch (Exception $e) {
        return $mail->ErrorInfo;
    }
}

/*
 * $content   邮件内容
 * 邮件模板
 */
function mail_view($content)
{
    $image = '';
    $template = '
        <style>
            .box_one{
                position: relative;
                color:#555;
                font:12px/1.5 Microsoft YaHei,Tahoma,Helvetica,Arial,sans-serif;
                max-width:600px;
                margin:50px auto;
                border-radius: 5px;
                box-shadow:0 5px 10px#aaaaaa;
                background: 0 0 repeat-x#FFF;
                background-image: -webkit-repeating-linear-gradient(135deg, #4882CE,#4882CE 20px, #FFF 20px, #FFF 35px, #EB1B2E 35px,#EB1B2E 55px, #FFF 55px, #FFF 70px);
                background-image:repeating-linear-gradient(-45deg, #4882CE, #4882CE 20px, #FFF 20px, #FFF 35px, #EB1B2E 35px, #EB1B2E 55px, #FFF 55px, #FFF 70px);
                background-size: 100% 10px;
            }
            .box_two{
                position: absolute; 
                right: 15px;
                top: 20px;
                width:133px;
                height: 87px;
            }
        </style>
        <div class="box_one">
            <img class="box_two" src="' . $image . '"/>
            <div style="padding: 0 15px 15px;">
                <h2 style="border-bottom:1px solid #e9e9e9;font-size:18px;font-weight:normal;padding:20px 0 10px;">
                    ' . get_system_config('mail_name') . '
                </h2>
                <p><span style="color: #007bfc;">' . $content . '</span></p> 
            </div>
            <div style="color:#888;padding:10px;border-top:1px solid #e9e9e9;background:#f5f5f5;border-radius: 0 0 5px 5px;">
                <p style="margin: 0;padding: 0;text-align: center;">
                    Copyright © <a href="' . request()->domain() . '" target="_blank">' . get_system_config('site_copyright') . '</a> All Rights Reserved.</p>
                <p style="color: red;margin: 0;padding: 0;text-align: center;">本邮件由系统发送,请勿回复</p>
            </div>
        </div>
    ';
    return $template;
}

function url_status($url)
{
    $ch = curl_init($url);
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
    curl_exec($ch);
    $res = curl_getinfo($ch, CURLINFO_HTTP_CODE); // 200
    curl_close($ch);
    return $res;
}
0

评论 (0)

取消