Backend/PHP

[PHP] 정보 수정 페이지 만들기

전예방 2023. 12. 11. 00:27
💡 정보 수정 페이지를 만들어보자

⭐️ 완성샷


🔴 세션 변수 불러오고, DB연결해서 결과 가져오기

<?php
session_start();

/* 로그인 사용자 */
$s_idx = $_SESSION["s_idx"];

/* DB 연결 */
include "../inc/dbcon.php";

/* 쿼리 작성 */
$sql = "select * from members where idx=$s_idx;";

/* 쿼리 전송 */
$result = mysqli_query($dbcon, $sql);

/* 결과 가져오기 */
$array = mysqli_fetch_array($result);

?>

$array = mysqli_fetch_array($result); 필드명으로 결과를 가져올 수 있다.


🟠 CSS

  body,select,option,button{font-size:16px}
  input{border:1px solid #999;font-size:14px;padding:5px 10px}
  input,button,select,option{vertical-align:middle}
  form{width:700px;margin:auto}
  input[type=checkbox]{width:20px;height:20px}
  span{font-size:14px;color:#f00}
  legend{font-size:20px;text-align:center}
  p span{display:block;margin-left:130px}
  button{cursor:pointer}
  .txt{display:inline-block;width:120px}
  .btn{background:#fff;border:1px solid #999;font-size:14px;padding:4px 10px}
  .btn_wrap{text-align:center}
  .email_sel{width:120px;height:28px}
  .postal_code{width:100px;margin-bottom:5px}
  .addr1{width:300px;margin-bottom:5px}
  .addr2{width:300px;margin-bottom:5px}

🟡 Java Script

function edit_check(){
    
    var pwd = document.getElementById("pwd");
    var repwd = document.getElementById("repwd");
    var mobile = document.getElementById("mobile");


    if(pwd.value){
        var pwd_len = pwd.value.length;
        if( pwd_len < 4 || pwd_len > 8){
            var err_txt = document.querySelector(".err_pwd");
            err_txt.textContent = "비밀번호는 4~8글자만 입력할 수 있습니다.";
            pwd.focus();
            return false;
        };
    };

    if(pwd.value){
        if(pwd.value != repwd.value){
            var err_txt = document.querySelector(".err_repwd");
            err_txt.textContent = "비밀번호를 확인해 주세요.";
            repwd.focus();
            return false;
        };
    };

    if(mobile.value){
        var reg_mobile = /^[0-9]+$/g;
        if(!reg_mobile.test(mobile.value)){
            var err_txt = document.querySelector(".err_mobile");
            err_txt.textContent = "전화번호는 숫자만 입력할 수 있습니다.";
            mobile.focus();
            return false;
        };
    };
};

function change_email(){
    var email_dns = document.getElementById("email_dns");
    var email_sel = document.getElementById("email_sel");

    var idx = email_sel.options.selectedIndex;

    var sel_txt = email_sel.options[idx].value;
    email_dns.value = sel_txt;
};

function addr_search(){
    window.open("search_addr.php", "", "width=600, height=400, left=0, top=0");
};

function del_check(){
    var i = confirm("정말 탈퇴하시겠습니까?\n탈퇴한 아이디는 사용하실 수 없습니다.");

    if(i == true){
        // location.href = "delete.php?idx=<?php echo $s_idx; ?>";
        location.href = "delete.php";
    };
};
  • 유효성 검사를 추가해준다
  • del_check()는 나중에 알아보자!!

🟢 HTML

<form name="edit_form" action="edit_ok.php" method="post" onsubmit="return edit_check()">
<fieldset>
    <legend>정보 수정</legend>
    <p>
        <div class="txt">이름</div>
        <?php echo $array["u_name"]; ?>
    </p>

    <p>
        <div class="txt">아이디</div>
        <?php echo $array["u_id"]; ?>
    </p>

    <p>
        <label for="pwd" class="txt">비밀번호</label>
        <input type="password" name="pwd" id="pwd" class="pwd">
        <br>
        <span class="err_pwd">* 비밀번호는 4~8글자만 입력할 수 있습니다.</span>
    </p>

    <p>
        <label for="repwd" class="txt">비밀번호 확인</label>
        <input type="password" name="repwd" id="repwd" class="repwd">
        <br>
        <span class="err_repwd"></span>
    </p>
    
    <?php
        // str_replace("어떤 문자를", "어떤 문자로", "어떤 문장에서");
        $birth = str_replace("-", "", $array["birth"]);
    ?>
    <p>
        <label for="repwd" class="txt">생년월일</label>
        <input type="text" name="birth" id="birth" class="birth" value="<?php echo $birth; ?>">
        <br>
        <span>* ex) 20211022</span>
    </p>

    <p>
        <label for="postalCode" class="txt">주소</label>
        <input type="text" name="postalCode" id="postalCode" class="postal_code" value="<?php echo $array["postalCode"]; ?>">
        <button type="button" class="btn" onclick="addr_search()">주소검색</button>
        <br>
        <label for="addr1" class="txt">기본주소 </label>
        <input type="text" name="addr1" id="addr1" class="addr1" value="<?php echo $array["add1"]; ?>">
        <br>
        <label for="addr2" class="txt">상세주소 </label>
        <input type="text" name="addr2" id="addr2" class="addr2" value="<?php echo $array["add2"]; ?>">
    </p>

    <?php
        // explode("기준 문자", "어떤 문장에서");
        $email = explode("@", $array["email"]);
    ?>
    <p>
        <label for="" class="txt">이메일</label>
        <input type="text" name="email_id" id="email_id" class="email_id" value="<?php echo $email[0]; ?>"> @ 
        <input type="text" name="email_dns" id="email_dns" class="email_dns" value="<?php echo $email[1]; ?>"> 
        <select name="email_sel" id="email_sel" class="email_sel" onchange="change_email()">
            <option value="">직접 입력</option>
            <option value="naver.com">NAVER</option>
            <option value="hanmail.net">DAUM</option>
            <option value="gmail.com">GOOGLE</option>
        </select>
    </p>
    
    <p>
        <label for="mobile" class="txt">전화번호</label>
        <input type="text" name="mobile" id="mobile" class="mobile" value="<?php echo $array["mobile"]; ?>">
        <br>
        <span class="err_mobile">"-"없이 숫자만 입력</span>
    </p>

    <p class="btn_wrap">
        <button type="button" class="btn" onclick="history.back()">이전으로</button>
        <button type="button" class="btn" onclick="location.href='../index.php'">홈으로</button>
        <button type="button" class="btn" onclick="del_check()">회원탈퇴</button>
        <button type="submit" class="btn">정보수정</button>
    </p>
</fieldset>
</form>
  • 바뀌면 안되는 정보는 바로 출력한다. (이름, 아이디)

🟤 생일 Date의 '-' 대체하기

<?php
 // str_replace("어떤 문자를", "어떤 문자로", "어떤 문장에서");
 $birth = str_replace("-", "", $array["birth"]);
?>

<input type="text" name="birth" id="birth" class="birth" value="<?php echo $birth; ?>">
  • 생일의 자료형은 date이다.
  • date에는 -가 들어가서 str_replace()를 이용해서 바꿔주자!

🟤 이메일의 @ 기준으로 나누기

<?php
    // explode("기준 문자", "어떤 문장에서");
    $email = explode("@", $array["email"]);
?>

<input type="text" name="email_id" id="email_id" class="email_id" value="<?php echo $email[0]; ?>"> @ 
<input type="text" name="email_dns" id="email_dns" class="email_dns" value="<?php echo $email[1]; ?>">
  • explode() 함수를 쓰면 기준 문자를 기준으로 배열 형태로 나뉜다.

🔵 edit_ok.php

<?php
/* 세션 시작 */
session_start();
$s_idx = $_SESSION["s_idx"];
// echo $s_idx;
// exit;


/* 이전 페이지에서 값 가져오기 */
$pwd = $_POST["pwd"];
$birth = $_POST["birth"];
$postalCode = $_POST["postalCode"];
$add1 = $_POST["add1"];
$add2 = $_POST["add2"];
$email = $_POST["email_id"]."@".$_POST["email_dns"];
$mobile = $_POST["mobile"];

// 값 확인
echo "비밀번호 : ".$pwd."<br>";
echo "생년월일 : ".$birth."<br>";
echo "우편번호 : ".$postalCode."<br>";
echo "기본주소 : ".$add1."<br>";
echo "상세주소 : ".$add2."<br>";
echo "이메일 : ".$email."<br>";
echo "전화번호 : ".$mobile."<br>";
// exit;


/*  DB 접속 */
include "../inc/dbcon.php";


/* 쿼리 작성 */
// update 테이블명 set 필드명=값, 필드명=값, ....;
if(!$pwd){
    $sql = "update members set birth='$birth', postalCode='$postalCode', add1='$add1', add2='$add2', email='$email', mobile='$mobile' where idx=$s_idx;";
} else{
    $sql = "update members set pwd='$pwd', birth='$birth', postalCode='$postalCode', add1='$add1', add2='$add2', email='$email', mobile='$mobile' where idx=$s_idx;";
};
echo $sql;
// exit;


/* 데이터베이스에 쿼리 전송 */
mysqli_query($dbcon, $sql);


/* DB(연결) 종료 */
mysqli_close($dbcon);


/* 리디렉션 */
echo "
    <script type=\"text/javascript\">
        alert(\"정보가 수정되었습니다.\");
        location.href = \"edit.php\";
    </script>
";
?>

🟤 쿼리 작성

  • 쿼리 작성할 때 if문을 사용해서 비밀번호를 바꿨을 때, 바꾸지 않았을 때 쿼리문을 각각 작성해줘야한다.

🟤 리디렉션

  • 정보가 수정된 후에는 알림창을 띄워주고, edit.php로 돌아가 정보가 수정된 것을 바로 확인해 볼 수 있다.

 

'Backend/PHP'의 다른글

  • 현재글 [PHP] 정보 수정 페이지 만들기

관련글