0

0

PHP惯用工具类大全

php中文网

php中文网

发布时间:2016-06-13 12:27:48

|

1027人浏览过

|

来源于php中文网

原创

PHP常用工具类大全

 0)); $i ++) {if ($number = strpos ( str_pad ( decbin ( ord ( substr ( $string, $i, 1 ) ) ), 8, '0', STR_PAD_LEFT ), '0' )) {if ($length < 1.0) {break;}$result .= substr ( $string, $i, $number );$length -= 1.0;$i += $number - 1;} else {$result .= substr ( $string, $i, 1 );$length -= 0.5;}}$result = htmlspecialchars ( $result, ENT_QUOTES, 'UTF-8' );if ($i < $strlen) {$result .= $etc;}return $result;}/*** 遍历文件夹* @param string $dir* @param boolean $all  true表示递归遍历* @return array*/public static function scanfDir($dir='', $all = false, &$ret = array()){if ( false !== ($handle = opendir ( $dir ))) {while ( false !== ($file = readdir ( $handle )) ) {if (!in_array($file, array('.', '..', '.git', '.gitignore', '.svn', '.htaccess', '.buildpath','.project'))) {$cur_path = $dir . '/' . $file;if (is_dir ( $cur_path )) {$ret['dirs'][] =$cur_path;$all && self::scanfDir( $cur_path, $all, $ret);} else {$ret ['files'] [] = $cur_path;}}}closedir ( $handle );}return $ret;}/*** 邮件发送* @param string $toemail* @param string $subject* @param string $message* @return boolean*/public static function sendMail($toemail = '', $subject = '', $message = '') {$mailer = Yii::createComponent ( 'application.extensions.mailer.EMailer' );//邮件配置$mailer->SetLanguage('zh_cn');$mailer->Host = Yii::app()->params['emailHost']; //发送邮件服务器$mailer->Port = Yii::app()->params['emailPort']; //邮件端口$mailer->Timeout = Yii::app()->params['emailTimeout'];//邮件发送超时时间$mailer->ContentType = 'text/html';//设置html格式$mailer->SMTPAuth = true;$mailer->Username = Yii::app()->params['emailUserName'];$mailer->Password = Yii::app()->params['emailPassword'];$mailer->IsSMTP ();$mailer->From = $mailer->Username; // 发件人邮箱$mailer->FromName = Yii::app()->params['emailFormName']; // 发件人姓名$mailer->AddReplyTo ( $mailer->Username );$mailer->CharSet = 'UTF-8';// 添加邮件日志$modelMail = new MailLog ();$modelMail->accept = $toemail;$modelMail->subject = $subject;$modelMail->message = $message;$modelMail->send_status = 'waiting';$modelMail->save ();// 发送邮件$mailer->AddAddress ( $toemail );$mailer->Subject = $subject;$mailer->Body = $message;if ($mailer->Send () === true) {$modelMail->times = $modelMail->times + 1;$modelMail->send_status = 'success';$modelMail->save ();return true;} else {$error = $mailer->ErrorInfo;$modelMail->times = $modelMail->times + 1;$modelMail->send_status = 'failed';$modelMail->error = $error;$modelMail->save ();return false;}}/*** 判断字符串是utf-8 还是gb2312* @param unknown $str* @param string $default* @return string*/public static function utf8_gb2312($str, $default = 'gb2312'){   $str = preg_replace("/[\x01-\x7F]+/", "", $str);   if (empty($str)) return $default;   $preg =  array(       "gb2312" => "/^([\xA1-\xF7][\xA0-\xFE])+$/", //正则判断是否是gb2312       "utf-8" => "/^[\x{4E00}-\x{9FA5}]+$/u",      //正则判断是否是汉字(utf8编码的条件了),这个范围实际上已经包含了繁体中文字了   );   if ($default == 'gb2312') {       $option = 'utf-8';   } else {       $option = 'gb2312';   }   if (!preg_match($preg[$default], $str)) {       return $option;   }   $str = @iconv($default, $option, $str);   //不能转成 $option, 说明原来的不是 $default   if (empty($str)) {       return $option;   }   return $default;}/*** utf-8和gb2312自动转化* @param unknown $string* @param string $outEncoding* @return unknown|string*/public static function safeEncoding($string,$outEncoding = 'UTF-8'){$encoding = "UTF-8";for($i = 0; $i < strlen ( $string ); $i ++) {if (ord ( $string {$i} ) < 128)continue;if ((ord ( $string {$i} ) & 224) == 224) {// 第一个字节判断通过$char = $string {++ $i};if ((ord ( $char ) & 128) == 128) {// 第二个字节判断通过$char = $string {++ $i};if ((ord ( $char ) & 128) == 128) {$encoding = "UTF-8";break;}}}if ((ord ( $string {$i} ) & 192) == 192) {// 第一个字节判断通过$char = $string {++ $i};if ((ord ( $char ) & 128) == 128) {// 第二个字节判断通过$encoding = "GB2312";break;}}}if (strtoupper ( $encoding ) == strtoupper ( $outEncoding ))return $string;elsereturn @iconv ( $encoding, $outEncoding, $string );}/*** 返回二维数组中某个键名的所有值* @param input $array* @param string $key* @return array*/public static function array_key_values($array =array(), $key=''){$ret = array();foreach((array)$array as $k=>$v){$ret[$k] = $v[$key];}return $ret;}/*** 判断 文件/目录 是否可写(取代系统自带的 is_writeable 函数)* @param string $file 文件/目录* @return boolean*/public static function is_writeable($file) {if (is_dir($file)){$dir = $file;if ($fp = @fopen("$dir/test.txt", 'w')) {@fclose($fp);@unlink("$dir/test.txt");$writeable = 1;} else {$writeable = 0;}} else {if ($fp = @fopen($file, 'a+')) {@fclose($fp);$writeable = 1;} else {$writeable = 0;}}return $writeable;}/*** 格式化单位*/static public function byteFormat( $size, $dec = 2 ) {$a = array ( "B" , "KB" , "MB" , "GB" , "TB" , "PB" );$pos = 0;while ( $size >= 1024 ) {$size /= 1024;$pos ++;}return round( $size, $dec ) . " " . $a[$pos];}/*** 下拉框,单选按钮 自动选择** @param $string 输入字符* @param $param  条件* @param $type   类型* selected checked* @return string*/static public function selected( $string, $param = 1, $type = 'select' ) {$true = false;if ( is_array( $param ) ) {$true = in_array( $string, $param );}elseif ( $string == $param ) {$true = true;}$return='';if ( $true )$return = $type == 'select' ? 'selected="selected"' : 'checked="checked"';echo $return;}/*** 下载远程图片* @param string $url 图片的绝对url* @param string $filepath 文件的完整路径(例如/www/images/test) ,此函数会自动根据图片url和http头信息确定图片的后缀名* @param string $filename 要保存的文件名(不含扩展名)* @return mixed 下载成功返回一个描述图片信息的数组,下载失败则返回false*/static public function downloadImage($url, $filepath, $filename) {//服务器返回的头信息$responseHeaders = array();//原始图片名$originalfilename = '';//图片的后缀名$ext = '';$ch = curl_init($url);//设置curl_exec返回的值包含Http头curl_setopt($ch, CURLOPT_HEADER, 1);//设置curl_exec返回的值包含Http内容curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);//设置抓取跳转(http 301,302)后的页面curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);//设置最多的HTTP重定向的数量curl_setopt($ch, CURLOPT_MAXREDIRS, 3);//服务器返回的数据(包括http头信息和内容)$html = curl_exec($ch);//获取此次抓取的相关信息$httpinfo = curl_getinfo($ch);curl_close($ch);if ($html !== false) {//分离response的header和body,由于服务器可能使用了302跳转,所以此处需要将字符串分离为 2+跳转次数 个子串$httpArr = explode("\r\n\r\n", $html, 2 + $httpinfo['redirect_count']);//倒数第二段是服务器最后一次response的http头$header = $httpArr[count($httpArr) - 2];//倒数第一段是服务器最后一次response的内容$body = $httpArr[count($httpArr) - 1];$header.="\r\n";//获取最后一次response的header信息preg_match_all('/([a-z0-9-_]+):\s*([^\r\n]+)\r\n/i', $header, $matches);if (!empty($matches) && count($matches) == 3 && !empty($matches[1]) && !empty($matches[1])) {for ($i = 0; $i < count($matches[1]); $i++) {if (array_key_exists($i, $matches[2])) {$responseHeaders[$matches[1][$i]] = $matches[2][$i];}}}//获取图片后缀名if (0 < preg_match('{(?:[^\/\\\\]+)\.(jpg|jpeg|gif|png|bmp)$}i', $url, $matches)) {$originalfilename = $matches[0];$ext = $matches[1];} else {if (array_key_exists('Content-Type', $responseHeaders)) {if (0 < preg_match('{image/(\w+)}i', $responseHeaders['Content-Type'], $extmatches)) {$ext = $extmatches[1];}}}//保存文件if (!empty($ext)) {//如果目录不存在,则先要创建目录if(!is_dir($filepath)){mkdir($filepath, 0777, true);}$filepath .= '/'.$filename.".$ext";$local_file = fopen($filepath, 'w');if (false !== $local_file) {if (false !== fwrite($local_file, $body)) {fclose($local_file);$sizeinfo = getimagesize($filepath);return array('filepath' => realpath($filepath), 'width' => $sizeinfo[0], 'height' => $sizeinfo[1], 'orginalfilename' => $originalfilename, 'filename' => pathinfo($filepath, PATHINFO_BASENAME));}}}}return false;}/*** 查找ip是否在某个段位里面* @param string $ip 要查询的ip* @param $arrIP     禁止的ip* @return boolean*/public static function ipAccess($ip='0.0.0.0', $arrIP = array()){$access = true;$ip && $arr_cur_ip = explode('.', $ip);foreach((array)$arrIP as $key=> $value){if($value == '*.*.*.*'){$access = false; //禁止所有break;}$tmp_arr = explode('.', $value);if(($arr_cur_ip[0] == $tmp_arr[0]) && ($arr_cur_ip[1] == $tmp_arr[1])) {//前两段相同if(($arr_cur_ip[2] == $tmp_arr[2]) || ($tmp_arr[2] == '*')){//第三段为* 或者相同if(($arr_cur_ip[3] == $tmp_arr[3]) || ($tmp_arr[3] == '*')){//第四段为* 或者相同$access = false; //在禁止ip列,则禁止访问break;}}}}return $access;}/*** @param string $string 原文或者密文* @param string $operation 操作(ENCODE | DECODE), 默认为 DECODE* @param string $key 密钥* @param int $expiry 密文有效期, 加密时候有效, 单位 秒,0 为永久有效* @return string 处理后的 原文或者 经过 base64_encode 处理后的密文** @example** $a = authcode('abc', 'ENCODE', 'key');* $b = authcode($a, 'DECODE', 'key');  // $b(abc)** $a = authcode('abc', 'ENCODE', 'key', 3600);* $b = authcode('abc', 'DECODE', 'key'); // 在一个小时内,$b(abc),否则 $b 为空*/public static function authcode($string, $operation = 'DECODE', $key = '', $expiry = 3600) {$ckey_length = 4;// 随机密钥长度 取值 0-32;// 加入随机密钥,可以令密文无任何规律,即便是原文和密钥完全相同,加密结果也会每次不同,增大破解难度。// 取值越大,密文变动规律越大,密文变化 = 16 的 $ckey_length 次方// 当此值为 0 时,则不产生随机密钥$key = md5 ( $key ? $key : 'key' ); //这里可以填写默认key值$keya = md5 ( substr ( $key, 0, 16 ) );$keyb = md5 ( substr ( $key, 16, 16 ) );$keyc = $ckey_length ? ($operation == 'DECODE' ? substr ( $string, 0, $ckey_length ) : substr ( md5 ( microtime () ), - $ckey_length )) : '';$cryptkey = $keya . md5 ( $keya . $keyc );$key_length = strlen ( $cryptkey );$string = $operation == 'DECODE' ? base64_decode ( substr ( $string, $ckey_length ) ) : sprintf ( '%010d', $expiry ? $expiry + time () : 0 ) . substr ( md5 ( $string . $keyb ), 0, 16 ) . $string;$string_length = strlen ( $string );$result = '';$box = range ( 0, 255 );$rndkey = array ();for($i = 0; $i <= 255; $i ++) {$rndkey [$i] = ord ( $cryptkey [$i % $key_length] );}for($j = $i = 0; $i < 256; $i ++) {$j = ($j + $box [$i] + $rndkey [$i]) % 256;$tmp = $box [$i];$box [$i] = $box [$j];$box [$j] = $tmp;}for($a = $j = $i = 0; $i < $string_length; $i ++) {$a = ($a + 1) % 256;$j = ($j + $box [$a]) % 256;$tmp = $box [$a];$box [$a] = $box [$j];$box [$j] = $tmp;$result .= chr ( ord ( $string [$i] ) ^ ($box [($box [$a] + $box [$j]) % 256]) );}if ($operation == 'DECODE') {if ((substr ( $result, 0, 10 ) == 0 || substr ( $result, 0, 10 ) - time () > 0) && substr ( $result, 10, 16 ) == substr ( md5 ( substr ( $result, 26 ) . $keyb ), 0, 16 )) {return substr ( $result, 26 );} else {return '';}} else {return $keyc . str_replace ( '=', '', base64_encode ( $result ) );}}public static function gbkToUtf8($str){return iconv("GBK", "UTF-8", $str);}/*** 取得输入目录所包含的所有目录和文件* 以关联数组形式返回* author: flynetcn*/static public function deepScanDir($dir){$fileArr = array();$dirArr = array();$dir = rtrim($dir, '//');if(is_dir($dir)){$dirHandle = opendir($dir);while(false !== ($fileName = readdir($dirHandle))){$subFile = $dir . DIRECTORY_SEPARATOR . $fileName;if(is_file($subFile)){$fileArr[] = $subFile;} elseif (is_dir($subFile) && str_replace('.', '', $fileName)!=''){$dirArr[] = $subFile;$arr = self::deepScanDir($subFile);$dirArr = array_merge($dirArr, $arr['dir']);$fileArr = array_merge($fileArr, $arr['file']);}}closedir($dirHandle);}return array('dir'=>$dirArr, 'file'=>$fileArr);}/*** 取得输入目录所包含的所有文件* 以数组形式返回* author: flynetcn*/static public function get_dir_files($dir){if (is_file($dir)) {return array($dir);}$files = array();if (is_dir($dir) && ($dir_p = opendir($dir))) {$ds = DIRECTORY_SEPARATOR;while (($filename = readdir($dir_p)) !== false) {if ($filename=='.' || $filename=='..') { continue; }$filetype = filetype($dir.$ds.$filename);if ($filetype == 'dir') {$files = array_merge($files, self::get_dir_files($dir.$ds.$filename));} elseif ($filetype == 'file') {$files[] = $dir.$ds.$filename;}}closedir($dir_p);}return $files;}}

太多1000多行呢了保存不了,查看完整并下载 

 下载地址:http://www.shouce.ren/post/d/id/1700

ChatX翻译
ChatX翻译

最实用、可靠的社交类实时翻译工具。 支持全球主流的20+款社交软件的聊天应用,全球200+语言随意切换。 让您彻底告别复制粘贴的翻译模式,与世界各地高效连接!

下载

相关文章

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
2026春节习俗大全
2026春节习俗大全

本专题整合了2026春节习俗大全,阅读专题下面的文章了解更多详细内容。

56

2026.02.11

Yandex网页版官方入口使用指南_国际版与俄罗斯版访问方法解析
Yandex网页版官方入口使用指南_国际版与俄罗斯版访问方法解析

本专题全面整理了Yandex搜索引擎的官方入口信息,涵盖国际版与俄罗斯版官网访问方式、网页版直达入口及免登录使用说明,帮助用户快速、安全地进入Yandex官网,高效使用其搜索与相关服务。

157

2026.02.11

虫虫漫画网页版入口与免费阅读指南_正版漫画全集在线查看方法
虫虫漫画网页版入口与免费阅读指南_正版漫画全集在线查看方法

本专题系统整理了虫虫漫画官网及网页版最新入口,涵盖免登录观看、正版漫画全集在线阅读方式,并汇总稳定可用的访问渠道,帮助用户快速找到虫虫漫画官方页面,轻松在线阅读各类热门漫画内容。

37

2026.02.11

Docker容器化部署与DevOps实践
Docker容器化部署与DevOps实践

本专题面向后端与运维开发者,系统讲解 Docker 容器化技术在实际项目中的应用。内容涵盖 Docker 镜像构建、容器运行机制、Docker Compose 多服务编排,以及在 DevOps 流程中的持续集成与持续部署实践。通过真实场景演示,帮助开发者实现应用的快速部署、环境一致性与运维自动化。

4

2026.02.11

Rust异步编程与Tokio运行时实战
Rust异步编程与Tokio运行时实战

本专题聚焦 Rust 语言的异步编程模型,深入讲解 async/await 机制与 Tokio 运行时的核心原理。内容包括异步任务调度、Future 执行模型、并发安全、网络 IO 编程以及高并发场景下的性能优化。通过实战示例,帮助开发者使用 Rust 构建高性能、低延迟的后端服务与网络应用。

1

2026.02.11

Spring Boot企业级开发与MyBatis Plus实战
Spring Boot企业级开发与MyBatis Plus实战

本专题面向 Java 后端开发者,系统讲解如何基于 Spring Boot 与 MyBatis Plus 构建高效、规范的企业级应用。内容涵盖项目架构设计、数据访问层封装、通用 CRUD 实现、分页与条件查询、代码生成器以及常见性能优化方案。通过完整实战案例,帮助开发者提升后端开发效率,减少重复代码,快速交付稳定可维护的业务系统。

5

2026.02.11

包子漫画网页版入口与全集阅读指南_正版免费漫画快速访问方法
包子漫画网页版入口与全集阅读指南_正版免费漫画快速访问方法

本专题汇总了包子漫画官网和网页版入口,提供最新章节抢先看方法、正版免费阅读指南,以及稳定访问方式,帮助用户快速直达包子漫画页面,无广告畅享全集漫画内容。

156

2026.02.10

MC.JS网页版快速畅玩指南_MC.JS官网在线入口及免安装体验方法
MC.JS网页版快速畅玩指南_MC.JS官网在线入口及免安装体验方法

本专题汇总了MC.JS官网入口和网页版快速畅玩方法,提供免安装访问、不同版本(1.8.8、1.12.8)在线体验指南,以及正版网页端操作说明,帮助玩家轻松进入MC.JS世界,实现即时畅玩与高效体验。

84

2026.02.10

谷歌邮箱网页版登录与注册全指南_Gmail账号快速访问与安全操作教程
谷歌邮箱网页版登录与注册全指南_Gmail账号快速访问与安全操作教程

本专题汇总了谷歌邮箱网页版的最新登录入口和注册方法,详细提供官方账号快速访问方式、网页版操作教程及安全登录技巧,帮助用户轻松管理Gmail邮箱账户,实现高效、安全的邮箱使用体验。

73

2026.02.10

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
深入剖析redis教程
深入剖析redis教程

共55课时 | 8.2万人学习

Redis中文开发手册
Redis中文开发手册

共0课时 | 0人学习

麦子学院深入浅出 redis 视频教程
麦子学院深入浅出 redis 视频教程

共20课时 | 4.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号