💡 정보 수정 페이지를 만들어보자
⭐️ 완성샷
🔴 세션 변수 불러오고, 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] 관리자 페이지 만들기 - 2 (0) | 2023.12.13 |
---|---|
[PHP] 관리자 페이지 만들기 - 1 (0) | 2023.12.13 |
[PHP] 회원탈퇴 페이지 만들기 (0) | 2023.12.13 |
[PHP] 로그인 페이지 만들기 - 2 (index, logout) (0) | 2023.12.11 |
[PHP] 로그인 페이지 만들기 - 1 (login, login_ok) (0) | 2023.12.10 |