HTTP 로그인 인증창에 대해 질문합니다 도와주세요ㅠㅠ

안녕하세요
저는 로그인페이지를 만들었는데..어떤 고객의 요청으로 인해
로그인페이지보다 그냥 "HTTP 로그인 인증창"이 띄울수있도록 원하답니다.
그래서 고객의 요청대로 그렇게 만들었는데..잘 안되었어요 ㅠㅠ
▒▒▒▒▒ 로그인 페이지 ▒▒▒▒▒
<?
 require "include/config.php";
 include "include/index_cookie.php";
   
 if($_SESSION[mb_userid]) { go_d(0,'m_sub01.html');  } // 이미 로그인 된경우 메인으로
?>
<meta http-equiv="Content-Type" content="text/html; charset=euc-kr">
<script language="JavaScript" src="<?echo"$HOME_PATH"?>/include/ebook.js"></script>
<LINK REL="StyleSheet" HREF="<?echo"$HOME_PATH"?>/include/style.css" type="text/css">
<link href="../include/style.css" rel="stylesheet" type="text/css">

<form action="app_login_act.html" method=post name=ebook_login onsubmit='return valid_ebooklogin_check()'>  
 <input type='hidden' name='mode' value='ebook_login'>
<?
 if($_SERVER[HTTP_REFERER]) {
  $returl = $_SERVER[HTTP_REFERER];
 }else if($returl) {
  $returl = $returl;
 }
 echo"<input type=hidden name=url value='$returl'>";
// echo"<input type=hidden name=url value='$PHP_SELF'>";
?>
<table width=80% border=0 align=center cellpadding="0" cellspacing="0">
  <tr>
    <td height="25" colspan=2 align=center>
      로그인
  <tr>
    <td width="35%" height="25">로그인
    <td width="65%" height="25"><input name="mb_userid" type="text" id="mb_userid" size="20">
  <tr>
    <td width="35%" height="25">비밀번호
    <td width="65%" height="25"><input name="mb_pwd" type="password" id="mb_pwd" size="20" onKeyPress="if(window.event.keyCode==13) ebooklogin();">
  <tr>
    <td height="25" colspan=2>  
        <input type="checkbox" onClick="id_save_delete(document.ebook_login);" name="id_save">자동로그인 
  <tr>
    <td height="25" colspan=2 align=center>
      <input type="submit" value="로그인" onclick="javascript:ebooklogin()">
      </td>
      </tr>
</table>
</form>
▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒
으로 잘 되었지만..
 
▒▒▒▒▒ HTTP 로그인 인증창 ▒▒▒▒▒
<?
 require "include/config.php";
 include "include/index_cookie.php";
   
 if($_SESSION[mb_userid]) { go_d(0,'m_sub01.html');  } // 이미 로그인 된경우 메인으로
function authenticate() // 인증을 받기 위해 인증 창을 여는 함수!
{
   // 인증 창이 떴을때의 문구와 인증 창의 헤더 설정!
      Header( "WWW-authenticate: basic realm=\"ADMIN영역\" ");
      Header( "HTTP/1.0 401 Unauthorized");
     
   // 아이디와 비밀번호가 일치하지 않을때 보여주는 문구!
   echo("이곳에 들어오시려면 관리자 아이디 암호가 필요합니다.");
      exit;
}
// 관리자 정보가 없을때 인증 창을 불러내는 부분으로서 관리자 인증을 받을때까지 인증 창을 띄움.
if(!isset($_SESSION[mb_userid]) || ($PHP_AUTH_USER!='mb_userid' || $PHP_AUTH_PW!='mb_pwd')) {
 authenticate();
}
?>
▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒
수정해봤는데.. 잘 안되었습니다 ㅠㅠㅠ
도와주세요 ㅠㅠㅠ
|

댓글 2개

죄송... HTTP Authorization 창이 뜨는걸 말씀하신거였네요... 저는 php 로 모달창 echo 해서 자스로 모달창을 별도로 띄우시려고 하는줄 알고, 엉뚱한 답글을 달았었네요.. ㅎㅎㅎㅎ

http://php.net/manual/en/features.http-auth.php
전에는 javascript는 잘한다고 했는데... 뭘라고 답변달았는지...

