php 功能函数集

1.获取页面闭合带id标签数据

View Code
 1 <?php
 2     header("Content-type: text/html; charset=utf-8"); 
 3     /**
 4      * $tag_id  HTML tag_id like id="abc"
 5      * $url     web url
 6      * $tag     HTML tag
 7      * $data    HTML data if $url set to false
 8      * @example echo getWebTag('id="nav"','http://mail.163.com/html/mail_intro/','ul');
 9      */
10     function getWebTag($tag_id,$url=false,$tag='div',$data=false){
11         if($url !== false){
12             $data = file_get_contents( $url );
13         }
14         $charset_pos = stripos($data,'charset');
15         if($charset_pos) {
16             if(stripos($data,'utf-8',$charset_pos)) {
17                 $data = iconv('utf-8','utf-8',$data);
18             }else if(stripos($data,'gb2312',$charset_pos)) {
19                 $data = iconv('gb2312','utf-8',$data);
20             }else if(stripos($data,'gbk',$charset_pos)) {
21                 $data = iconv('gbk','utf-8',$data);
22             }
23         }
24         
25         preg_match_all('/<'.$tag.'/i',$data,$pre_matches,PREG_OFFSET_CAPTURE);    //获取所有div前缀
26         preg_match_all('/<\/'.$tag.'/i',$data,$suf_matches,PREG_OFFSET_CAPTURE); //获取所有div后缀
27         $hit = strpos($data,$tag_id);
28         if($hit == -1) return false;    //未命中
29         $divs = array();    //合并所有div
30         foreach($pre_matches[0] as $index=>$pre_div){
31             $divs[(int)$pre_div[1]] = 'p';
32             $divs[(int)$suf_matches[0][$index][1]] = 's';    
33         }
34         
35         //对div进行排序
36         $sort = array_keys($divs);
37         asort($sort);
38         
39         $count = count($pre_matches[0]);
40         foreach($pre_matches[0] as $index=>$pre_div){
41             //<div $hit <div+1    时div被命中
42             if(($pre_matches[0][$index][1] < $hit) && ($hit < $pre_matches[0][$index+1][1])){
43                 $deeper = 0;
44                 //弹出被命中div前的div
45                 while(array_shift($sort) != $pre_matches[0][$index][1] && ($count--)) continue;
46                 //对剩余div进行匹配,若下一个为前缀,则向下一层,$deeper加1,
47                 //否则后退一层,$deeper减1,$deeper为0则命中匹配,计算div长度
48                 foreach($sort as $key){
49                     if($divs[$key] == 'p') $deeper++;
50                     else if($deeper == 0) {
51                         $length = $key-$pre_matches[0][$index][1];
52                         break;
53                     }else {
54                         $deeper--;
55                     }
56                 }
57                 $hitDivString = substr($data,$pre_matches[0][$index][1],$length).'</'.$tag.'>';
58                 break;
59             }
60         }
61         return $hitDivString;
62     }
63     
64     echo getWebTag('id="nav"','http://mail.163.com/html/mail_intro/','ul');
65     echo getWebTag('id="homeBanners"','http://mail.163.com/html/mail_intro/');
66     echo getWebTag('id="performance"','http://mail.163.com/html/mail_intro/','section');
67 
68 //End_php

1.1 由(1)改进为获取页面任意标签,参考《颠覆想象的php解析获取跨域HTML标签

