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,876
13년 전 조회 1,181
13년 전 조회 702
13년 전 조회 875
13년 전 조회 702
13년 전 조회 588
13년 전 조회 823
13년 전 조회 951
13년 전 조회 646
13년 전 조회 717
13년 전 조회 1,149
13년 전 조회 7,698
13년 전 조회 2,897
13년 전 조회 628
13년 전 조회 1,189
13년 전 조회 1,138
13년 전 조회 1,235
13년 전 조회 5,142
13년 전 조회 593
13년 전 조회 1,114
13년 전 조회 2,543
13년 전 조회 2,189
13년 전 조회 1,849
13년 전 조회 2,026
13년 전 조회 2,940
13년 전 조회 601
13년 전 조회 2,079
13년 전 조회 1,475
13년 전 조회 3,268
13년 전 조회 3,332
13년 전 조회 1,116
13년 전 조회 4,171
13년 전 조회 1,222
13년 전 조회 1,418
13년 전 조회 1,858
13년 전 조회 1,801
13년 전 조회 884
13년 전 조회 1,071
13년 전 조회 2,976
13년 전 조회 1,044
13년 전 조회 1,566
13년 전 조회 2,336
13년 전 조회 2,157
13년 전 조회 885
13년 전 조회 1,522
13년 전 조회 3,863
13년 전 조회 1,142
13년 전 조회 1,588
13년 전 조회 1,088
13년 전 조회 1,262
13년 전 조회 1,747
13년 전 조회 859
13년 전 조회 1,757
13년 전 조회 1,400
13년 전 조회 952
13년 전 조회 9,357
13년 전 조회 1,045
13년 전 조회 940
13년 전 조회 1,025
13년 전 조회 1,742
13년 전 조회 1,135
13년 전 조회 1,233
13년 전 조회 897
13년 전 조회 745
13년 전 조회 4,842
13년 전 조회 1,119
13년 전 조회 1,185
13년 전 조회 973
13년 전 조회 6,882
13년 전 조회 1,019
13년 전 조회 1,359
13년 전 조회 1,350
13년 전 조회 3,043
13년 전 조회 1,026
13년 전 조회 2,916
13년 전 조회 1,371
13년 전 조회 1,973
13년 전 조회 1,521
13년 전 조회 1,679
13년 전 조회 1,929
13년 전 조회 752
13년 전 조회 963
13년 전 조회 925
13년 전 조회 1,257
13년 전 조회 1,281
13년 전 조회 2,041
13년 전 조회 882
13년 전 조회 971
13년 전 조회 3,359
13년 전 조회 1,089
13년 전 조회 1,346
13년 전 조회 1,760
13년 전 조회 1,194
13년 전 조회 2,155
13년 전 조회 889
13년 전 조회 3,011
13년 전 조회 1,381
13년 전 조회 1,666
13년 전 조회 1,108
13년 전 조회 1,278