range

If there were you, the world would be just right

1.xml转数组

function xmlToArray( $xml )
{
    if ( !$xml ) {
        return false;
    }
    //禁止引用外部xml实体
    libxml_disable_entity_loader(true);
    // 将XML转为array
    $data = json_decode( json_encode( simplexml_load_string( $xml, 'SimpleXMLElement', LIBXML_NOCDATA ) ), true );
    return $data;
}

2.数组转xml

function array_toxml($array)
{
    if (!is_array($array) || count($array) <= 0) {
        return false;
    }

    $xml = "<xml>";
    foreach ($array as $key => $val) {
        if (is_numeric($val)) {
            $xml .= "<" . $key . ">" . $val . "</" . $key . ">";
        } else {
            $xml .= "<" . $key . "><![CDATA[" . $val . "]]></" . $key . ">";
        }
    }
    $xml .= "</xml>";
    return $xml;
}

1. nginx介绍与安装

1.1 nginx介绍

Nginx (engine x) 是一个高性能的HTTP和反向代理web服务器,Nginx是一款轻量级的Web 服务器/反向代理服 务器及电子邮件(IMAP/POP3)代理服务器,在BSD-like 协议下发行。其特点是占有内存少,并发能力强,事实上nginx的并发能力在同类型的网页服务器中表现较好,中国大陆使用nginx网站用户有:百度、京东、新浪、网易、腾讯、淘宝等。

反向代理

反向代理服务器位于用户与目标服务器之间,但是对于用户而言,反向代理服务器就相当于目标服务器,即用户直接访问反向代理服务器就可以获得目标服务器的资源。同时,用户不需要知道目标服务器的地址,也无须在用户端作任何设定。反向代理服务器通常可用来作为Web加速,即使用反向代理作为Web服务器的前置机来降低网络和服务器的负载,提高访问效率。

负载均衡

负载均衡(Load Balance)其意思就是分摊到多个操作单元上进行执行,例如Web服务器、FTP服务器、企业关键应用服务器和其它关键任务服务器等,从而共同完成工作任务。

单个服务器解决不了,我们增加服务器的数量,然后将请求分发到各个服务器上面,将原先请求到单个服务器上面的情况改为将请求分发到多个服务器上,将负载分发到不同的服务器,这就是所说的负载均衡。

动静分离

为了加快网站的解析速度,可以把动态页面和静态页面由不同的服务器来解析,加快解析速度,降低单个服务器的压力。

1.2 nginx安装

1.2.1 nginx安装

nginx可以使用各平台的默认包来安装,这里介绍使用源码编译安装,包括具体的编译参数信息。

安装前的准备

安装make:

yum install gcc automake autoconf libtool make

安装g++

yum install gcc gcc-c++

阅读剩余部分...


1 临时设置 sql_mode

set global sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION';

无限级应用场景:下拉列表,树型列表等

多种实现方式

第一种(推荐)

function infiniteSort($data, $showFName, $titleFName, $pidFName = 'pid', $idFName = 'id', $levelFName = 'level', $pid = 0, $level = 0)
{
    $tree = array();

    foreach ($data as $key => $value) {

        if ($value[$pidFName] == $pid) {
            $value[$levelFName] = $level;
            $value[$showFName] = str_repeat('&nbsp;&nbsp;', $level) . '|-' . $value[$titleFName];
            $tree[] = $value;
            unset($data[$key]);
            $tempArr = infiniteSort($data, $showFName, $titleFName, $pidFName, $idFName, $level, $value[$idFName], $level + 1);
            if(!empty($tempArr)){
                $tree = array_merge($tree, $tempArr);
            }
        }

    }

    return $tree;
}
注意:
1、$data 已经asc排序过的所有数据
2、$showFName 显示名字的字段名(格式化过的)
3、$titleFName 标题的字段名(无格式化)
4、$levelFName 层级字段名
5、$pidFName 父id的字段名
6、$idFName id的字段名

第二种(使用引用变量)

/**
 * 无限级分类
 * @param Array $treeList //接受处理完成数据的数组
 * @param Array $data //数据库里获取的结果集
 * @param String $level //格式化层级字段名
 * @param Int $pid
 * @param Int $count //第几级分类
 */
function tree(&$treeList, &$data, $level, $show_name, $field_name, $field_pid = 'pid', $field_id = 'id', $pid = 0, $count = 0)
{
    foreach ($data as $key => $value) {

        if ($value[$field_pid] == $pid) {
            $value[$level] = $count;
            $value[$show_name] = str_repeat('&nbsp;&nbsp;&nbsp;&nbsp;',$count).'|-'.$value[$field_name];
            $treeList[] = $value;
            unset($data[$key]);
            tree($treeList, $data, $level, $show_name, $field_name,$field_pid, $field_id, $value[$field_id], $count+1);
        }

    }
}
注意:
1、$data 已经asc排序过的所有数据
2、返回的无限级列表数据都存在$treeList里面

第三种(使用静态变量有限制:如果一次请求调用两次来实现2个无限级分类就会出现问题,所以不推荐)

public function getTree($list, $parent_id, $level=0) {
    //应该是静态的局部变量,这样才能保证,在递归调用时,所有
    //的getTree方法,操作的是一个Tree空间。
    static $tree = array();//保存找到的分类的数组
    //遍历所有分类,通过parent_id判断,哪些是我们正在查找的
    foreach($list as $row) {
        //判断当前所遍历的分类$row, 是否是当前需要查找的子分类
        if($row['pid'] == $parent_id) {
            //找到了一个分类
            //存起来,存哪?
            $row['level'] = $level;
            $tree[] = $row;
            //继续查找当前$row所代表的分类的子分类
            $this->getTree($list, $row['id'], $level+1);
        }
    }
    return $tree;
}
注意:
1、$list 已经asc排序过的所有数据

location / {
    add_header Access-Control-Allow-Origin *;
    add_header Access-Control-Allow-Methods 'GET, POST, OPTIONS';
    add_header Access-Control-Allow-Headers 'DNT,Keep-Alive,User-Agent,Cache-Control,Content-Type,Authorization';

    if ($request_method = 'OPTIONS') {
        return 204;
    }
}