View Code
  1  <?php
  2     header("Content-type: text/html; charset=utf-8"); 
  3     /**
  4       * $tag_id  HTML tag_id like id="abc"
  5       * $url     web url
  6       * $tag     HTML tag
  7       * $data    HTML data if $url set to false
  8       * $first   Only get the first match
  9       * @example 
 10         var_dump(getWebTag('id="nav"','http://mail.163.com/html/mail_intro/','ul'));
 11       */
 12     function getWebTag($tag_id,$url=false,$tag='div',$data=false,$first=false){
 13         //默认采用URL获取数据
 14         if($url !== false){
 15             $data = file_get_contents( $url );
 16         }
 17         //页面编码判定及转码
 18         $charset_pos = stripos($data,'charset');
 19         if($charset_pos) {
 20             if(stripos($data,'charset=utf-8',$charset_pos)) {
 21                 $data = iconv('utf-8','utf-8',$data);
 22             }else if(stripos($data,'charset=gb2312',$charset_pos)) {
 23                 $data = iconv('gb2312','utf-8',$data);
 24             }else if(stripos($data,'charset=gbk',$charset_pos)) {
 25                 $data = iconv('gbk','utf-8',$data);
 26             }
 27         }
 28 
 29         //匹配命中标签至数组$hits
 30         preg_match_all('/<'.$tag.'[^<]*?'.$tag_id.'/i',$data,$hits,PREG_OFFSET_CAPTURE);
 31         if(count($hits[0]) === 0) {                //未命中,直接返回
 32             return '没有匹配项!';
 33         }
 34 
 35         preg_match_all('/<'.$tag.'/i',$data,$pre_matches,PREG_OFFSET_CAPTURE);        //获取所有HTML标签前缀
 36         preg_match_all('/<\/'.$tag.'/i',$data,$suf_matches,PREG_OFFSET_CAPTURE);     //获取所有HTML标签后缀
 37 
 38         //判断是否<div></div>格式,是则添加结束标签,否则为false;  注:img、input等可能不是这种格式,此时$suf_matches[0]为空。
 39         if(!empty($suf_matches[0])) $endTag = '</'.$tag.'>';
 40         else $endTag = false;
 41         
 42         //合并所有HTML标签
 43         $htmltags = array();
 44         if($endTag !== false){
 45             foreach($pre_matches[0] as $index=>$pre_div){
 46                 $htmltags[(int)$pre_matches[0][$index][1]] = 'p';
 47                 $htmltags[(int)$suf_matches[0][$index][1]] = 's';
 48             }
 49         }else{
 50             foreach($pre_matches[0] as $index=>$pre_div){
 51                 //非<div></div>格式,获取前缀下标后的第一个>作为标签结束
 52                 $suf_matches[0][$index][1] = stripos($data,'>',$pre_matches[0][$index][1])+1;
 53                 
 54                 $htmltags[(int)$pre_matches[0][$index][1]] = 'p';
 55                 $htmltags[(int)$suf_matches[0][$index][1]] = 's';
 56             }
 57         }
 58         //对所有HTML标签按index进行排序
 59         $sort = array_keys($htmltags);
 60         asort($sort);
 61 
 62         //开始获取命中字符串
 63         $hitTagStrings = array();
 64         foreach($hits[0] as $hit){
 65             $hit = $hit[1];        //获取命中index
 66 
 67             $count = count($sort);    //循环控制,$count--避免无限循环
 68             foreach($pre_matches[0] as $index=>$pre_div){
 69                 //最后一个$pre_matches[0][$index+1]会造成数组出界,因此设置其index等于总长度
 70                 if(!isset($pre_matches[0][$index+1][1])) $pre_matches[0][$index+1][1] = strlen($data);
 71                 
 72                 //<div $hit <div+1    时div被命中
 73                 if(($pre_matches[0][$index][1] <= $hit) && ($hit < $pre_matches[0][$index+1][1])){
 74                     $deeper = 0;
 75                     //弹出被命中HTML标签前的所有HTML标签
 76                     while(array_shift($sort) != $pre_matches[0][$index][1] && ($count--)) continue;
 77                     //对剩余HTML标签进行匹配,若下一个为前缀(p),则向下一层,$deeper加1,
 78                     //否则后退一层,$deeper减1,$deeper为0则命中匹配结束标记,计算div长度
 79                     foreach($sort as $key){
 80                         if($htmltags[$key] == 'p') {    //进入子层
 81                             $deeper++;
 82                         }else if($deeper == 0) {        //碰到结束标记
 83                             $length = $key-$pre_matches[0][$index][1];        //长度等于结束标记index 减去 前缀index
 84                             break;
 85                         }else {                            //碰到子层结束标记
 86                             $deeper--;
 87                         }
 88                     }
 89                     $hitTagStrings[] = substr($data,$pre_matches[0][$index][1],$length).$endTag;
 90                     break;
 91                 }
 92             }
 93             //若只获取第一个匹配项,退出循环
 94             if($first && count($hitTagStrings) == 1) break;
 95         }
 96 
 97         return $hitTagStrings;
 98     }
 99     
