php functions

2019-08-13  本文已影响0人  JUN888

<?php

/**
 * 微擎密码生成
 *
 */

function we7password($passwordinput, $salt, $authkey)
{
    $passwordinput = "{$passwordinput}-{$salt}-{$authkey}";
    return sha1($passwordinput);
}

/*****************************************时间相关函数*********************************************** */

/**
 * @title  计算时间差
 * @author lyj [author] [2018-06-07]
 * @param  [type] $datetimeStr1 [日期时间字符串1]
 * @param  [type] $datetimeStr2 [日期时间字符串2]
 * @return [type]               [返回秒数]
 */
function getDateTimeDifference($datetimeStr1, $datetimeStr2)
{
    return strtotime($datetimeStr1) - strtotime($datetimeStr2);
}

/**
 * @title  时间戳 转 日期时间字符串
 * @author lyj [author] [2018-06-07]
 * @param  [type] $timeStamp [时间戳 数字]
 * @param  string $pattern   [日期时间格式 Y-m-d H:i:s]
 * @return [type]            [返回 日期时间字符串]
 */
function getDateTimeStr($timeStamp = null, $pattern = 'Y-m-d H:i:s')
{
    if ($timeStamp == null || !is_int($timeStamp)) {
        return date($pattern);
    } else {
        return date($pattern, $timeStamp);
    }
}

/**
 * @title  根据需要返回对应时间戳
 * @author lyj [author] [2018-06-04]
 * @param  string $config [description]
 * @return [type]         [description]
 */
function getTimestamp($config = '')
{
    switch ($config) {
        case '1':
            // 返回 明天 的Unix时间戳
            return strtotime("+1 day");
            break;
        case '2':
            // 返回 昨天 的Unix时间戳
            return strtotime("-1 day");
            break;
        case '3':
            // 返回 下月 的Unix时间戳
            return strtotime("+1 month");
            break;
        case '4':
            // 返回 上月 的Unix时间戳
            return strtotime("-1 month");
            break;
        case '5':
            // 返回 明年 的Unix时间戳
            return strtotime("+1 year");
            break;
        case '6':
            // 返回 上年 的Unix时间戳
            return strtotime("-1 year");
            break;
        case '7':
            // 返回 下星期 的Unix时间戳
            return strtotime("+1 week");
            break;
        case '8':
            // 返回 上星期 的Unix时间戳
            return strtotime("-1 week");
            break;
        case '9':
            // 返回 本月第一天 的Unix时间戳
            return strtotime(date("Y-m-01 H:i:s"));
            break;
        case '10':
            // 返回 本月最后一天 的Unix时间戳
            return strtotime(date("Y-m-t H:i:s"));
            break;
        case '11':
            // 返回 本周第一天 的Unix时间戳
            return strtotime("this week");
            break;
        case '12':
            // 返回 本周最后一天 的Unix时间戳
            return strtotime("last day this week");
            break;

        case '13':
            // 返回 今年开始 的Unix时间戳
            return strtotime(date("Y-m-d"));
            break;
        default:
            // 返回 当前 的Unix时间戳
            return time();
            break;
    }
}

/*****************************************时间相关函数*********************************************** */

/*****************************************工具类函数*********************************************** */

/**
 * 获取二维数组中某列 $colstr 的最大最小值
 */
function getMaxAndMinInArr($arr, $colstr = 0)
{
    //求colstr这一列的最大值
    $max = 0;
    foreach ($arr as $key => $val) {
        $max = max($max, $val[$colstr]);
    }

    //求colstr这一列的最小值
    $min = $max;
    foreach ($arr as $key => $val) {
        $min = min($min, $val[$colstr]);
    }

    return array('max' => $max, 'min' => $min);
}

/**
 * @param int $n  参数。188752
 * @param int $length  要保存的小数位
 * @param bool $status 当为true时四舍五入保存
 * @return double   返回数据
 */
function decimals($n = 0, $length = 2, $status = false)
{
    if ($status === true) {
        $num = round($n, $length);
        return $num;
    }
    $n = (string) $n;
    $n = explode('.', $n);
    $n[0] .= '.';
    for ($i = 0; $i < $length; $i++) {
        $n[0] .= !isset($n[1][$i]) ? '0' : $n[1][$i];
    }
    return $n[0];
}

/**
 * 获取唯一码
 * @param int $len
 * @return string
 */
function get_uni_code($len = 8)
{
    $code = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ';
    $rand = $code[rand(0, 25)]
    . strtoupper(dechex(date('m')))
    . date('d') . substr(time(), -5)
    . substr(microtime(), 2, 5)
    . sprintf('%02d', rand(0, 99));
    for (
        $a = md5($rand),
        $s = '0123456789ABCDEFGHIJKLMNOPQRSTUV',
        $d = '',
        $f = 0;
        $f < $len;
        $g = ord($a[$f]),
        $d .= $s[($g ^ ord($a[$f])) - $g & 0x1F],
        $f++
    );

    return $d;
}

/**
 * 根据两点经纬度计算距离
 * @param $lat1 点1纬度
 * @param $lng1 点1经度
 * @param $lat2 点2纬度
 * @param $lng2 点2经度
 * @return float 距离单位:千米
 */
