php函数封装

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 这是一些自定义封装的函数类,调用起来很方便,以后会有更多的封装函数更新!// 弹框跳转function alert($msg,$url=''){ echo ""; echo "alert('$msg');"; if($url){ echo "window.

这是一些自定义封装的函数类,调用起来很方便,以后会有更多的封装函数更新!

// 弹框跳转
function alert($msg,$url=''){
echo "<script>";
echo "alert('$msg');";
if($url){
echo "window.location.href='$url';";
}else{
echo "window.history.go(-1);";
}
echo "</script>";
}


//获取单条数据
function getONE($sql){
$sql = mysql_query($sql);
$list = array();
if($sql && mysql_affected_rows()>0){
$list = mysql_fetch_assoc($sql);
}return $list;
}

//获取多条数据
function getALL($sql){
$sql = mysql_query($sql);
$list = array();
if($sql && mysql_affected_rows()>0){
while($row = mysql_fetch_assoc($sql)){
$list[] = $row;
}
}return $list;
}

/**
* [delete 删除数据]
* @param [string] $table [表名]
* @param [string] $where [条件]
* @return [boolean] [返回结果]
*/
//删除数据SQL语句封装
function delete($table,$where){
//构造删除的SQL语句
$sql = "DELETE FROM `$table` WHERE $where;";
//把SQL语句执行
$res = mysql_query($sql);
//判断是否执行成功
if($res && mysql_affected_rows()>0){
return true;
}else{
return false;
}
}

/**
* [update 更新数据]
* @param [string] $table [表名]
* @param [array] $array [要更新的数据]
* @param [string] $where [条件]
* @return [type] [返回结果]
*/
//更新数据SQL语句封装
function update($table,$array,$where){
$str = '';
foreach($array as $key => $value){
$str .= "`".$key."`='".$value."',";
}
//去除最右边的逗号
$str = rtrim($str,',');
//构造更新的SQL语句
$sql = "UPDATE `$table` SET $str WHERE $where";
// dump($sql);exit;
$res = mysql_query($sql);
//判断是否执行成功
if($res){
return true;
}else{
return false;
}
}

/**
* [insert 插入数据]
* @param [string] $table [表名]
* @param [array] $data [数据]
* @return [bool] [是否成功]
*/
function insert($table,$data){
$tmp = array_keys($data);
$field = '`'.implode('`,`', $tmp).'`';
$value = "'".implode("','",$data)."'";
$sql = "INSERT INTO $table ($field) VALUES ($value)";
// dump($sql);exit;
$res = mysql_query($sql);
if($res && mysql_affected_rows()>0){
return mysql_insert_id();
}else{
return false;
}
}

//pre预排版打印
function dump($content){
echo "<pre>";
print_r($content);
echo "</pre>";
}


/**
*
* 字符截取
* @param string $string
* @param int $start
* @param int $length
* @param string $charset
* @param string $dot
*
* @return string
*/
function str_cut(&$string, $start, $length, $charset = "utf-8", $dot = '...') {
if(function_exists('mb_substr')) {
if(mb_strlen($string, $charset) > $length) {
return mb_substr ($string, $start, $length, $charset) . $dot;
}
return mb_substr ($string, $start, $length, $charset);

}else if(function_exists('iconv_substr')) {
if(iconv_strlen($string, $charset) > $length) {
return iconv_substr($string, $start, $length, $charset) . $dot;
}
return iconv_substr($string, $start, $length, $charset);
}

$charset = strtolower($charset);
switch ($charset) {
case "utf-8" :
preg_match_all("/[\x01-\x7f]|[\xc2-\xdf][\x80-\xbf]|\xe0[\xa0-\xbf][\x80-\xbf]|[\xe1-\xef][\x80-\xbf][\x80-\xbf]|\xf0[\x90-\xbf][\x80-\xbf][\x80-\xbf]|[\xf1-\xf7][\x80-\xbf][\x80-\xbf][\x80-\xbf]/", $string, $ar); if(func_num_args() >= 3) { if (count($ar[0]) > $length) { return join("", array_slice($ar[0], $start, $length)) . $dot; } return join("", array_slice($ar[0], $start, $length)); } else { return join("", array_slice($ar[0], $start)); } break; default: $start = $start * 2; $length = $length * 2; $strlen = strlen($string); for ( $i = 0; $i < $strlen; $i++ ) { if ( $i >= $start && $i < ( $start + $length ) ) { if ( ord(substr($string, $i, 1)) > 129 ) $tmpstr .= substr($string, $i, 2); else $tmpstr .= substr($string, $i, 1); } if ( ord(substr($string, $i, 1)) > 129 ) $i++; } if ( strlen($tmpstr) < $strlen ) $tmpstr .= $dot; return $tmpstr; }}


