2026, 새로운 도약을 시작합니다.

관리자 및 회원의 페이지 접근 권한 간단구현 입니다.

관리자 및 회원별로 각 메뉴별로 접근가능한 권한을 설정하는 간단한 구현방법입니다.

우선 사용자별로 접근가능한 메뉴별 코드를 "/"을 구분자로 불러온 뒤
현재페이지의 접근코드와 비교해서 퍼미션을 주는 방식입니다.

이것의 간편한점은 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;
  }
}
?>

|

댓글 1개

$i 의 2와 4는 $anypage 와 $perpage 의 배열 갯수 같은데 2와 4가 아닌 상황이 되면 쓰기에 비효율적으로 보이네요
차라리 $anypage 또는 $perpage의 배열 갯수로 for 문을 돌리는게 나을거 같습니다.
count($perpage)

댓글 작성

댓글을 작성하시려면 로그인이 필요합니다.

로그인하기

프로그램

+
번호 제목 글쓴이 날짜 조회
8230 9년 전 조회 20
8229 9년 전 조회 25
8228 9년 전 조회 62
8227 9년 전 조회 72
8226 9년 전 조회 117
8225 9년 전 조회 100
8224 9년 전 조회 92
8223 9년 전 조회 54
8222 9년 전 조회 126
8221 9년 전 조회 38
8220 9년 전 조회 35
8219 9년 전 조회 38
8218 9년 전 조회 73
8217 9년 전 조회 51
8216 9년 전 조회 101
8215 9년 전 조회 56
8214 9년 전 조회 175
8213 9년 전 조회 116
8212 9년 전 조회 22
8211 9년 전 조회 191
8210 9년 전 조회 181
8209 9년 전 조회 281
8208 9년 전 조회 154
8207 9년 전 조회 171
8206 9년 전 조회 127
8205 9년 전 조회 119
8204 9년 전 조회 75
8203 9년 전 조회 168
8202 9년 전 조회 97
8201 9년 전 조회 137
8200 9년 전 조회 94
8199 9년 전 조회 149
8198 9년 전 조회 123
8197 9년 전 조회 103
8196 9년 전 조회 481
8195 9년 전 조회 103
8194 9년 전 조회 239
8193 9년 전 조회 108
8192 9년 전 조회 134
8191 9년 전 조회 87
8190 9년 전 조회 83
8189 9년 전 조회 141
8188 9년 전 조회 71
8187 9년 전 조회 91
8186 9년 전 조회 101
8185 9년 전 조회 260
8184 9년 전 조회 57
8183 9년 전 조회 286
8182 9년 전 조회 117
8181 9년 전 조회 83
8180 9년 전 조회 647
8179 9년 전 조회 443
8178 9년 전 조회 248
8177 9년 전 조회 253
8176 9년 전 조회 298
8175 9년 전 조회 172
8174 9년 전 조회 178
8173 9년 전 조회 295
8172 9년 전 조회 138
8171 9년 전 조회 137
8170 9년 전 조회 245
8169 9년 전 조회 215
8168 9년 전 조회 263
8167 9년 전 조회 275
8166 9년 전 조회 188
8165 9년 전 조회 129
8164 9년 전 조회 247
8163 9년 전 조회 235
8162 9년 전 조회 244
8161 9년 전 조회 233
8160 9년 전 조회 436
8159 9년 전 조회 341
8158 9년 전 조회 163
8157 9년 전 조회 307
8156 9년 전 조회 219
8155 9년 전 조회 201
8154 9년 전 조회 541
8153 9년 전 조회 176
8152 9년 전 조회 346
8151 9년 전 조회 358
8150 9년 전 조회 445
8149 9년 전 조회 283
8148 9년 전 조회 112
8147 9년 전 조회 332
8146 9년 전 조회 386
8145 9년 전 조회 306
8144 9년 전 조회 272
8143 9년 전 조회 125
8142 9년 전 조회 377
8141 9년 전 조회 328
8140 9년 전 조회 869
8139 9년 전 조회 193
8138 9년 전 조회 339
8137 9년 전 조회 316
8136 9년 전 조회 683
8135 9년 전 조회 721
8134 9년 전 조회 437
8133 9년 전 조회 387
8132 9년 전 조회 401
8131 9년 전 조회 753
🐛 버그신고