PHP常用自定义功能函数

这篇博客分享了一系列PHP自定义函数,包括计算多久以前的时间显示、文件上传与管理、根据IP获取地理位置、文件下载、文件删除、去除HTML标签、文件大小转换、目录文件遍历、强制下载、防止网页复制、字符截取、获取当前URL、文件扩展名获取、解压文件和获取客户端IP等功能。这些函数涵盖了常见的Web开发需求,有助于提高开发效率。
摘要由CSDN通过智能技术生成

PHP常用的自定义功能函数

这里累积了一些PHP常用的功能的自定义函数,希望大家参考。

php实现多长时间之前

function word_time($time) {
    $time = (int) substr($time, 0, 10);
    $int = time() - $time;
    $str = '';
    if ($int <= 2){
        $str = sprintf('刚刚', $int);
    }elseif ($int < 60){
        $str = sprintf('%d秒前', $int);
    }elseif ($int < 3600){
        $str = sprintf('%d分钟前', floor($int / 60));
    }elseif ($int < 86400){
        $str = sprintf('%d小时前', floor($int / 3600));
    }elseif ($int < 1728000){
        $str = sprintf('%d天前', floor($int / 86400));
    }else{
        $str = date('Y-m-d H:i:s', $time);
    }
    return $str;
}
//使用方法
$date = date('Y-m-d H:i:s',time()-3600);
$time = strtotime($date);
echo word_time($time);

php文件上传函数

/**
 1. [file_upload 文件上传函数,支持单文件,多文件]
 2. Author: 程威明
 3. @param  string $name         input表单中的name
 4. @param  string $save_dir         文件保存路径,相对于当前目录
 5. @param  array  $allow_suffix 允许上传的文件后缀
 6. @return array                array() {
 7.                                         ["status"]=> 全部上传成功为true,全部上传失败为false,部分成功为成功数量
 8.                                         ["path"]=>array() {已成功的文件路径}
 9.                                         ["error"]=>array() {失败信息}
 10.                                      }
 */
function files_upload($name="photo",$save_dir="images",$allow_suffix=array('jpg','jpeg','gif','png')){
    //如果是单文件上传,改变数组结构
    if(!is_array($_FILES[$name]['name'])){
        $list = array();
        foreach($_FILES[$name] as $k=>$v){
            $list[$k] = array($v);
        }
        $_FILES[$name] = $list;
    }
 
    $response = array();
    $response['status'] = array();
    $response['path'] = array();
    $response['error'] = array();
 
    //拼接保存目录
    $save_dir = './'.trim(trim($save_dir,'.'),'/').'/';
 
    //判断保存目录是否存在
    if(!file_exists($save_dir))
    {
        //不存在则创建
        if(false==mkdir($save_dir,0777,true))
        {
            $response['status'] = false;
            $response['error'][] = '文件保存路径错误,路径 "'.$save_dir.'" 创建失败';
        }
    }
 
    $num = count($_FILES[$name]['tmp_name']);
 
    $success = 0;
 
    //循环处理上传
    for($i=0;$i <$num;$i++)
    {
        //判断是不是post上传
        if(!is_uploaded_file($_FILES[$name]['tmp_name'][$i]))
        {
            $response['error'][] = '非法上传,文件 "'.$_FILES[$name]['name'][$i].'" 不是post获得的';
            continue;
        }
 
        //判断错误
        if($_FILES[$name]['error'][$i]>0)
        {
            $response['error'][] = '文件 "'.$_FILES[$name]['name'][$i].'" 上传错误,error下标为 "'.$_FILES[$name]['error'][$i].'"';
            continue;
        }
 
        //获取文件后缀
        $suffix = ltrim(strrchr($_FILES[$name]['name'][$i],'.'),'.');
 
        //判断后缀是否是允许上传的格式
        if(!in_array($suffix,$allow_suffix))
        {
            $response['error'][] = '文件 "'.$_FILES[$name]['name'][$i].'" 为不允许上传的文件类型';
            continue;
        }
 
        //得到上传后文件名
        $new_file_name =date('ymdHis',time()).'_'.uniqid().'.'.$suffix;
 
        //拼接完整路径
        $new_path = $save_dir.$new_file_name;
 
        //上传文件 把tmp文件移动到保存目录中
        if(!move_uploaded_file($_FILES[$name]['tmp_name'][$i],$new_path))
        {
            $response['error'][] = '文件 "'.$_FILES[$name]['name'][$i].'" 从临时文件夹移动到保存目录时发送错误';
            continue;
        }
 
        //返回由图片文件路径组成的数组
        $response['path'][] =$save_dir.$new_file_name;
 
        $success++;
    }
 
    if(0==$success){
        $success = false;
    }elseif($success==$num){
        $success = true;
    }
 
    $response['status'] = $success;
 
    return $response;
}

