PHP unlimited classification (tree class)_PHP tutorial
//模拟PHP无限分类查询结果
return array(
array(
'id'=>1,
'pid'=>0,
'name'=>'主页'
),
array(
'id'=>2,
'pid'=>0,
'name'=>'新闻'
),
array(
'id'=>3,
'pid'=>0,
'name'=>'媒体'
),
array(
'id'=>4,
'pid'=>0,
'name'=>'下载'
),
array(
'id'=>5,
'pid'=>0,
'name'=>'关于我们'
),
array(
'id'=>6,
'pid'=>2,
'name'=>'天朝新闻'
),
array(
'id'=>7,
'pid'=>2,
'name'=>'海外新闻'
),
array(
'id'=>8,
'pid'=>6,
'name'=>'州官新闻'
),
array(
'id'=>9,
'pid'=>3,
'name'=>'音乐'
),
array(
'id'=>10,
'pid'=>3,
'name'=>'电影'
),
array(
'id'=>11,
'pid'=>3,
'name'=>'小说'
),
array(
'id'=>12,
'pid'=>9,
'name'=>'铃声'
),
array(
'id'=>13,
'pid'=>9,
'name'=>'流行音乐'
),
array(
'id'=>14,
'pid'=>9,
'name'=>'古典音乐'
),
array(
'id'=>15,
'pid'=>12,
'name'=>'热门铃声'
),
array(
'id'=>16,
'pid'=>12,
'name'=>'搞笑铃声'
),
array(
'id'=>17,
'pid'=>12,
'name'=>'MP3铃声'
),
array(
'id'=>18,
'pid'=>17,
'name'=>'128K'
),
array(
'id'=>19,
'pid'=>8,
'name'=>'娱乐新闻'
),
array(
'id'=>20,
;21,
'pid'=>11,
'name'=>'Martial Arts'
),
);
?>
It’s popular, but the infinite categories of class-related operations provided by those articles are a bit frustrating, and the database operations are also directly encapsulated. In other words, if other people want to use your class, they also have to build the same table as you. It's really disgusting. Since the project will use it, I wrote a PHP infinite classification class (also called a tree class). There is no database operation. I only need to pass in the result set, which is a tree array, when instantiating it. Then execute the leaf method or navi method to get the desired result. Please see the source code below. After reading it, I will provide the corresponding template recursive method of the smarty template engine.
/**
* Tree tree class (unlimited classification)
*
* @author Kvoid
* @copyright http://kvoid.com
* @version 1.0
* @access public
* @example
* $tree= new Tree($result);
* $arr=$tree->leaf(0);
* $nav=$tree->navi (15);
*/
class Tree {
private $result;
private $tmp;
private $arr;
private $already = array();
/**
* Constructor
*
* @param array $result Tree data table result set
* @param array $fields Tree data table fields, array (category id, parent id)
* @param integer $root The parent id of the top category
*/
public function __construct($result, $fields = array('id', 'pid'), $root = 0) {
$this->result = $result;
$this->fields = $fields;
$this->root = $root;
$this->handler();
}
/**
* Tree data table result set processing
*/
private function handler() {
foreach ($this->result as $node) {
$tmp[$node[$this->fields[1]]][] = $node;
}
krsort($tmp);
for ($i = count($tmp); $i > 0; $i--) {
foreach ($tmp as $k => $v) {
if (!in_array($k, $this->already)) {
if (!$this->tmp) {
$this->tmp = array($k, $v);
$this->already[] = $k;
continue;
} else {
foreach ($v as $key => $value) {
if ($value[$this->fields[0]] == $this->tmp[0]) {
$tmp[$k][$key]['child'] = $this->tmp[1];
$this->tmp = array($k, $tmp[$k]);
}
}
}
}
}
$this->tmp = null;
}
$this->tmp = $tmp;
}
/**
* Reverse recursion
*/
private function recur_n($arr, $id) {
foreach ($arr as $v) {
if ($v[$this->fields[0]] == $id) {
$this->arr[] = $v;
if ($v[$this->fields[1]] != $this->root) $this->recur_n($arr, $v[$this->fields[1]]);
}
}
}
/**
* Forward recursion
*/
private function recur_p($arr) {
foreach ($arr as $v) {
$this->arr[] = $v[$this->fields[0]];
if ($v['child']) $this->recur_p($v['child']);
}
}
/**
* Menu multi-dimensional array
*
* @param integer $id category id
* @return array Returns the branch, and returns the entire tree by default
*/
public function leaf($id = null) {
$id = ($id == null) ? $this->root : $id;
return $this->tmp[$id];
}
/**
* Navigation one-dimensional array
*
* @param integer $id category id
* @return array Returns single-line classification until the top category
*/
public function navi($id) {
$this->arr = null;
$this->recur_n($this->result, $id);
krsort($this->arr);
return $this->arr;
}
/**
* Scattered one-dimensional array
*
* @param integer $id category id
* @return array Returns all category ids under leaf
*/
public function leafid($id) {
$this->arr = null;
$this->arr[] = $id;
$this->recur_p($this->leaf($id));
return $this->arr;
}
}
?>
在smarty中的PHP无限分类的使用方法:
$result=$db->query(……);//这里查询得到结果集,注意结果集为数组
$tree= new Tree($result);
$arr=$tree->leaf(0);
$nav=$tree->navi(15);
$smarty->assign(‘arr',$arr);
$smarty->assign(‘nav',$nav);
$smarty->display(‘test.html');
在smarty模板中这样递归:
转载请申明来自kvoid.com
当然,你也可以更改递归方法,用你想的标签不受拘束。HTML+PHP混编的递归方法这里就不贴了,我也懒得写,最讨厌混编,看着恶心,在这里推荐一下jake前辈的SpeedPHP框架,由于默认的引擎是smarty,我的这个PHP无限分类完全兼容SP框架。同样的,jquery的treeview插件和下拉菜单插件也完美支持。
对了,建议使用Smarty强大的缓存功能,缓存才是王道。

Absolute session timeout starts at the time of session creation, while an idle session timeout starts at the time of user's no operation. Absolute session timeout is suitable for scenarios where strict control of the session life cycle is required, such as financial applications; idle session timeout is suitable for applications that want users to keep their session active for a long time, such as social media.

The server session failure can be solved through the following steps: 1. Check the server configuration to ensure that the session is set correctly. 2. Verify client cookies, confirm that the browser supports it and send it correctly. 3. Check session storage services, such as Redis, to ensure that they are running normally. 4. Review the application code to ensure the correct session logic. Through these steps, conversation problems can be effectively diagnosed and repaired and user experience can be improved.

session_start()iscrucialinPHPformanagingusersessions.1)Itinitiatesanewsessionifnoneexists,2)resumesanexistingsession,and3)setsasessioncookieforcontinuityacrossrequests,enablingapplicationslikeuserauthenticationandpersonalizedcontent.

