관리자 및 회원별로 각 메뉴별로 접근가능한 권한을 설정하는 간단한 구현방법입니다.
우선 사용자별로 접근가능한 메뉴별 코드를 "/"을 구분자로 불러온 뒤
현재페이지의 접근코드와 비교해서 퍼미션을 주는 방식입니다.
이것의 간편한점은 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에서 이동 됨]
게시글 목록
| 번호 | 제목 |
|---|---|
| 12007 |
기타
그라디언트
5
|
| 12006 | |
| 12005 | |
| 12000 |
Flash
일러스트 단축키
4
|
| 11994 |
Flash
[[ 플래시 MX 단축키 요약 ]]
5
|
| 11993 | |
| 11992 | |
| 11991 |
JavaScript
adduser 명령어 기본사용법
|
| 11990 |
MySQL
리눅스 자동백업
|
| 11989 | |
| 29203 | |
| 11988 |
Linux
Xinetd 설치하기&설명
|
| 11986 |
MySQL
mysql버전확인
1
|
| 11985 |
JavaScript
su, telnet, ftp 권한제한
|
| 11984 | |
| 11983 |
JavaScript
Portsentry 1.1 설치하기(실시간해킹방지프로그램)
|
| 11982 |
Linux
리눅스에서 휴지통 (safedelete)
|
| 29202 |
HTML
apache2 가상호스트 설정방법
|
| 29201 | |
| 24968 | |
| 11981 |
JavaScript
시작과 멈춤이 가능한 스크롤 텍스트
|
| 29200 |
HTML
이미지에 마우스만 올려도 링크로 이동
|
| 29198 | |
| 11979 | |
| 11978 |
Flash
php.ini정보
|
| 11975 |
JavaScript
Lightbox2 적용 방법
2
|
| 11973 |
기타
rpm 명령어
1
|
| 11972 |
기타
Trac 설치
|
| 11971 | |
| 11970 |
기타
META 태그 사용법
|
| 11966 | |
| 11962 |
MySQL
MySQL 다운로드
3
|
| 29197 | |
| 29196 |
HTML
간단PHP(4)
|
| 11961 |
기타
간단PHP(3)
|
| 11960 |
기타
간단PHP(2)
|
| 11959 |
JavaScript
간단PHP(1)
|
| 11958 | |
| 11956 | |
| 11952 | |
| 11948 |
JavaScript
[질문] 페도라리눅스에서 한글깨짐현상
3
|
| 11944 | |
| 11936 | |
| 11935 | |
| 29195 | |
| 11934 |
JavaScript
포토샵 CS3에서 JPG 파일을 RAW 파일처럼 보정하기 - 사진 후보정
|
| 29191 | |
| 11933 |
JavaScript
[소스] 배경이미지 바꾸기 (PHP에서)에 대한 초보
|
| 29186 | |
| 11932 |
Flash
플래쉬쪽에서의 파일업로드
|
| 11931 |
Flash
플래쉬에서 PHP와 연동하면서 파일 업로드
|
| 11926 |
Flash
초보가 올리는 왼쪽 메뉴(허접)
4
|
| 11922 | |
| 29183 | |
| 11920 | |
| 11916 | |
| 11915 | |
| 11913 |
JavaScript
타일 이미지 멥핑
1
|
| 11910 | |
| 29182 |
HTML
브러쉬만들기
|
| 11904 | |
| 11901 |
기타
눈물만들기
2
|
| 11900 | |
| 29181 |
HTML
말랑말랑 젤리 텍스트
|
| 11898 | |
| 29179 |
HTML
간단하게 수채화 느낌 내기
1
|
| 11894 |
JavaScript
htmlspecialchars() 역변환(반대) 함수
3
|
| 11892 | |
| 11890 |
JavaScript
배경이미지 바꾸기 (PHP에서)
1
|
| 11889 |
JavaScript
검색창 추가
|
| 11888 | |
| 11886 |
기타
질문입니다
1
|
| 11883 | |
| 11879 | |
| 11875 | |
| 29178 |
HTML
팝업소스 관련질문-오늘하루창안열기
|
| 29167 |
HTML
자바스크립으로 플래쉬 메뉴처럼
10
|
| 11874 |
JavaScript
글씨의 색을 자동으로 변환시켜주는 함수
|
| 29166 | |
| 11872 | |
| 11870 |
JavaScript
[스크립트] 이미지 리사이징
1
|
| 11867 | |
| 11866 | |
| 11865 |
MySQL
MySQL에서 Query Cache 사용하기
|
| 29165 |
HTML
색상표
|
| 29162 |
HTML
입출력폼 생성기
2
|
| 11861 |
MySQL
무료 웹방화벽 Modsecurity..!
3
|
| 11851 |
MySQL
리눅스 포기 하고 싶습니다.. ㅠ.ㅠ
9
|
| 11850 | |
| 11847 | |
| 11846 | |
| 11845 |
JavaScript
ucc(동영상) 서비스 운영관련 자료 (키워드 ffmpeg)
|
| 11840 | |
| 11826 | |
| 11825 |
MySQL
MySQL 한글 정렬 Tip
|
| 11823 |
기타
외부문서불러오기
1
|
| 11816 | |
| 11808 |
Flash
플래시 메뉴 소스
7
|
| 11805 | |
| 11804 |
JavaScript
<script>
|
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기