php根据IP地址获取地理位置函数


/**
 * 获取IP的地理位置
 * @param  String $ip IP地址
 * @return 所在位置
 */
function get_address($ip){
	if($ip == '127.0.0.1') return '本地地址';
	$content = @file_get_contents('http://int.dpool.sina.com.cn/iplookup/iplookup.php?format=json&ip='.$ip);
	$arr = json_decode($content, true);
	if(is_array($arr)){
		return $arr['country'].'-'.$arr['province'].'-'.$arr['city'];
	}else{
		return '未知';
	}
}

php文件下载函数

/**
 * 文件下载
 * @param $filepath 文件路径
 * @param $filename 文件名称
 */

function file_down($filepath, $filename = '') {
	if(!$filename) $filename = basename($filepath);
	if(is_ie()) $filename = rawurlencode($filename);
	$filetype = fileext($filename);
	$filesize = sprintf("%u", filesize($filepath));
	if(ob_get_length() !== false) @ob_end_clean();
	header('Pragma: public');
	header('Last-Modified: '.gmdate('D, d M Y H:i:s') . ' GMT');
	header('Cache-Control: no-store, no-cache, must-revalidate');
	header('Cache-Control: pre-check=0, post-check=0, max-age=0');
	header('Content-Transfer-Encoding: binary');
	header('Content-Encoding: none');
	header('Content-type: '.$filetype);
	header('Content-Disposition: attachment; filename="'.$filename.'"');
	header('Content-length: '.$filesize);
	readfile($filepath);
	exit;
}

php删除指定路径下文件

/**
 * 删除指定路径下文件
 * @param  [type] $path 文件路径
 */
function delFile($path) {
	try {
  		if(file_exists($path)) {
   			unlink($path);
  		}
  	} catch (Exception $e) {
  		echo $e->getMessage();
  	}
}

正则去掉字符串中的html标签

/**
 * 正则去掉字符串中的html标签
 * @param unknown $str
 * @return string
 */
function filterHtml($str) {
	$str = str_replace("&nbsp;","",strip_tags($str));
	$str = preg_replace('/((\s)*(\n)+(\s)*)/i','', $str);
	$str = trim($str);
	return $str;
}

php将文件大小换算成合适的单位

/**
 * 将文件大小换算成合适的单位
 * @param int $size
 * @return $size
 */
function convertSize($size) {
	// Adapted from: http://www.php.net/manual/en/function.filesize.php  
	$mod = 1024;
	$units = explode(' ', 'B KB MB GB TB PB');
	for($i = 0; $size > $mod; $i ++) {
		$size /= $mod;
	}
	return round($size, 2).' '.$units[$i];
}

列出目录下的文件名

/**
 * 列出目录下的文件名
 * @param  [type] $DirPath 目录
 */
function listDirFiles($DirPath){
	if($dir = opendir($DirPath)){
		while(($file = readdir($dir))!== false){
			if(!is_dir($DirPath.$file)) { 
				echo "filename: $file<br />";
			} 
		} 
	}
}

php强制下载文件

/**
 * php强制下载文件
 * @param String $filename 文件名称
 */
function download($filename){ 
    if ((isset($filename))&&(file_exists($filename))){ 
       header("Content-length: ".filesize($filename)); 
       header('Content-Type: application/octet-stream'); 
       header('Content-Disposition: attachment; filename="' . $filename . '"'); 
       readfile("$filename"); 
    } else { 
       echo "Looks like file does not exist!"; 
    } 
}

防止网页复制代码

/**
 * 防止网页复制代码
 */
echo "<script>
document.οncοntextmenu=new Function("event.returnValue=false;");
document.onselectstart=new Function("event.returnValue=false;");
</script>
";

php字符截取

