几个自定义的函数,不知道什么时候就可能用到了。。。。

时间:2022-10-11 16:02:10
/**
 * curl发送post请求
 * @access public
 * @param array $url        (必须)请求的地址
 * @param array $post_data  (可选)要发送的post数组
 * @return data             目标返回值
 */
function request_post($url, $post_data = array()) {

    if (empty($url) || empty($post_data))return false;

    $o = "";
    foreach ( $post_data as $k => $v ){
        $o.= "$k=" . urlencode( $v ). "&" ;
    }
    $curlPost = substr($o,0,-1);

    $ch = curl_init();//初始化curl
    curl_setopt($ch, CURLOPT_URL,$url);//抓取指定网页
    curl_setopt($ch, CURLOPT_HEADER, 0);//设置header
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);//要求结果为字符串且输出到屏幕上
    curl_setopt($ch, CURLOPT_POST, 1);//post提交方式
    curl_setopt($ch, CURLOPT_POSTFIELDS, $curlPost);
    $data = curl_exec($ch);//运行curl
    curl_close($ch);

    return $data;
}




/**
 * 产生随机字串,可用来自动生成密码 默认长度6位 字母和数字混合
 * @param string $len 长度
 * @param string $type 字串类型
 * 0 字母 1 数字 其它 混合
 * @param string $addChars 额外字符
 * @return string
 */