/**
* [uploads 文件上传函数]
* @param [string] $name [表单域的name名]
* @param [string] $catalog [文件保存的路径]
* @param array $type [允许上传的文件类型]
* @param integer $size [允许上传的文件大小]
* @return [array] [error 1 上传失败 2 上传成功]
*/
function uploads($name,$catalog,$type=array('jpg','jpeg','gif','png'),$size=1048576){
$status = $_FILES[$name]['error'];
if($status>0){
switch($status){
case 1:
$res['msg'] = "文件上传超过最大值2M";
$res['err'] = 1;
return $res;
break;
case 2:
$res['msg'] = "文件上传超过MAX_FILE_SIZE大小";
$res['err'] = 1;
return $res;
break;
case 3:
$res['msg'] = "文件上传失败";
$res['err'] = 1;
return $res;
break;
case 4:
$res['msg'] = '请选择文件';
$res['err'] = 1;
return $res;
break;
default:
break;
}
}
if($_FILES[$name]['size']>$size){
$res['msg'] = '上传文件超出指定大小';
$res['err'] = 1;
return $res;
}
$ext = pathinfo($_FILES[$name]['name'],PATHINFO_EXTENSION);

if(!in_array($ext,$type)){
$res['msg'] = '请上传指定的文件类型';
$res['err'] = 1;
return $res;
}
//第一种做法
$catalog = rtrim($catalog,'/');
$dir = $catalog;
if(!is_dir($dir)){
mkdir($dir,0777,true);
}
do{
$file = time().mt_rand(1000,9999);

$filename = $file.'.'.$ext;

$newname = $dir.'/'.$filename;

}while(is_file($dir.'/'.$filename));
move_uploaded_file($_FILES[$name]['tmp_name'], $dir.'/'.$filename);
$res['msg'] = '文件上传成功';
$res['err'] = 2;
$res['filename'] = $filename;
$res['name'] = $filename;
return $res;
}

 

 


//封装缩略图的函数
function small($file,$widths,$heights,$address){
$filename="$file";
$info = getimagesize($filename);

//获取图片的宽
$width = $info[0];
//获取图片的高
$height = $info[1];

//打开图片
if($info[2]==1){
$parent = imagecreatefromgif($filename);
}else if($info[2]==2){
$parent = imagecreatefromjpeg($filename);
}else if($info[2]==3){
$parent = imagecreatefrompng($filename);
}

$son_width = $widths;
$son_height = $heights;
// 等比例缩放
// $son_height = ceil(($height*$son_width)/$width);

//w/h = s_w/s_h
//新建图像
$son = imagecreatetruecolor($son_width,$son_height);

imagecopyresized($son,$parent,0,0,0,0,$son_width,$son_height,$width,$height);
$path = pathinfo($filename,PATHINFO_EXTENSION);
$time = time();
$pathname = $time.mt_rand(1000,9999).'.'.$path;

$save = $address.$pathname;
if($info[2]==1){ imagegif($son,$save); }else if($info[2]==2){ imagejpeg($son,$save); }else if($info[2]==3){ imagepng($son,$save); } imagedestroy($son); imagedestroy($parent); return $pathname; }

/**
* 获得用户的真实IP地址
*
* @access public
* @return string
*/
function real_ip()
{
static $realip = NULL;

if ($realip !== NULL)
{
return $realip;
}

if (isset($_SERVER))
{
if (isset($_SERVER['HTTP_X_FORWARDED_FOR']))
{
$arr = explode(',', $_SERVER['HTTP_X_FORWARDED_FOR']);

/* 取X-Forwarded-For中第一个非unknown的有效IP字符串 */
foreach ($arr AS $ip)
{
$ip = trim($ip);

if ($ip != 'unknown')
{
$realip = $ip;

break;
}
}
}
elseif (isset($_SERVER['HTTP_CLIENT_IP']))
{
$realip = $_SERVER['HTTP_CLIENT_IP'];
}
else
{
if (isset($_SERVER['REMOTE_ADDR']))
{
$realip = $_SERVER['REMOTE_ADDR'];
}
else
{
$realip = '0.0.0.0';
}
}
}
else
{
if (getenv('HTTP_X_FORWARDED_FOR'))
{
$realip = getenv('HTTP_X_FORWARDED_FOR');
}
elseif (getenv('HTTP_CLIENT_IP'))
{
$realip = getenv('HTTP_CLIENT_IP'); } else { $realip = getenv('REMOTE_ADDR'); } } preg_match("/[\d\.]{7,15}/", $realip, $onlineip); $realip = !empty($onlineip[0]) ? $onlineip[0] : '0.0.0.0'; return $realip;}