Setting the httponly flag is crucial for session cookies because it can effectively prevent XSS attacks and protect user session information. Specifically, 1) the httponly flag prevents JavaScript from accessing cookies, 2) the flag can be set through setcookies and make_response in PHP and Flask, 3) Although it cannot be prevented from all attacks, it should be part of the overall security policy.

PHPsessionssolvetheproblemofmaintainingstateacrossmultipleHTTPrequestsbystoringdataontheserverandassociatingitwithauniquesessionID.1)Theystoredataserver-side,typicallyinfilesordatabases,anduseasessionIDstoredinacookietoretrievedata.2)Sessionsenhances

PHPsessionscanstorestrings,numbers,arrays,andobjects.1.Strings:textdatalikeusernames.2.Numbers:integersorfloatsforcounters.3.Arrays:listslikeshoppingcarts.4.Objects:complexstructuresthatareserialized.

TostartaPHPsession,usesession_start()atthescript'sbeginning.1)Placeitbeforeanyoutputtosetthesessioncookie.2)Usesessionsforuserdatalikeloginstatusorshoppingcarts.3)RegeneratesessionIDstopreventfixationattacks.4)Considerusingadatabaseforsessionstoragei

Session regeneration refers to generating a new session ID and invalidating the old ID when the user performs sensitive operations in case of session fixed attacks. The implementation steps include: 1. Detect sensitive operations, 2. Generate new session ID, 3. Destroy old session ID, 4. Update user-side session information.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Dreamweaver CS6
Visual web development tools

PhpStorm Mac version
The latest (2018.2.1) professional PHP integrated development tool

WebStorm Mac version
Useful JavaScript development tools

Notepad++7.3.1
Easy-to-use and free code editor

Atom editor mac version download
The most popular open source editor
