개발 프로젝트에서 백엔드 인피니투스 메뉴 표시는 불가피하며 매우 일반적입니다. 일반적으로 배경 메뉴는 2단계, 최대 3단계로 나누어지지만, 여러 단계가 있을 수도 있습니다. 오늘은 인피니터스 메뉴 구현 과정을 기록해보겠습니다.
여기서 수행되는 작업은 역할 기반 액세스 제어입니다. RBAC에서는 권한이 역할과 연결되며 사용자는 적절한 역할의 구성원이 되어 이러한 역할의 권한을 얻습니다. 이는 권한 관리를 크게 단순화합니다. 조직에서는 다양한 작업을 완료하기 위해 역할이 생성되고 사용자에게는 책임과 자격에 따라 해당 역할이 할당됩니다. 사용자는 한 역할에서 다른 역할로 쉽게 할당될 수 있습니다. 새로운 요구 사항 및 시스템 통합을 기반으로 역할에 새 권한을 부여할 수 있으며 필요에 따라 역할에서 권한을 회수할 수도 있습니다. 캐릭터 대 캐릭터 관계는 더 넓은 범위의 객관적인 상황을 포괄하도록 설정될 수 있습니다.
먼저 다음 테이블 구조를 소개합니다.
CREATE TABLE `sp_auth` (
`auth_id` smallint(5) unsigned NOT NULL AUTO_INCREMENT,
`auth_name` varchar(30) NOT NULL COMMENT '기관 이름',
`action_name` varchar( 30) NOT NULL COMMENT '권한 코드',
`desc` varchar(120) NOT NULL DEFAULT '' COMMENT '권한 설명',
`pid` smallint(5) unsigned NOT NULL DEFAULT '0' COMMENT ' 상위 권한 ID',
`sort_id` smallint(5) unsigned NOT NULL DEFAULT '0' COMMENT '권한 정렬 값',
`add_time` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '시간 추가 ',
`update_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '업데이트 시간',
`is_delete`tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '삭제 여부(0 삭제 안함 | 1) 삭제됨)',
기본 키(`auth_id`),
고유 키 `action_name`(`action_name`),
KEY `pid`(`pid`),
KEY `add_time` ( `add_time`),
KEY `is_delete`(`is_delete`),
KEY `controller_name`(`controller_name`(6)),
KEY `auth_name`(`auth_name`(16)) ,
KEY `sort_id` (`sort_id`)
) ENGINE=MyISAM AUTO_INCREMENT=113 DEFAULT CHARSET=utf8 COMMENT='권한 테이블';
처리방법 :
//打印无限极树形结构菜单展示<br> function _reSorts($data, $pid=0)<br> {<br> $ret = array();<br> foreach ($data as $k => $v) {<br> if($v['pid'] == $pid) {<br> $v['children'] = _reSorts($data, $v['auth_id']);<br> $ret[] = $v;<br> }<br> }<br> return $ret;<br> }<br>//打印二级菜单的方法
function getMenuShow($data)<br>{<br> $ret = array();<br> if (!is_array($data)) {<br> return false;<br> }<br> foreach ($data as $key => $val) {<br> if ($val['pid'] == 0) {<br> //再次遍历,将第二级别的放在作为其子菜单<br> foreach ($data as $k => $v) {<br> if ($v['pid'] == $val['auth_id']) {<br> $val['children'][] = $v;<br> }<br> }<br> $ret[] = $val;<br> }<br> }<br> return $ret;<br>}
이렇게 하면 표시된 메뉴 데이터를 얻을 수 있습니다.