/**
 * 字符截取
 * @param $string 要截取的字符串
 * @param $length 截取长度
 * @param $dot	  截取之后用什么表示
 * @param $code	  编码格式,支持UTF8/GBK
 */
function str_cut($string, $length, $dot = '...', $code = 'utf-8') {
	$strlen = strlen($string);
	if($strlen <= $length) return $string;
	$string = str_replace(array(' ','&nbsp;', '&amp;', '&quot;', '&#039;', '&ldquo;', '&rdquo;', '&mdash;', '&lt;', '&gt;', '&middot;', '&hellip;'), array('∵',' ', '&', '"', "'", '“', '”', '—', '<', '>', '·', '…'), $string);
	$strcut = '';
	if($code == 'utf-8') {
		$length = intval($length-strlen($dot)-$length/3);
		$n = $tn = $noc = 0;
		while($n < strlen($string)) {
			$t = ord($string[$n]);
			if($t == 9 || $t == 10 || (32 <= $t && $t <= 126)) {
				$tn = 1; $n++; $noc++;
			} elseif(194 <= $t && $t <= 223) {
				$tn = 2; $n += 2; $noc += 2;
			} elseif(224 <= $t && $t <= 239) {
				$tn = 3; $n += 3; $noc += 2;
			} elseif(240 <= $t && $t <= 247) {
				$tn = 4; $n += 4; $noc += 2;
			} elseif(248 <= $t && $t <= 251) {
				$tn = 5; $n += 5; $noc += 2;
			} elseif($t == 252 || $t == 253) {
				$tn = 6; $n += 6; $noc += 2;
			} else {
				$n++;
			}
			if($noc >= $length) {
				break;
			}
		}
		if($noc > $length) {
			$n -= $tn;
		}
		$strcut = substr($string, 0, $n);
		$strcut = str_replace(array('∵', '&', '"', "'", '“', '”', '—', '<', '>', '·', '…'), array(' ', '&amp;', '&quot;', '&#039;', '&ldquo;', '&rdquo;', '&mdash;', '&lt;', '&gt;', '&middot;', '&hellip;'), $strcut);
	} else {
		$dotlen = strlen($dot);
		$maxi = $length - $dotlen - 1;
		$current_str = '';
		$search_arr = array('&',' ', '"', "'", '“', '”', '—', '<', '>', '·', '…','∵');
		$replace_arr = array('&amp;','&nbsp;', '&quot;', '&#039;', '&ldquo;', '&rdquo;', '&mdash;', '&lt;', '&gt;', '&middot;', '&hellip;',' ');
		$search_flip = array_flip($search_arr);
		for ($i = 0; $i < $maxi; $i++) {
			$current_str = ord($string[$i]) > 127 ? $string[$i].$string[++$i] : $string[$i];
			if (in_array($current_str, $search_arr)) {
				$key = $search_flip[$current_str];
				$current_str = str_replace($search_arr[$key], $replace_arr[$key], $current_str);
			}
			$strcut .= $current_str;
		}
	}
	return $strcut.$dot;
}

获取当前页面完整URL地址

/**
 * 获取当前页面完整URL地址
 */
function get_url() {
	$sys_protocal = isset($_SERVER['SERVER_PORT']) && $_SERVER['SERVER_PORT'] == '443' ? 'https://' : 'http://';
	$php_self = $_SERVER['PHP_SELF'] ? safe_replace($_SERVER['PHP_SELF']) : safe_replace($_SERVER['SCRIPT_NAME']);
	$path_info = isset($_SERVER['PATH_INFO']) ? safe_replace($_SERVER['PATH_INFO']) : '';
	$relate_url = isset($_SERVER['REQUEST_URI']) ? safe_replace($_SERVER['REQUEST_URI']) : $php_self.(isset($_SERVER['QUERY_STRING']) ? '?'.safe_replace($_SERVER['QUERY_STRING']) : $path_info);
	return $sys_protocal.HTTP_HOST.$relate_url;
}

取得文件扩展

/**
 * 取得文件扩展
 *
 * @param $filename 文件名
 * @return 扩展名
 */
function fileext($filename) {
	return strtolower(trim(substr(strrchr($filename, '.'), 1, 10)));
}

php解压文件

/* 
  * 解压文件 
  * 需开启配置 php_zip.dll 
  * filename 要解压的文件全路径 
  * path 解压文件后保存路径 
  * 返回值 trur或者false
  *  
  */  