100     //直接用例
101     var_dump(getWebTag('id="nav"','http://mail.163.com/html/mail_intro/','ul'));
102 
103     /*        //注释这句即可显示
104     //ajax请求用例,必要参数:dataType:'json',type:'POST'
105     $tag_id     =     urldecode($_POST['tag_id']);
106     $url        =    urldecode($_POST['url']);
107     $tag        =    isset($_POST['tag'])? urldecode($_POST['tag']) : 'div';
108     $data        =    urldecode($_POST['data']);
109     $first        =    (urldecode($_POST['first']) == 'checked')? true : false;
110     foreach($_POST as $key => $value){
111         if($value == 'EmPtYValue') $$key = false;
112     }
113     echo json_encode(getWebTag($tag_id,$url,$tag,$data,$first));
114     //*/
115 
116 //End_php

 

2.虚拟POST数据至远程服务器并获取返回数据

View Code
 1 <?php
 2 header("Content-type: text/html; charset=utf-8"); 
 3 /**
 4  * $url  web url
 5  * $post POST data
 6  * @example 
 7     $data = array (
 8      'type' => 'text',
 9      'inputValue' => '哈哈'
10     );
11     $result = Post('http://tool.anzhuoxiazai.com:80//servlet/QRServlet', $data);
12     echo str_replace("src='","src='http://tool.anzhuoxiazai.com/",$result);
13  */
14 function Post($url, $post = null) {
15  $context = array();
16  if (is_array($post)) {
17      ksort($post);
18      $context['http'] = array (
19          'timeout'=>60,
20          'method' => 'POST',
21          'content' => http_build_query($post)
22      );
23  }
24  return file_get_contents($url, false, stream_context_create($context));
25 }
26 
27 $data = array (
28  'type' => 'text',
29  'inputValue' => '哈哈'
30 );
31 $result = Post('http://tool.anzhuoxiazai.com:80//servlet/QRServlet', $data);
32 echo str_replace("src='","src='http://tool.anzhuoxiazai.com/",$result);
33 //End_php

 

3.文件夹复制

View Code
 1 /** 
 2      * Copy file or folder from source to destination, it can do 
 3      * recursive copy as well and is very smart 
 4      * It recursively creates the dest file or directory path if there weren't exists 
 5      * Situtaions : 
 6      * - Src:/home/test/file.txt ,Dst:/home/test/b ,Result:/home/test/b -> If source was file copy file.txt name with b as name to destination 
 7      * - Src:/home/test/file.txt ,Dst:/home/test/b/ ,Result:/home/test/b/file.txt -> If source was file Creates b directory if does not exsits and copy file.txt into it 
 8      * - Src:/home/test ,Dst:/home/ ,Result:/home/test/** -> If source was directory copy test directory and all of its content into dest      
 9      * - Src:/home/test/ ,Dst:/home/ ,Result:/home/**-> if source was direcotry copy its content to dest 
10      * - Src:/home/test ,Dst:/home/test2 ,Result:/home/test2/** -> if source was directoy copy it and its content to dest with test2 as name 
11      * - Src:/home/test/ ,Dst:/home/test2 ,Result:->/home/test2/** if source was directoy copy it and its content to dest with test2 as name 
12      * @todo 
13      *     - Should have rollback technique so it can undo the copy when it wasn't successful 
14      *  - Auto destination technique should be possible to turn off 
15      *  - Supporting callback function 
16      *  - May prevent some issues on shared enviroments : http://us3.php.net/umask 
17      * @param $source //file or folder 
18      * @param $dest ///file or folder 
19      * @param $options //folderPermission,filePermission 
20      * @return boolean 
21      */ 
22     function smartCopy($source, $dest, $options=array('folderPermission'=>0755,'filePermission'=>0755)) 
23     { 
24         $result=false; 
25         
26         if (is_file($source)) { 
27             if ($dest[strlen($dest)-1]=='/') { 
28                 if (!file_exists($dest)) { 
29                     cmfcDirectory::makeAll($dest,$options['folderPermission'],true); 
30                 } 
31                 $__dest=$dest."/".basename($source); 
32             } else { 
33                 $__dest=$dest; 
34             } 
35             $result=copy($source, $__dest); 
36             chmod($__dest,$options['filePermission']); 
37             
38         } elseif(is_dir($source)) { 
39             if ($dest[strlen($dest)-1]=='/') { 
40                 if ($source[strlen($source)-1]=='/') { 
41                     //Copy only contents 
42                 } else { 
43                     //Change parent itself and its contents 
44                     $dest=$dest.basename($source); 
45                     @mkdir($dest); 
46                     chmod($dest,$options['filePermission']); 
47                 } 
48             } else { 
49                 if ($source[strlen($source)-1]=='/') { 
50                     //Copy parent directory with new name and all its content 
51                     @mkdir($dest,$options['folderPermission']); 
52                     chmod($dest,$options['filePermission']); 
53                 } else { 
54                     //Copy parent directory with new name and all its content 
55                     @mkdir($dest,$options['folderPermission']); 
56                     chmod($dest,$options['filePermission']); 
57                 } 
58             } 
59 
60             $dirHandle=opendir($source); 
61             while($file=readdir($dirHandle)) 
62             { 
63                 if($file!="." && $file!="..") 
64                 { 
65                      if(!is_dir($source."/".$file)) { 
66                         $__dest=$dest."/".$file; 
67                     } else { 
68                         $__dest=$dest."/".$file; 
69                     } 
70                     //echo "$source/$file ||| $__dest<br />"; 
71                     $result=smartCopy($source."/".$file, $__dest, $options); 
72                 } 
73             } 
74             closedir($dirHandle); 
75             
76         } else { 
77             $result=false; 
78         } 
79         return $result; 
80     }

 