function get_distance($lat1, $lng1, $lat2, $lng2)
{
    $earthRadius = 6371.004;
    $lat1 = ($lat1 * pi()) / 180;
    $lng1 = ($lng1 * pi()) / 180;
    $lat2 = ($lat2 * pi()) / 180;
    $lng2 = ($lng2 * pi()) / 180;
    $calcLongitude = $lng2 - $lng1;
    $calcLatitude = $lat2 - $lat1;
    $stepOne = pow(sin($calcLatitude / 2), 2) + cos($lat1) * cos($lat2) * pow(sin($calcLongitude / 2), 2);
    $stepTwo = 2 * asin(min(1, sqrt($stepOne)));
    $calculatedDistance = $earthRadius * $stepTwo;

    return sprintf("%.2f", $calculatedDistance);
}

/**
 * @title  随机字符串
 * @author lyj [author] [2018-06-08]
 * @param  integer $length  [字符长度]
 * @param  string  $type    [类型 数字 大写字母 小写字母 全部]
 * @param  integer $convert [大小写 大于0 大写 小于0 小写]
 * @return [type]           [description]
 *
 * echo random(32,'all',-45646);
 */
function random($length = 6, $type = 'all', $convert = 0)
{
    $config = array(
        'number' => '1234567890',
        'capital_letter'=> 'ABCDEFGHIJKLMNOPQRSTUVWXYZ',
        'small_letter'=> 'abcdefghijklmnopqrstuvwxyz',         
        'all'    => 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890'
    );
 
    if (!isset($config[$type])) {
        $type = 'string';
    }
    $string = $config[$type];
 
    $code = '';
    $strlen = strlen($string) - 1;
    for ($i = 0; $i < $length; $i++) {
        $code .= $string{mt_rand(0, $strlen)};
    }
    if ($convert != 0) {
        $code = ($convert > 0) ? strtoupper($code) : strtolower($code);
    }
    return $code;
}


/**
 * @title  去除代码中的空白和注释
 * @author lyj [author] [2018-06-08]
 * @param  [type] $content [php文件内容]
 * @return [type]          [清空空白和注释后的代码]
 *
 *
 *  使用说明
 *   $phpstr = file_get_contents("E:/www/test/functions.php");
 *   $phpstr_new = strip_whitespace($phpstr); 
 *   file_put_contents('E:/www/test/newphp.php', $phpstr_new);
 */
function strip_whitespace($content) 
{
    $stripStr   = '';
    //分析php源码
    $tokens     = token_get_all($content);
    $last_space = false;
    for ($i = 0, $j = count($tokens); $i < $j; $i++) {
        if (is_string($tokens[$i])) {
            $last_space = false;
            $stripStr  .= $tokens[$i];
        } else {
            switch ($tokens[$i][0]) {
                //过滤各种PHP注释
                case T_COMMENT:
                case T_DOC_COMMENT:
                    break;
                //过滤空格
                case T_WHITESPACE:
                    if (!$last_space) {
                        $stripStr  .= ' ';
                        $last_space = true;
                    }
                    break;
                case T_START_HEREDOC:
                    $stripStr .= "<<<THINK\n";
                    break;
                case T_END_HEREDOC:
                    $stripStr .= "THINK;\n";
                    for($k = $i+1; $k < $j; $k++) {
                        if(is_string($tokens[$k]) && $tokens[$k] == ';') {
                            $i = $k;
                            break;
                        } else if($tokens[$k][0] == T_CLOSE_TAG) {
                            break;
                        }
                    }
                    break;
                default:
                    $last_space = false;
                    $stripStr  .= $tokens[$i][1];
            }
        }
    }
    return $stripStr;
}

if (!function_exists('arr_multi_sort')) {
    
    /**
     * 根据二维数组某列 排序
     *
     * @param [type] $arr  数组
     * @param [type] $arg  列的键值
     * @param string $sort 排序类型 asc 升序 desc 降序 默认升序
     * @return void
     */
    function arr_multi_sort(&$arr,$arg,$sort = 'asc')
    {
        $sort = $sort=='asc'?SORT_ASC:SORT_DESC;
        $column_data = array_column($arr,$arg);
        array_multisort($column_data,$sort,$arr);
    }
}

if (!function_exists('log2txt')) {
    
    /**
     * 写入日志
     *
     * @param [type] $values
     * @param string $dir
     * @return void
     */
    function log2txt($values, $dir = 'lyj')
    {
        // 如果数据是数组则转换成字符
        if (is_array($values)) {
            $values = print_r($values, true);
        }

        // 日志内容
        $content = '[' . date('Y-m-d H:i:s') . ']' . PHP_EOL . $values . PHP_EOL . PHP_EOL;
        try {
            // 文件路径
            $filePath = $dir . '/logs/';
            // 路径不存在则创建
            !is_dir($filePath) && mkdir($filePath, 0755, true);
            // 写入文件
            return file_put_contents($filePath . date('Y-m-d') . '.log', $content . PHP_EOL . PHP_EOL, FILE_APPEND);
        } catch (\Exception $e) {
            return false;
        }
    }

}






/*****************************************工具类函数*********************************************** */
 

$arr = [
    'a' => [
        'name' => '对的',
        'num' => 20,
    ],
    'b' => [
        'name' => 'as',
        'num' => 32,
    ],
    'c' => [
        'name' => '对方答复',
        'num' => 1,
    ],
]; 

print_r($arr);

arr_multi_sort($arr, 'num', desc);

print_r($arr);



上一篇下一篇

猜你喜欢

热点阅读