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년 전 조회 4,822
13년 전 조회 1,129
13년 전 조회 655
13년 전 조회 821
13년 전 조회 651
13년 전 조회 533
13년 전 조회 782
13년 전 조회 912
13년 전 조회 595
13년 전 조회 671
13년 전 조회 1,097
13년 전 조회 7,650
13년 전 조회 2,845
13년 전 조회 577
13년 전 조회 1,140
13년 전 조회 1,090
13년 전 조회 1,187
13년 전 조회 5,084
13년 전 조회 534
13년 전 조회 1,056
13년 전 조회 2,489
13년 전 조회 2,131
13년 전 조회 1,800
13년 전 조회 1,978
13년 전 조회 2,881
13년 전 조회 558
13년 전 조회 2,020
13년 전 조회 1,424
13년 전 조회 3,207
13년 전 조회 3,282
13년 전 조회 1,061
13년 전 조회 4,119
13년 전 조회 1,171
13년 전 조회 1,370
13년 전 조회 1,816
13년 전 조회 1,747
13년 전 조회 831
13년 전 조회 1,021
13년 전 조회 2,923
13년 전 조회 992
13년 전 조회 1,513
13년 전 조회 2,289
13년 전 조회 2,109
13년 전 조회 825
13년 전 조회 1,459
13년 전 조회 3,810
13년 전 조회 1,085
13년 전 조회 1,538
13년 전 조회 1,040
13년 전 조회 1,218
13년 전 조회 1,691
13년 전 조회 806
13년 전 조회 1,707
13년 전 조회 1,352
13년 전 조회 903
13년 전 조회 9,306
13년 전 조회 1,002
13년 전 조회 881
13년 전 조회 966
13년 전 조회 1,692
13년 전 조회 1,078
13년 전 조회 1,179
13년 전 조회 844
13년 전 조회 703
13년 전 조회 4,786
13년 전 조회 1,069
13년 전 조회 1,154
13년 전 조회 916
13년 전 조회 6,819
13년 전 조회 972
13년 전 조회 1,318
13년 전 조회 1,289
13년 전 조회 3,003
13년 전 조회 969
13년 전 조회 2,866
13년 전 조회 1,320
13년 전 조회 1,928
13년 전 조회 1,472
13년 전 조회 1,630
13년 전 조회 1,867
13년 전 조회 705
13년 전 조회 907
13년 전 조회 875
13년 전 조회 1,197
13년 전 조회 1,222
13년 전 조회 2,001
13년 전 조회 844
13년 전 조회 916
13년 전 조회 3,308
13년 전 조회 1,035
13년 전 조회 1,297
13년 전 조회 1,714
13년 전 조회 1,140
13년 전 조회 2,114
13년 전 조회 838
13년 전 조회 2,968
13년 전 조회 1,330
13년 전 조회 1,616
13년 전 조회 1,068
13년 전 조회 1,230