해당 글은 이전 글들의 작업을 이어서 진행되고 있는 글입니다.
1. 회원가입 페이지 만들기
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.1.3/dist/css/bootstrap.min.css" rel="stylesheet"
integrity="sha384-1BmE4kWBq78iYhFldvKuhfTAU6auU8tT94WrHftjDbrCEXSU1oBoqyl2QvZ6jIW3" crossorigin="anonymous">
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.1.3/dist/css/bootstrap.min.css" rel="stylesheet"
integrity="sha384-1BmE4kWBq78iYhFldvKuhfTAU6auU8tT94WrHftjDbrCEXSU1oBoqyl2QvZ6jIW3" crossorigin="anonymous">
<!-- <link rel="stylesheet" href="main.css"> -->
<script src="https://kit.fontawesome.com/f8ad50bee4.js" crossorigin="anonymous"></script>
<title></title>
</head>
<body>
<!--nav 부분 조립식으로 include하기 -->
<!-- <%- include('nav.html') %> -->
<h4 class="container mt-4"><strong>회원가입</strong></h4>
<div class="container mt-5">
<form action="/join" method="POST">
<!-- method : 전송 버튼을 누르면 어떻게(post/get) 할건지 / action : 어떤 경로로 post/get할 건지 -->
<div class="form-group mt-2">
<label>아이디를 입력해주세요.</label>
<input type="text" class="form-control" name="id">
</div>
<div class="form-group mt-5">
<label>비밀번호를 입력해주세요.</label>
<input type="password" id="firstPW" class="form-control" name="pw">
</div>
<div class="form-group mt-2">
<label>비밀번호를 한번 더 입력해주세요.</label>
<input type="password" id="secondPW" class="form-control" name="pw2">
</div>
<p id="pwError" style="color: red; display: none;">비밀번호가 일치하지 않습니다.</p>
<div class="form-group mt-2">
<label>닉네임 입력해주세요.</label>
<input type="text" id="nickname" class="form-control" name="nickname">
</div>
<button type="submit" class="btn btn-outline-secondary mt-3" style="float: right">회원가입 완료하기</button>
</form>
</div>
<!-- jQeury install -->
<script src="https://code.jquery.com/jquery-3.7.0.min.js"
integrity="sha256-2Pmvv0kuTBOenSvLm6bvfBSSHrUJ+3A7x6P5Ebd07/g=" crossorigin="anonymous"></script>
<!-- JavaScript -->
<!-- <script src="main.js"></script> -->
<script>
$('#secondPW').keyup(function(){
if($('#secondPW').val() == $('#firstPW').val()) {
$('#pwError').css('display', 'none');
} else {
$('#pwError').css('display', 'block');
}
})
</script>
<!-- <!— bootstrap install —> -->
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.1.3/dist/js/bootstrap.bundle.min.js"
integrity="sha384-ka7Sk0Gln4gmtz2MlQnikT1wXgYsOg+OMhuP+IlRH9sENBO0LRn5q+8nbTov4+1p" crossorigin="anonymous">
</script>
</body>
</html>
2. 회원가입 페이지 라우팅하기
app.get('/join', function(request, response){
response.render('join.ejs');
})
app.post('/join', function(request, response){
db.collection('login').insertOne({ id: request.body.id, pw: request.body.pw, nickname: request.body.nickname}, function (error, result) {
if (error) return done(error)
if (!result) {return done(null, false, { message: '회원가입에 실패하였습니다.' })} else {
response.redirect('/login')
}
// console.log(result);
});
});
'Server > Node.js' 카테고리의 다른 글
검색기능 만들기(1) - URL query string (0) | 2023.09.08 |
---|---|
ENV (0) | 2023.09.07 |
로그인 기능 만들기 Session (3) - 마이페이지 기능 만들어보기 (0) | 2023.09.06 |
로그인 기능 만들기 Session (2) - 아이디 비밀번호 DB와 비교하고 세션 만들어주기 (0) | 2023.09.06 |
로그인 기능 만들기 Session (1) - 로그인 페이지 만들기, 아이디 비밀번호 검사하기 (0) | 2023.09.06 |