/**
* [arraySort 无限极分类函数]
* @param [type] $arr [description]
* @param integer $parentid [description]
* @return [type] [description]
*/
function arraySort($arr,$id,$pid,$parentid=0){
$list=array();
foreach($arr as $key => $v){
if($v[$pid]==$parentid){
$tmp = arraySort($arr,$id,$pid,$v[$id]);
if($tmp){
$v['submenu'] = $tmp;
}
$list[]=$v;
}
}
return $list;
}

 

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
3月前
|
PHP
php常见问题,php.ini文件不存在或者找不到,mb_strlen()函数未定义系列问题,dll模块找不到的解决
本文介绍了解决PHP常见问题的步骤,包括定位和创建`php.ini`文件,以及解决`mb_strlen()`函数未定义和DLL模块加载错误的具体方法。
php常见问题,php.ini文件不存在或者找不到,mb_strlen()函数未定义系列问题,dll模块找不到的解决
|
1月前
|
关系型数据库 MySQL 数据库连接
PHP内置函数
PHP内置函数
28 5
|
3月前
|
存储 API PHP
php学习笔记-php数组的创建和使用,数组常用函数-day03
关于PHP数组的创建、使用以及常用函数的详细学习笔记。
php学习笔记-php数组的创建和使用,数组常用函数-day03
|
2月前
|
Unix PHP 数据库
PHP日期和时间Date()函数获取当前时间
通过灵活运用 `date()`函数及其丰富的格式选项,PHP开发者可以轻松地在应用程序中处理和展示日期及时间信息。无论是需要精确到秒的完整时间戳,还是仅仅展示日期或时间的某一部分,`date()`函数都能胜任。理解并熟练应用这些格式化技巧,对于提升代码的可读性和维护性至关重要。
69 1
|
7月前
|
PHP 开发者
【专栏】介绍PHP的命名空间,它是一个用于封装代码、避免名称冲突的机制
【4月更文挑战第27天】本文介绍了PHP的命名空间,它是一个用于封装代码、避免名称冲突的机制。命名空间的作用包括:防止大型项目中的命名冲突,提升代码可读性和可维护性,以及方便代码重用。文章详细阐述了如何定义、导入命名空间,使用完全限定名称以及设置命名空间别名。通过实例展示了命名空间在项目模块划分和第三方库如Laravel中的应用,强调了命名空间在组织和管理PHP代码中的关键作用。
73 4
|
3月前
|
XML SQL PHP
php学习笔记-php字符串及字符串常用函数总结-day04
本文总结了PHP中字符串的三种定义方式和常用字符串处理函数,包括字符串的修剪、转换、长度计算、子串操作、比较、连接、分割及替换等操作。
|
3月前
|
设计模式 存储 算法
PHP中的设计模式:策略模式的深入解析与应用在软件开发的浩瀚海洋中,PHP以其独特的魅力和强大的功能吸引了无数开发者。作为一门历史悠久且广泛应用的编程语言,PHP不仅拥有丰富的内置函数和扩展库,还支持面向对象编程(OOP),为开发者提供了灵活而强大的工具集。在PHP的众多特性中,设计模式的应用尤为引人注目,它们如同精雕细琢的宝石,镶嵌在代码的肌理之中,让程序更加优雅、高效且易于维护。今天,我们就来深入探讨PHP中使用频率颇高的一种设计模式——策略模式。
本文旨在深入探讨PHP中的策略模式,从定义到实现,再到应用场景,全面剖析其在PHP编程中的应用价值。策略模式作为一种行为型设计模式,允许在运行时根据不同情况选择不同的算法或行为,极大地提高了代码的灵活性和可维护性。通过实例分析,本文将展示如何在PHP项目中有效利用策略模式来解决实际问题,并提升代码质量。
|
4月前
|
Linux PHP
Linux CentOS 宝塔 Suhosin禁用php5.6版本eval函数详细图文教程
【8月更文挑战第27天】本文介绍两种禁用PHP执行的方法:使用`PHP_diseval_extension`禁用和通过`suhosin`禁用。由于`suhosin`不支持PHP8,仅适用于PHP7及以下版本,若服务器安装了PHP5.6,则需对应安装`suhosin-0.9.38`版本。文章提供了详细的安装步骤,并强调了宝塔环境下与普通环境下的PHP路径差异。安装完成后,在`php.ini`中添加`suhosin.so`扩展并设置`executor.disable_eval = on`以禁用执行功能。最后通过测试代码验证是否成功禁用,并重启`php-fpm`服务生效。
62 2
|
4月前
|
JavaScript 前端开发 PHP
|
4月前
|
监控 数据库连接 PHP
php中register_shutdown_function函数用法详解
通过 `register_shutdown_function`,PHP开发者可以对脚本的终止进行更精细化的处理,这个函数让开发者能在脚本的生命周期结束时有机会执行最后的操作,无论脚本是正常结束还是发生错误。由于它的高度实用性和灵活性,`register_shutdown_function`是PHP开发中不可或缺的工具之一。
72 0