4.文件遍历(可匹配模式)

View Code
 1 /**
 2      * 遍历目录并获取所有目录即文件,以数组array('dirs'=>$dirs,'files'=>$files)方式返回。
 3      * @param $dir          //搜索目录
 4      * @param $pattern         // '*'搜索全部文件,可以智能匹配,如*.jpg 搜索jpg文件,*.{jpg,png}搜索jpg和png文件,区分大小写!!
 5      * @param $skip           //排除遍历文件,如"*.{jpg,png}"排除.jpg和.png类型文件
 6      * @param $subInclude   //默认遍历子目录,$subInclude设置为false则仅遍历当前目录
 7      * @param @flag            //glob函数的标记,有效标记如下:
 8             GLOB_MARK - 在每个返回的项目中加一个斜线 
 9             GLOB_NOSORT - 按照文件在目录中出现的原始顺序返回(不排序) 
10             GLOB_NOCHECK - 如果没有文件匹配则返回用于搜索的模式 
11             GLOB_NOESCAPE - 反斜线不转义元字符 
12             GLOB_BRACE - 扩充 {a,b,c} 来匹配 'a','b' 或 'c' 
13             GLOB_ONLYDIR - 仅返回与模式匹配的目录项 
14      */
15     function scandir_through($dir,$pattern='*',$skip=false,$subInclude=true,$flag=GLOB_BRACE){
16         $dirs = array();
17         $files = array();
18         //获取当前目录下所有文件及文件夹
19         $items  = glob($dir . '/*');
20 
21         //遍历所有项目,若设置$subInclude为true,则继续遍历子目录
22         for ($i = 0; $i < count($items); $i++) {
23             if ($subInclude && is_dir($items[$i])) {
24                 $dirs[] = iconv('gb2312','utf-8',$items[$i]);
25                 $add = glob($items[$i] . '/*');
26                 if($add === false) $add = array();
27                 $items = array_merge($items, $add);
28             }else {
29                 $slash = strrpos($items[$i],'/');
30                 $dir = substr($items[$i],0,$slash);
31                 //若当前文件匹配文件查找模式$pattern,则加入$files数组中
32                 if(in_array($items[$i],glob($dir.'/'.$pattern,$flag)) && (($skip===false) || !in_array($items[$i],glob($dir.'/'.$skip,$flag)))) {
33                     $items[$i] = iconv('gb2312','utf-8',$items[$i]);
34                     $file = substr($items[$i],$slash+1);
35                     $files[] = $items[$i];
36                 }
37             }
38         }
39         return array('dirs'=>$dirs,'files'=>$files);
40     }

 

