테스트 사이트 - 개발 중인 베타 버전입니다

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

· 13년 전 · 1026 · 2
안녕하세요
저는 로그인페이지를 만들었는데..어떤 고객의 요청으로 인해
로그인페이지보다 그냥 "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가 같은지 않은지를 확인하는 방법을 쓸 수도 있습니다.

게시글 목록

번호 제목
9917
9914
17542
9908
19902
9907
9905
9900
17541
9898
19895
9895
9893
19894
9892
19886
19884
19883
19880
9885
17540
9880
9876
9872
9868