function get_zip($filename, $path) {
    $filename = iconv("utf-8", "gb2312", $filename);  //中文路径转码
    $path = iconv("utf-8", "gb2312", $path);  
    if (!file_exists($filename)) {              //先判断待解压的文件是否存在 
       die("文件 $filename 不存在!"); 
       return false; 
    }  
    $resource = zip_open($filename);  //打开压缩包
    while ($dir_resource = zip_read($resource)) {  //遍历读取压缩包里面的一个个文件  
        if (zip_entry_open($resource, $dir_resource)) {  //如果能打开则继续  
            $file_name = $path.zip_entry_name($dir_resource);  //获取当前项目的名称,即压缩包里面当前对应的文件名  
            $file_path = substr($file_name, 0, strrpos($file_name, "/"));  //以最后一个“/”分割,再用字符串截取出路径部分  
            if (!is_dir($file_path)) {  //如果路径不存在,则创建一个目录,true表示可以创建多级目录  
                mkdir($file_path, 0777, true);  
            }  
            if (!is_dir($file_name)) {      //如果不是目录,则写入文件  
                $file_size = zip_entry_filesize($dir_resource);       //读取这个文件  
                if ($file_size < (1024 * 1024 * 200)) {       //最大读取200M,如果文件过大,跳过解压,继续下一个  
                    $file_content = zip_entry_read($dir_resource, $file_size);  
                    file_put_contents($file_name, $file_content);  
                } else {  
                  return false;
                }  
            }  
            zip_entry_close($dir_resource);   //关闭当前  
        }  
    }  
    zip_close($resource); //关闭压缩包  
    return true;   
} 

获取客户端IP地址

/**
 * 获取客户端IP地址
 * @param integer $type 返回类型 0 返回IP地址 1 返回IPV4地址数字
 * @param boolean $adv 是否进行高级模式获取(有可能被伪装) 
 * @return mixed
 */
function get_client_ip($type = 0,$adv=false) {
    $type       =  $type ? 1 : 0;
    static $ip  =   NULL;
    if ($ip !== NULL) return $ip[$type];
    if($adv){
        if (isset($_SERVER['HTTP_X_FORWARDED_FOR'])) {
            $arr    =   explode(',', $_SERVER['HTTP_X_FORWARDED_FOR']);
            $pos    =   array_search('unknown',$arr);
            if(false !== $pos) unset($arr[$pos]);
            $ip     =   trim($arr[0]);
        }elseif (isset($_SERVER['HTTP_CLIENT_IP'])) {
            $ip     =   $_SERVER['HTTP_CLIENT_IP'];
        }elseif (isset($_SERVER['REMOTE_ADDR'])) {
            $ip     =   $_SERVER['REMOTE_ADDR'];
        }
    }elseif (isset($_SERVER['REMOTE_ADDR'])) {
        $ip     =   $_SERVER['REMOTE_ADDR'];
    }
    // IP地址合法验证
    $long = sprintf("%u",ip2long($ip));
    $ip   = $long ? array($ip, $long) : array('0.0.0.0', 0);
    return $ip[$type];
}

获取文件后缀

/** 
 * 获取文件后缀(如果文件名为11.11,11不是后缀,会默认11为后缀)
 * $file string 文件路径或者文件名
 */
function get_extension($file){
    return pathinfo($file, PATHINFO_EXTENSION);
}

URL重定向

/**
 * URL重定向
 * @param string $url 重定向的URL地址
 * @param integer $time 重定向的等待时间(秒)
 * @param string $msg 重定向前的提示信息
 * @return void
 */
function redirect($url, $time=0, $msg='') {
    //多行URL地址支持
    $url        = str_replace(array("\n", "\r"), '', $url);
    if (empty($msg))
        $msg    = "系统将在{$time}秒之后自动跳转到{$url}!";
    if (!headers_sent()) {
        // redirect
        if (0 === $time) {
            header('Location: ' . $url);
        } else {
            header("refresh:{$time};url={$url}");
            echo($msg);
        }
        exit();
    } else {
        $str    = "<meta http-equiv='Refresh' content='{$time};URL={$url}'>";
        if ($time != 0)
            $str .= $msg;
        exit($str);
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

燕鹏01

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值