5.zip压缩文件夹

View Code
 1 /**
 2  * 打包文件夹成zip文件函数
 3  * @param $path        //打包文件夹路径
 4  * @param $zip        //ZipArchive 对象
 5  */
 6 function addFileToZip($path, $zip) {
 7     $handler = opendir($path); //打开当前文件夹由$path指定。
 8     /*
 9     循环的读取文件夹下的所有文件和文件夹
10     其中$filename = readdir($handler)是每次循环的时候将读取的文件名赋值给$filename,
11     为了不陷于死循环,所以还要让$filename !== false。
12     一定要用!==,因为如果某个文件名如果叫'0',或者某些被系统认为是代表false,用!=就会停止循环
13     */
14     while (($filename = readdir($handler)) !== false) {
15         if ($filename != "." && $filename != "..") {//文件夹文件名字为'.'和‘..’,不要对他们进行操作
16             if (is_dir($path . "/" . $filename)) {// 如果读取的某个对象是文件夹,则递归
17                 addFileToZip($path . "/" . $filename, $zip);
18             } else { //将文件加入zip对象
19                 $zip->addFile($path . "/" . $filename);
20             }
21         }
22     }
23     @closedir($path);
24 }
25 //运用
26 $zip = new ZipArchive();
27 if ($zip->open('test.zip', ZipArchive::OVERWRITE) === TRUE) {
28     addFileToZip('./testdir', $zip); //调用方法,对要打包的根目录进行操作,并将ZipArchive的对象传递给方法
29     $zip->close(); //关闭处理的zip文件
30 }

 

 6.打印两个日期之间的日期

View Code
1 function prDates($start, $end) { 
2     //将ISO Date 转成 Timestamp
3     $dt_start = strtotime($start);
4     $dt_end   = strtotime($end);
5     do { 
6         //将 Timestamp 转成 ISO Date 输出
7         echo date('Y-m-d', $dt_start).PHP_EOL;
8     } while (($dt_start += 86400) <= $dt_end);    // 重复 Timestamp + 1 天(86400), 直至大于结束日期中止
9 }

 

 7.RC4加密算法

View Code
 1 /*
 2  * rc4加密算法,二次加密即可还原
 3  * $pwd 密钥
 4  * $data 要加密的数据
 5  */
 6 function rc4 ($pwd, $data)//$pwd密钥 $data需加密字符串
 7 {
 8     $key[] ="";
 9     $box[] ="";
10 
11     $pwd_length = strlen($pwd);
12     $data_length = strlen($data);
13 
14     for ($i = 0; $i < 256; $i++)
15     {
16         $key[$i] = ord($pwd[$i % $pwd_length]);
17         $box[$i] = $i;
18     }
19 
20     for ($j = $i = 0; $i < 256; $i++)
21     {
22         $j = ($j + $box[$i] + $key[$i]) % 256;
23         $tmp = $box[$i];
24         $box[$i] = $box[$j];
25         $box[$j] = $tmp;
26     }
27 
28     for ($a = $j = $i = 0; $i < $data_length; $i++)
29     {
30         $a = ($a + 1) % 256;
31         $j = ($j + $box[$a]) % 256;
32 
33         $tmp = $box[$a];
34         $box[$a] = $box[$j];
35         $box[$j] = $tmp;
36 
37         $k = $box[(($box[$a] + $box[$j]) % 256)];
38         $cipher .= chr(ord($data[$i]) ^ $k);
39     }
40     
41     return $cipher;
42 }

 

 8.utf8_substr UTF8编码字符串截取,解决中英文混杂截取

View Code
 1 /**
 2   * $sting                         输入字符串
 3   * $start                         截取起始位,默认为0
 4   * $length                        截取长度,中英文长度都为1,默认为'',跟输入负数一样截取至字符串结束。
 5   * [\x00-\x7F]                    匹配英文字符
 6   * [\xC0-\xFF][\x80-\xBF]+        匹配中文字符
 7   * 模式修正符s                     将换行当成普通字符,此时.*能匹配包括换行任意字符
 8   */
 9  function utf8_substr($string, $start=0, $length=''){
10      return preg_replace('#^(?:[\x00-\x7F]|[\xC0-\xFF][\x80-\xBF]+){0,'.$start.'}'
11      .'((?:[\x00-\x7F]|[\xC0-\xFF][\x80-\xBF]+){0,'.$length.'}).*#s','$1',$string);
12  }

 