아파치 Http Authentication을 사용하게 되면 별도의 인증창이 필요없습니다. 그리고 "HTTP 로그인 인증창"은 잘 한 것 같은데 문제는 세션을 생성하는 부분이 없습니다. 인증이 맞으면세션을 생성을 해야 무한 로그인 안되는 루프에 빠지지 않겠죠... 그러므로 if절의 else를 만들어 세션을 생성하는 문구를 넣어주시면 됩니다.

if(!isset($_SESSION[mb_userid]) || ($PHP_AUTH_USER!='mb_userid' || $PHP_AUTH_PW!='mb_pwd')) {
authenticate();
} else {
$_SESSION['mb_userid'] = 'mb_userid';
}

이런 식으로요... 그런데 실제로 아이디가 mb_userid나 비번이 mb_pwd는 아니겠죠? 그리고 이부분을 디비와 연동해서 디비에서 mb_userid가 사용하는 mb_passwd가 같은지 않은지를 확인하는 방법을 쓸 수도 있습니다.
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

+
제목 글쓴이 날짜 조회
13년 전 조회 5,245
13년 전 조회 1,522
13년 전 조회 1,074
13년 전 조회 1,241
13년 전 조회 1,046
13년 전 조회 943
13년 전 조회 1,185
13년 전 조회 1,283
13년 전 조회 1,016
13년 전 조회 1,079
13년 전 조회 1,516
13년 전 조회 8,052
13년 전 조회 3,251
13년 전 조회 1,011
13년 전 조회 1,543
13년 전 조회 1,480
13년 전 조회 1,567
13년 전 조회 5,536
13년 전 조회 980
13년 전 조회 1,508
13년 전 조회 2,945
13년 전 조회 2,566
13년 전 조회 2,220
13년 전 조회 2,388
13년 전 조회 3,303
13년 전 조회 1,005
13년 전 조회 2,536
13년 전 조회 1,939
13년 전 조회 3,638
13년 전 조회 3,711
13년 전 조회 1,508
13년 전 조회 4,525
13년 전 조회 1,632
13년 전 조회 1,783
13년 전 조회 2,319
13년 전 조회 2,238
13년 전 조회 1,275
13년 전 조회 1,462
13년 전 조회 3,376
13년 전 조회 1,467
13년 전 조회 1,921
13년 전 조회 2,722
13년 전 조회 2,545
13년 전 조회 1,291
13년 전 조회 1,909
13년 전 조회 4,232
13년 전 조회 1,581
13년 전 조회 1,999
13년 전 조회 1,504
13년 전 조회 1,694
13년 전 조회 2,122
13년 전 조회 1,257
13년 전 조회 2,138
13년 전 조회 1,790
13년 전 조회 1,378
13년 전 조회 9,746
13년 전 조회 1,474
13년 전 조회 1,355
13년 전 조회 1,431
13년 전 조회 2,159
13년 전 조회 1,531
13년 전 조회 1,618
13년 전 조회 1,266
13년 전 조회 1,117
13년 전 조회 5,290
13년 전 조회 1,518
13년 전 조회 1,559
13년 전 조회 1,375
13년 전 조회 7,308
13년 전 조회 1,415
13년 전 조회 1,821
13년 전 조회 1,737
13년 전 조회 3,525
13년 전 조회 1,492
13년 전 조회 3,296
13년 전 조회 1,822
13년 전 조회 2,364
13년 전 조회 1,886
13년 전 조회 2,101
13년 전 조회 2,320
13년 전 조회 1,145
13년 전 조회 1,350
13년 전 조회 1,334
13년 전 조회 1,663
13년 전 조회 1,703
13년 전 조회 2,458
13년 전 조회 1,300
13년 전 조회 1,386
13년 전 조회 3,771
13년 전 조회 1,474
13년 전 조회 1,743
13년 전 조회 2,159
13년 전 조회 1,650
13년 전 조회 2,523
13년 전 조회 1,301
13년 전 조회 3,366
13년 전 조회 1,836
13년 전 조회 2,041
13년 전 조회 1,520
13년 전 조회 1,647