[정보] 관리자 및 회원의 페이지 접근 권한 간단구현
관리자 및 회원별로 각 메뉴별로 접근가능한 권한을 설정하는 간단한 구현방법입니다.
우선 사용자별로 접근가능한 메뉴별 코드를 "/"을 구분자로 불러온 뒤
현재페이지의 접근코드와 비교해서 퍼미션을 주는 방식입니다.
이것의 간편한점은 DB나 이런것이 않쓰이기 때문에 이미 구현된 홈페이지에
간단하게 퍼미션파일만 인크루드시키면 권한설정이 끝납니다.
간단한 로직이니 보시면 아실듯하네요. 그냥 간단하게 권한설정 기능을 주실분들은
사용해봐도 좋을듯 합니다. ^^;;
<?
$strSQL = "SELECT perpage FROM TBmanager WHERE no='$managerNo'";
$resultArray = $conn->fetchArray($strSQL)
if($conn->numRows())
{
$arrpercode = explode("/", $resultArray[perpage]);
$arrcnt = count($arrpercode) - 1;
}
else
{
alertBox("로그인 하세요.", "location.href='/otsuni/manager/'");
exit;
}
// 부운영자일 경우 권한 체크
if($managerPermission != "1")
{
// 일단은 접근권한이 없음
$ispermission = 0;
// 누구나 접근 가능한 페이지 설정
$anypage[0] = "/otsuni/manager/index.php";
$anypage[1] = "/otsuni/manager/loginpost.php";
$anypage[2] = "/otsuni/manager/logout.php";
// 현재페이지가 누구나 접근가능한 페이지인지 판단
for($i=0; $i<=2; $i++)
{
if($anypage[$i] == $PHP_SELF)
{
$ispermission = 1;
break;
}
}
// 누구나 접근 가능한 페이지가 아닐 경우의 권한 체크
if($ispermission)
{
$perpage[0] = "/otsuni/manager/company/list.php"; $percode[0] = "001";
$perpage[1] = "/otsuni/manager/company/add.php"; $percode[1] = "010";
$perpage[2] = "/otsuni/manager/company/addpost.php"; $percode[2] = "010";
$perpage[3] = "/otsuni/manager/company/edit.php"; $percode[3] = "010";
$perpage[4] = "/otsuni/manager/company/editpost.php"; $percode[4] = "010";
// 현재페이지의 페이지코드 찾기
for($i=0; $i<=4; $i++)
{
if($perpage[$i] == $PHP_SELF)
{
$currpercode = $percode[$i];
break;
}
}
// 현재페이지코드와 관리자의 접근페이지코드가 일치하는지 판단
for($i=0; $i<$arrcnt; $i++)
{
if($arrpercode[$i] == $currpercode)
{
$ispermission = 1;
break;
}
}
}
// 이 페이지에 대한 접근권한 없음
if(!$ispermission)
{
alertBox("사용권한이 없습니다", "history.back();");
exit;
}
}
?>
우선 사용자별로 접근가능한 메뉴별 코드를 "/"을 구분자로 불러온 뒤
현재페이지의 접근코드와 비교해서 퍼미션을 주는 방식입니다.
이것의 간편한점은 DB나 이런것이 않쓰이기 때문에 이미 구현된 홈페이지에
간단하게 퍼미션파일만 인크루드시키면 권한설정이 끝납니다.
간단한 로직이니 보시면 아실듯하네요. 그냥 간단하게 권한설정 기능을 주실분들은
사용해봐도 좋을듯 합니다. ^^;;
<?
$strSQL = "SELECT perpage FROM TBmanager WHERE no='$managerNo'";
$resultArray = $conn->fetchArray($strSQL)
if($conn->numRows())
{
$arrpercode = explode("/", $resultArray[perpage]);
$arrcnt = count($arrpercode) - 1;
}
else
{
alertBox("로그인 하세요.", "location.href='/otsuni/manager/'");
exit;
}
// 부운영자일 경우 권한 체크
if($managerPermission != "1")
{
// 일단은 접근권한이 없음
$ispermission = 0;
// 누구나 접근 가능한 페이지 설정
$anypage[0] = "/otsuni/manager/index.php";
$anypage[1] = "/otsuni/manager/loginpost.php";
$anypage[2] = "/otsuni/manager/logout.php";
// 현재페이지가 누구나 접근가능한 페이지인지 판단
for($i=0; $i<=2; $i++)
{
if($anypage[$i] == $PHP_SELF)
{
$ispermission = 1;
break;
}
}
// 누구나 접근 가능한 페이지가 아닐 경우의 권한 체크
if($ispermission)
{
$perpage[0] = "/otsuni/manager/company/list.php"; $percode[0] = "001";
$perpage[1] = "/otsuni/manager/company/add.php"; $percode[1] = "010";
$perpage[2] = "/otsuni/manager/company/addpost.php"; $percode[2] = "010";
$perpage[3] = "/otsuni/manager/company/edit.php"; $percode[3] = "010";
$perpage[4] = "/otsuni/manager/company/editpost.php"; $percode[4] = "010";
// 현재페이지의 페이지코드 찾기
for($i=0; $i<=4; $i++)
{
if($perpage[$i] == $PHP_SELF)
{
$currpercode = $percode[$i];
break;
}
}
// 현재페이지코드와 관리자의 접근페이지코드가 일치하는지 판단
for($i=0; $i<$arrcnt; $i++)
{
if($arrpercode[$i] == $currpercode)
{
$ispermission = 1;
break;
}
}
}
// 이 페이지에 대한 접근권한 없음
if(!$ispermission)
{
alertBox("사용권한이 없습니다", "history.back();");
exit;
}
}
?>
[이 게시물은 관리자님에 의해 2011-10-31 17:12:10 PHP & HTML에서 이동 됨]
댓글 1개
18년 전
디비를 쓰면 더 좋을것 같네요 ^^
게시글 목록
| 번호 | 제목 |
|---|---|
| 11797 | |
| 11796 |
기타
Progress 로딩바
|
| 29161 |
HTML
체크박스 전체선택 소스
|
| 11795 | |
| 11794 | |
| 11793 | |
| 11789 | |
| 11784 | |
| 29160 | |
| 11781 |
Flash
도와주세요..
2
|
| 11778 |
PHP
SSL 관련 링크
2
|
| 24966 | |
| 24964 | |
| 24963 |
제안서
회사약식제안서_기타
|
| 24961 | |
| 24960 | |
| 24950 |
제안서
홈페이지개발제안서_개발
9
|
| 24948 | |
| 24947 | |
| 24946 | |
| 24945 | |
| 24944 |
계약서
표준임대차계약서_부동산
|
| 24943 | |
| 24942 | |
| 24941 | |
| 24940 | |
| 24939 | |
| 29158 | |
| 11777 |
MySQL
Logrotate
|
| 11774 |
JavaScript
startssl 자동실행
2
|
| 11772 | |
| 11771 | |
| 11770 |
MySQL
mysql error code
|
| 11769 |
MySQL
Mysql - ErrCode
|
| 11765 | |
| 11764 |
기타
날짜 맞추기
|
| 11763 | |
| 11758 | |
| 29148 |
HTML
괜찮은 레이어 팝업창 소스
9
|
| 11752 | |
| 11747 | |
| 11746 | |
| 29147 | |
| 11744 |
JavaScript
플래쉬 초보입니다...질문좀 ^^
1
|
| 11735 |
Flash
퀵메뉴 - 수정해서 쓰세요!^^
8
|
| 29145 | |
| 11733 |
기타
히든필드 처리하기
1
|
| 11731 |
JavaScript
경고창의 폰트 조절.....
1
|
| 11730 | |
| 24937 | |
| 11728 | |
| 11727 | |
| 11725 | |
| 11717 | |
| 29138 | |
| 11716 | |
| 11715 |
JavaScript
특정 프로세스가 연 파일 보기.
|
| 11714 | |
| 11711 |
기타
CS3 간단 리뷰
2
|
| 11710 |
Flash
플래시 파일명 대신 외부파일 호출
|
| 11708 |
Flash
플래시 파일명 대신 외부파일 호출
1
|
| 11700 |
MySQL
mysql 원격접속방법
7
|
| 11697 | |
| 24936 | |
| 24935 | |
| 24934 | |
| 24933 | |
| 24932 | |
| 24931 | |
| 24930 | |
| 24929 | |
| 24928 | |
| 24927 | |
| 24926 |
계약서
주식양수도계약서_경리
|
| 24925 | |
| 24922 |
제안서
제안서_기업일반
2
|
| 24921 |
계약서
전세계약서_일반계약
|
| 24920 |
계약서
전세계약서_부동산
|
| 24919 | |
| 24918 | |
| 24917 | |
| 24916 | |
| 24915 |
계약서
장비임대 계약서_영업
|
| 24914 | |
| 24913 | |
| 11696 |
기타
메뉴를 찾습니다
|
| 11694 | |
| 24912 | |
| 24911 | |
| 24910 | |
| 24909 | |
| 24908 | |
| 24907 | |
| 24906 | |
| 11692 | |
| 24905 | |
| 24904 | |
| 24903 | |
| 24902 |
계약서
연봉제근로계약서
|
| 24901 |
계약서
연봉계약서-근로_기타
|
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기