9.创建透明图片

$image = imagecreatetruecolor(300,300); 
$transparent = imagecolorallocatealpha($image, 255, 255, 255,127);    //创建透明背景色 
imagecolortransparent($img, $transparent);
imagefill($image, 0, 0, $transparent); //填充透明背景色
View Code

 

 10.图片灰白化

 1 <?php
 2 /**
 3  * 图片黑白处理
 4  * @params     $file          图片地址
 5  * @params    $output     直接输出
 6  * @params    $newFile    保存黑白图片
 7  * @usage
 8  1、imageGray('test.png');
 9  2、imageGray('test.png',false,'test_gray.png');
10  */
11 function imageGray($file,$output=true,$newFile=false){
12     if(preg_match('#\.(jpg|png|jpeg|gif)$#i',$file,$match)){
13         //不同类型图片读取函数
14         $create_function = 'imagecreatefrom'.$match[1];
15         //根据不同类型图片创建图片
16         $im = $create_function($file);
17         
18         //过滤成灰色图片
19         if($im) imagefilter($im, IMG_FILTER_GRAYSCALE);
20         
21         //不同类型图片写入函数
22         $image_function = 'image'.$match[1];
23         //输出到浏览器端
24         if ($output) {
25             header ("Content-type: image/".$match[1]);
26             $image_function($im);
27         }
28         //保存黑白照片
29         if($newFile) {
30             $file = $newFile;
31             $image_function($im,$file);
32         }
33         //删除图片资源
34         imagedestroy($im);
35     }
36     return $file;
37 }
38 ?> 
View Code

 

 11.域名授权认证

 1 function checkAuthenticated()
 2 {    
 3     //合法域名数组
 4     $domain_array = array(
 5         base64_encode(base64_encode('127.0.0.1')),
 6         base64_encode(base64_encode('localhost')),
 7         base64_encode(base64_encode('test.com')),
 8         base64_encode(base64_encode('*.test.com')),
 9     );
10     //对域名数组系列化并进行base64编码,为了安全,做了拼接处理,防止被直接解编码反系列化获取结果
11     $str = base64_encode(base64_encode(serialize($domain_array))."|".serialize($domain_array));
12     //解编码,分离拼接
13     $arr = explode("|",base64_decode($str));
14     //获取数据系列化部分,反系列化得到域名数组
15     $arr = unserialize($arr[1]);
16     //遍历域名数组,解编码获取域名
17     foreach($arr as $k=>$v)
18     {
19         $arr[$k] = base64_decode(base64_decode($v));
20     }
21     //获取当前URL的host地址
22     $host = $_SERVER['HTTP_HOST'];
23     //host:端口 分离
24     $host = explode(":",$host);
25     //去除端口部分
26     $host = $host[0];
27     //认证通过标志,默认未通过认证
28     $passed = false;
29     //遍历域名数组
30     foreach($arr as $k=>$v)
31     {
32         //带通配子域名情况,使用preg_match进行匹配检测
33         if(substr($v,0,2)=='*.')
34         {
35             $preg_str = substr($v,2);    //去掉通配部分
36             if(preg_match("/".$preg_str."$/",$host)>0)    //preg_match('/test.com$/','www.test.com') ,$preg_str中的.可匹配任意字符,包括.
37             {
38                 $passed = true;        //匹配通过,退出循环
39                 break;
40             }
41         }
42     }
43     if(!$passed)        //标志为假,因为foreach中为判断非通配域名(test.com),因此还需要进行一次in_array判断
44     {
45         if(!in_array($host,$arr))
46         {
47             return false;
48         }
49     }
50     return true;
51 }
View Code

 

12.获取文件权限值

1 function getChmod($filepath){
2     return substr(base_convert(@fileperms($filepath),10,8),-4);
3 }

 