function rand_string($len=6,$type='',$addChars='') {
    $str ='';
    switch($type) {
        case 0:
            $chars='ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz'.$addChars;
            break;
        case 1:
            $chars= str_repeat('0123456789',3);
            break;
        case 2:
            $chars='ABCDEFGHIJKLMNOPQRSTUVWXYZ'.$addChars;
            break;
        case 3:
            $chars='abcdefghijklmnopqrstuvwxyz'.$addChars;
            break;
        case 4:
            $chars = "们以我到他会作时要动国产的一是工就年阶义发成部民可出能方进在了不和有大这主中人上为来分生对于学下级地个用同行面说种过命度革而多子后自社加小机也经力线本电高量长党得实家定深法表着水理化争现所二起政三好十战无农使性前等反体合斗路图把结第里正新开论之物从当两些还天资事队批点育重其思与间内去因件日利相由压员气业代全组数果期导平各基或月毛然如应形想制心样干都向变关问比展那它最及外没看治提五解系林者米群头意只明四道马认次文通但条较克又公孔领军流入接席位情运器并飞原油放立题质指建区验活众很教决特此常石强极土少已根共直团统式转别造切九你取西持总料连任志观调七么山程百报更见必真保热委手改管处己将修支识病象几先老光专什六型具示复安带每东增则完风回南广劳轮科北打积车计给节做务被整联步类集号列温装即毫知轴研单色坚据速防史拉世设达尔场织历花受求传口断况采精金界品判参层止边清至万确究书术状厂须离再目海交权且儿青才证低越际八试规斯近注办布门铁需走议县兵固除般引齿千胜细影济白格效置推空配刀叶率述今选养德话查差半敌始片施响收华觉备名红续均药标记难存测士身紧液派准斤角降维板许破述技消底床田势端感往神便贺村构照容非搞亚磨族火段算适讲按值美态黄易彪服早班麦削信排台声该击素张密害侯草何树肥继右属市严径螺检左页抗苏显苦英快称坏移约巴材省黑武培著河帝仅针怎植京助升王眼她抓含苗副杂普谈围食射源例致酸旧却充足短划剂宣环落首尺波承粉践府鱼随考刻靠够满夫失包住促枝局菌杆周护岩师举曲春元超负砂封换太模贫减阳扬江析亩木言球朝医校古呢稻宋听唯输滑站另卫字鼓刚写刘微略范供阿块某功套友限项余倒卷创律雨让骨远帮初皮播优占死毒圈伟季训控激找叫云互跟裂粮粒母练塞钢顶策双留误础吸阻故寸盾晚丝女散焊功株亲院冷彻弹错散商视艺灭版烈零室轻血倍缺厘泵察绝富城冲喷壤简否柱李望盘磁雄似困巩益洲脱投送奴侧润盖挥距触星松送获兴独官混纪依未突架宽冬章湿偏纹吃执阀矿寨责熟稳夺硬价努翻奇甲预职评读背协损棉侵灰虽矛厚罗泥辟告卵箱掌氧恩爱停曾溶营终纲孟钱待尽俄缩沙退陈讨奋械载胞幼哪剥迫旋征槽倒握担仍呀鲜吧卡粗介钻逐弱脚怕盐末阴丰雾冠丙街莱贝辐肠付吉渗瑞惊顿挤秒悬姆烂森糖圣凹陶词迟蚕亿矩康遵牧遭幅园腔订香肉弟屋敏恢忘编印蜂急拿扩伤飞露核缘游振操央伍域甚迅辉异序免纸夜乡久隶缸夹念兰映沟乙吗儒杀汽磷艰晶插埃燃欢铁补咱芽永瓦倾阵碳演威附牙芽永瓦斜灌欧献顺猪洋腐请透司危括脉宜笑若尾束壮暴企菜穗楚汉愈绿拖牛份染既秋遍锻玉夏疗尖殖井费州访吹荣铜沿替滚客召旱悟刺脑措贯藏敢令隙炉壳硫煤迎铸粘探临薄旬善福纵择礼愿伏残雷延烟句纯渐耕跑泽慢栽鲁赤繁境潮横掉锥希池败船假亮谓托伙哲怀割摆贡呈劲财仪沉炼麻罪祖息车穿货销齐鼠抽画饲龙库守筑房歌寒喜哥洗蚀废纳腹乎录镜妇恶脂庄擦险赞钟摇典柄辩竹谷卖乱虚桥奥伯赶垂途额壁网截野遗静谋弄挂课镇妄盛耐援扎虑键归符庆聚绕摩忙舞遇索顾胶羊湖钉仁音迹碎伸灯避泛亡答勇频皇柳哈揭甘诺概宪浓岛袭谁洪谢炮浇斑讯懂灵蛋闭孩释乳巨徒私银伊景坦累匀霉杜乐勒隔弯绩招绍胡呼痛峰零柴簧午跳居尚丁秦稍追梁折耗碱殊岗挖氏刃剧堆赫荷胸衡勤膜篇登驻案刊秧缓凸役剪川雪链渔啦脸户洛孢勃盟买杨宗焦赛旗滤硅炭股坐蒸凝竟陷枪黎救冒暗洞犯筒您宋弧爆谬涂味津臂障褐陆啊健尊豆拔莫抵桑坡缝警挑污冰柬嘴啥饭塑寄赵喊垫丹渡耳刨虎笔稀昆浪萨茶滴浅拥穴覆伦娘吨浸袖珠雌妈紫戏塔锤震岁貌洁剖牢锋疑霸闪埔猛诉刷狠忽灾闹乔唐漏闻沈熔氯荒茎男凡抢像浆旁玻亦忠唱蒙予纷捕锁尤乘乌智淡允叛畜俘摸锈扫毕璃宝芯爷鉴秘净蒋钙肩腾枯抛轨堂拌爸循诱祝励肯酒绳穷塘燥泡袋朗喂铝软渠颗惯贸粪综墙趋彼届墨碍启逆卸航衣孙龄岭骗休借".$addChars;
            break;
        case 5:  //VIN
            $chars='ABCDEFGHJKLMNPRSTUVWXYZ0123456789'.$addChars;
            break;
        default :
            // 默认去掉了容易混淆的字符oOLl和数字01,要添加请使用addChars参数
            $chars='ABCDEFGHIJKMNPQRSTUVWXYZabcdefghijkmnpqrstuvwxyz23456789'.$addChars;
            break;
    }
    if($len>10 ) {//位数过长重复字符串一定次数
        $chars= $type==1? str_repeat($chars,$len) : str_repeat($chars,5);
    }
    if($type!=4) {
        $chars   =   str_shuffle($chars);
        $str     =   substr($chars,0,$len);
    }else{
        // 中文随机字
        for($i=0;$i<$len;$i++){
            $str.= msubstr($chars, floor(mt_rand(0,mb_strlen($chars,'utf-8')-1)),1);
        }
    }
    return $str;
}


 /**
     * 返回传入的字母附近第n个字母
     * @author gjy
     *
     * @param  string $letter
     * @param  integer $num
     * @return string
     */
    function neighbor_letter($letter = '', $num = 1)
    {
        $num = (int) $num;
        if ($num === 0) {
            return $letter;
        }

        $ascllDec = ord($letter) + $num;
        if ($ascllDec < 65
            || ($ascllDec > 90 && $ascllDec < 97)
            || $ascllDec > 122) {
            return '';
        }

        return chr($ascllDec);
    }

    /**
     * 全角字符转半角
     * @author gjy
     *
     * @param  string $str
     * @param  string $coding
     * @return string
     */
    function str_full2half($str = '', $coding = 'UTF-8')
    {
        if (empty($str)) {
            return '';
        }

        if ($coding !== 'UTF-8') {
            $str = mb_convert_encoding($str, 'UTF-8', $coding);
        }

        $ret = '';

        for ($i = 0; $i < strlen($str); ++$i) {
            $s1 = $str[$i];
            if (($c = ord($s1)) & 0x80) {
                $s2 = $str[++$i];
                $s3 = $str[++$i];
                $c = (($c & 0xF) << 12) | ((ord($s2) & 0x3F) << 6) | (ord($s3) & 0x3F);
                if ($c == 12288) {
                    $ret .= ' ';
                } elseif ($c > 65280 && $c < 65375 && $c != 65374) {
                    $c -= 65248;
                    $ret .= chr($c);
                } else {
                    $ret .= $s1 . $s2 . $s3;
                }
            } else {
                $ret .= $str[$i];
            }
        }

        if ($coding === 'UTF-8') {
            return $ret;
        }

        return mb_convert_encoding($ret, $coding, 'UTF-8');
    }

    /**
     * 去除制定的html标签
     * @author gjy
     *
     * @param  string $str
     * @param  string $type
     * @return string
     */
    function strip_html_tags($str = '', $type = 'script')
    {
        if (empty($str)) {
            return '';
        }

        $stripType = array(
            'all' => '@<[\/\!]*?[^<>]*?>@si', // 所有标签, 等同于 strip_tags()
            'script' => '@<script[^>]*?>.*?</script>@si', // 去除js
            'style' => '@<style[^>]*?>.*?</style>@siU', // 去除css
            'comments' => '@<![\s\S]*?--[ \t\n\r]*>@', // 去除注释
            'html' => '@<html[^>]*?>.*?</html>@si', // 去除html标签
            'body' => '@<body[^>]*?>.*?</body>@si', // 去除body标签
        );

        if (empty($stripType[$type])) {
            return $str;
        }

        return preg_replace($stripType[$type], '', $str);
    }

    /**
     * 生成随机字符串
     * @author CodeIgniter developer
     * @revisor gjy
     *
     * @param  string $type
     * @param  integer $len
     * @return string
     */
    function random_string($type = 'distinct_num', $len = 8)
    {
        switch (true) {
            default:
            case 'numeric' === $type:
                $pool = '1234567890';
                break;
            case 'nozero' === $type:
                $pool = '123456789';
                break;
            case 'alnum' === $type:
                $pool = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
                break;
            case 'alpha' === $type:
                $pool = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
                break;
            case 'distinct' === $type:
                $pool = 'abcdefghijkmnpqrstuvwxyzABCDEFGHIJKLMNPQRSTUVWXYZ';
                break;
            case 'distinct_num' === $type:
                $pool = '3456789abcdefghijkmnpqrstuvwxyABCDEFGHIJKLMNPQRSTUVWXY';
                break;
            case 'abc123' === $type:
                $pool = '3456789abcdefghijkmnpqrstuvwxy';
                break;
            case 'md5' === $type:
                return md5(uniqid(mt_rand()));
            case 'sha1' === $type:
                return sha1(uniqid(mt_rand(), true));
        }

        return substr(str_shuffle(str_repeat($pool, ceil($len / strlen($pool)))), 0, $len);
    }

    /**
     * 生成可识别的序列号
     * @author gjy
     *
     * @param  string $type
     * @return string 至少32位
     */
    function gen_serial_no($type = 'numeric', $len = 0)
    {
        if ('numeric' === $type) {
            /** 长度为32+的基本数字流水号 */
            $time = microtime(true);
            $micro = sprintf('%06d', ($time - floor($time)) * 1000000);
            // 时间&毫秒(20) + 随机数位(12+n)
            return date('YmdHis' . $micro, $time) . self::random_string('numeric', 12 + ($len < 1 ? 0 : intval($len)));
        } else {
            return md5(uniqid(mt_rand()));
        }
    }

    /**
     * 去除字符两边的标点符号 (中英文)
     * @author gjy
     *
     * @param  string $string
     * @return string
     */
    function trim_punctuation($string = '', $pos = '')
    {
        $pos = strtolower($pos);
        switch (true) {
            case 'l' === $pos:
                $pattern = '/^' . CommonRegex::PUNCTUATION_UNICODE . '*/';
                break;
            case 'r' === $pos:
                $pattern = '/' . CommonRegex::PUNCTUATION_UNICODE . '*$/';
                break;

            default:
                $pattern = [
                    // left
                    '/^' . CommonRegex::PUNCTUATION_UNICODE . '*/',
                    // right
                    '/' . CommonRegex::PUNCTUATION_UNICODE . '*$/',
                ];
                break;
        }

        return urldecode(preg_replace($pattern, '', urlencode($string)));
    }

    /**
     * 按行将字符处理为数组
     * @author gjy
     *
     * @param  string $string
     * @return array
     */
    function row_explode(string $string) : array
    {
        $delimiter = '__EXPLODE__' . uniqid(mt_rand());
        return explode($delimiter, str_replace(array("\n\r", "\r\n", "\r", "\n"), $delimiter, $string));
    }



    /**
     * 性能更高的数组去重
     * 解决 array_unique 使用快排算法处理大数组时的性能损耗问题
     * @author gjy
     *
     * @param  array $arrData
     * @param  boolean $filtered
     * @return array
     */
    function unique(array $arrData = array(), $filtered = FALSE) : array
    {
        if (!$filtered) {
            $arrData = array_filter($arrData);
        }

        return array_keys(array_flip($arrData));
    }


    /**
     * 随机取数组中一个值
     * @author gjy
     *
     * @param  array $array
     * @return array | mixed
     */
    function random_value(array $array)
    {
        return empty($array) ? [] : $array[array_rand($array)];
    }


    /**
     * 在一维数组中筛选出数字
     * @author gjy <goujinyang@kuaiqiangche.com>
     *
     * @param  array $array
     * @return array
     */
    function filter_number(array $array)
    {
        return array_filter($array, function($item, $key) {
            $tmpVar = trim($item);
            return is_numeric($tmpVar);
        }, ARRAY_FILTER_USE_BOTH);
    }