13.数组不定长多键值排序

 1 <?php
 2 /**
 3  * PHP数组不定长多键值排序
 4  *
 5  * @param array $list     数据源
 6  * @param array $rules    排序规则 ['key1'=>'asc', 'key2' => 'desc', ...]
 7  * @return array
 8  */
 9 function smartMultiSort($list, $rules) {
10     $multisortParams = [];
11     foreach($rules as $key => $sort) {
12         $multisortParams[$key] = [];
13         $multisortParams[$key . $sort] = constant(strtoupper("sort_{$sort}"));
14     }
15     foreach($list as $item) {
16         foreach($rules as $key => $sort) {
17             $multisortParams[$key][] = $item[$key];
18         }
19     }
20     $multisortParams[] = &$list;
21 
22     call_user_func_array('array_multisort', $multisortParams);
23     return array_pop($multisortParams);
24 }
25 
26 //示例
27 $list = array ();
28 $list [] = array (
29         'id' => 1,
30         'name' => '学生1',
31         'school' => '学校1',
32         'class' => '班级1'
33 );
34 $list [] = array (
35         'id' => 4,
36         'name' => '学生4',
37         'school' => '学校2',
38         'class' => '班级2'
39 );
40 $list [] = array (
41         'id' => 3,
42         'name' => '学生3',
43         'school' => '学校2',
44         'class' => '班级1'
45 );
46 $list [] = array (
47         'id' => 2,
48         'name' => '学生2',
49         'school' => '学校1',
50         'class' => '班级2'
51 );
52 $list [] = array (
53         'id' => 5,
54         'name' => '学生5',
55         'school' => '学校2',
56         'class' => '班级3'
57 );
58 print_r(smartMultiSort($list, ['school' => 'desc','id' => 'asc']));
View Code

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/403675.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

JS prototype作用

prototype可查看原型属性&#xff0c;还可对原型添加属性或方法 function Car(name) {this.name name;this.run function () {console.log(this.heightcm this.name is run!)}}var dazhong new Car(dazhong);Car.prototype.height null; //给对象添加新属性…

高性能并发TCP网络服务-IOCP框架修正VC2008版本

From: http://blog.csdn.net/lsfa1234/article/details/6223635 高性能并发TCP网络服务IOCP框架修正VC2008版本 从Source Code里可发现&#xff0c;此工程整合的epoll&#xff0c;iocp及kqueue三种模型&#xff0c;应该是非常有用的一个东东&#xff08;如果ACE能够把它的那些…

解决uni-app小程序图片转base64;微信小程序上传图片转base64;

base64转微信小程序图片 点击看这篇 以下是小程序图片转base64&#xff1a; uni.chooseImage({count: 6, //默认9sizeType: [original, compressed], //可以指定是原图还是压缩图&#xff0c;默认二者都有sourceType: [album], //从相册选择success: function (res) {console…

java中byte转换int时为何与0xff进行与运算

另一篇分析如下&#xff1a; byte为什么要与上0xff&#xff1f; 在剖析该问题前请看如下代码 public static String bytes2HexString(byte[] b) {String ret "";for (int i 0; i < b.length; i) {String hex Integer.toHexString(b[ i ] & 0xFF);if (hex.l…

element 增加自由验证

<el-form-item label"社会统一信用代码" prop"socialCode"><el-input v-model"ruleForm.socialCode"></el-input></el-form-item> 主要是validator返回的是对象 rules: {socialCode: [ //社会统一信用代码{requir…

ADempiere 360LTS 地址(Address)的中国格式定制

地址(Address)的中国格式定制AD里面设置合作伙伴&#xff0c;仓库等需要输入地址的地方&#xff0c;目前都是按照美国的习惯&#xff0c;即使国家选择了中国&#xff0c;还是不符合国内习惯&#xff0c;下面通过配置可使地址按照&#xff1a;省、市、详细地址的格式显示1) 国家…

git 配置免密登陆

SSH免密码登录配置 注意&#xff1a;这些命令需要在git bash here中敲 注意先配置好账户名和邮箱 # git config user.name zhangsan # git config user.email zhangsanqq.com # 使用–global参数&#xff0c;配置全局的用户名和邮箱&#xff0c;只需要配置一次即可。推荐配置…

ASP.NET MVC URL重写与优化(初级篇)-使用Global路由表定制URL

ASP.NET MVC URL重写与优化(初级篇)-使用Global路由表定制URL 引言--- 在现今搜索引擎制霸天下的时代&#xff0c;我们不得不做一些东西来讨好爬虫&#xff0c;进而提示网站的排名来博得一个看得过去的流量。 URL重写与优化就是搜索引擎优化的手段之一。 假如某手机网站(基于AS…

js splice

splice(删除数组第几个,删除几个数据) splice(从第几个新增,如果设置为 0&#xff0c;则不会删除项目。,新增的对象)

PHP autoload实践

本文目的 本文简要的描述了PHP提供的autoload机制&#xff0c;以及在scake中使用实践。用于减少不必要的文件包含&#xff0c;提高php系统性能。 什么是__autoload php是脚本语言&#xff0c;不同于c只需要编译一次&#xff0c;php每次执行过程中都需要编译&#xff0c;所以…

mac无法ssh localhost

From: http://www.2cto.com/os/201203/123274.html mac 无法ssh localhost&#xff0c;错误提示&#xff1a;bash: /usr/local/bin/ssh_session: Permission denied 在网上找了很久也没有找到解决方案&#xff0c;最后根据提示自己摸索如下&#xff1a; 1.编辑/etc/sshd_confi…

文件加密及解密openssl

Openssl是一个开源的用以实现SSL协议的产品&#xff0c;它主要包括了三个部分&#xff1a;密码算法库、应用程序、SSL协议库。Openssl实现了SSL协议所需要的大多数算法。 下面我将单介绍使用Openssl进行文件的对称加密操作。 一、Openssl支持的加密算法有&#xff1a; -aes-128…

el-select回显

<el-select style"width:162px;" change"aaa" v-model"searchObj.id" placeholder"请选择"><el-option v-for"item in optionsId" :key"item.value" :label"item.value" :value"item.lab…

i标签content属性输入空白

content: \20; 表示里面有值&#xff0c;你可以随便操作了

Mac OS X下查看CPU信息

From: http://forum.51nb.com/tid698668 在终端输入&#xff1a;sysctl -a | grep ".cpu." 以下是我的电脑的输出信息: hw.ncpu: 8 hw.activecpu: 8 hw.physicalcpu: 4 hw.physicalcpu_max: 4 hw.logicalcpu: 8 hw.logicalcpu_max: 8 hw.cputype: 7 hw.cpusubtype:…

MS SQLSERVER 各种乱七八糟

2019独角兽企业重金招聘Python工程师标准>>> 这个是看完了sql语法的一点个人练手&#xff0c;没什么价值&#xff0c;权且当做记录 select employee_id,dept_code,last_name,manager_id from l_employees where last_name like %e%--%代表任意字符串 order by dept_…

第二阶段团队项目冲刺第三天

1.&#xff08;昨天干了什么&#xff09; 昨天基本将我们网站的框架搭建起来了&#xff0c;但是还是有很多的不完善&#xff0c;并没有达到我想要的效果。 2.&#xff08;今天准备干什么&#xff09; 今天计划完善我们的网站框架&#xff0c;添加一些一般网站都有的按钮、快捷方…

uni-app阻止事件冒泡

<!-- #ifdef MP-WEIXIN --><uni-icons v-if"key_word" tap.stop"closeInput(e)" class"input-uni-icon" type"closeempty" size"22" color"#ccc" /><!-- #endif -->注意&#xff1a;事件必须要…

[C++11 std::thread] 使用C++11 编写 Linux 多线程程序

From: http://www.ibm.com/developerworks/cn/linux/1412_zhupx_thread/index.html 本文讲述了如何使用 C11 编写 Linux 下的多线程程序&#xff0c;如何使用锁&#xff0c;以及相关的注意事项&#xff0c;还简述了 C11 引入的一些高级概念如 promise/future 等。 前言 在这个…

div 背景图 居中

这里主要是 background-position: center;属性很给力 div{width: 100%;height: 100%;background-image: url(../../../assets/initialize.png);background-repeat: no-repeat;background-size:70px 70px;background-position: center;}