Programming/Spring
[스프링 프레임워크] 회원가입 이메일 인증 구현하기
hyunipad
2022. 1. 23. 15:29
반응형
이번 포스팅에서는 회원가입 이메일 인증을 구현하는 방법을 소개하겠습니다.
그 외의 프로젝트 세팅이나 게시판 구현 등은 아래의 포스팅을 참고해주시길 바랍니다.
2021.07.05 - [Programming/Spring] - [스프링 프레임워크]게시판 만들기 #1 : 프로젝트 생성 및 셋팅
우선 제가 구현한 회원가입 폼입니다.
1인 1 아이디를 구현하기 위해서 이메일 인증을 도입했고, 다른 양식은 최대한 간단하게 구현하였습니다.
join.jsp안에 있는 default.css는 빼셔도 무방합니다. 밑에 한 줄이 default.css입니다.
button:hover {
cursor: pointer;
}
1. join.jsp
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<html>
<head>
<meta charset="UTF-8">
<script src="https://code.jquery.com/jquery-3.4.1.min.js"></script>
<script src="${path}/resources/js/join.js"></script>
<link rel="stylesheet" href="${path}/resources/css/default.css">
<link rel="stylesheet" href="${path}/resources/css/join.css">
<title>filetable</title>
</head>
<body>
<div id="container" class="container">
<div class="content">
<div class="join_wrap">
<form id="join_frm">
<div class="join_title">회원가입</div>
<div class="join_box">
<input type="text" placeholder="아이디" name="id" id="id" style="margin: 0;">
<span id="id_ck" class="dpn">이미 사용중인 아이디입니다.</span>
<input type="text" placeholder="닉네임" name="nickname" id="nickname">
<span id="nickname_ck" class="dpn">이미 사용중인 닉네임입니다.</span>
<input type="password" placeholder="비밀번호" name="password" id="password">
<input type="password" placeholder="비밀번호 확인" id="password_ck">
<div class="email_auth">
<input type="text" placeholder="이메일" name="email" id="email" class="email">
<button type="button" id="email_auth_btn" class="email_auth_btn">인증번호 받기</button>
</div>
<input type="text" placeholder="인증번호 입력" id="email_auth_key">
</div>
<button type="button" id="join" class="join_btn">가입하기</button>
</form>
</div>
</div>
</div>
</body>
</html>
2. join.css
@charset "UTF-8";
#container {width: 100%; height: 100%; position: relative;}
.dpn {display: none !important;}
.join_wrap {width:550px; margin: 0 auto; border: 1px solid #dadada; padding: 24px; border-radius: 5px;}
.join_title {width:100%; height:35px; font-size: 19px; font-weight: bold; padding-left: 10px; padding: 0 0 10px 10px;}
.join_box {width: 100%;}
.join_box input {width: 100%; height: 50px; border: 1px solid #dadada;padding: 17px; border-radius: 5px; margin-top: 20px;}
.join_box span {display: inline-block; color: red; font-size: 12px; padding-left: 1px; padding-top: 8px;}
.email_auth {width: 100%; margin-top: 10px;}
.email_auth input {display:inline-block; width: calc(100% - 121px); vertical-align: top; margin: 0;}
.email_auth_btn{
display: inline-block;
width: 115px;
height: 50px;
padding: 17px 0 15px;
border-radius: 6px;
border: solid 1px rgba(0,0,0,.15);
background-color: #03c75a;
color: white;
font-size: 17px;
font-weight: bold;
line-height: 1;
}
.join_btn {
display: block;
width: 100%;
padding: 17px 0 15px;
border-radius: 6px;
border: solid 1px rgba(0,0,0,.15);
background-color: #03c75a;
color: white;
font-size: 19px;
font-weight: bold;
margin-top: 20px;
}
3. root-context.xml
naver 메일 설정과 SSL 보안 관련 설정을 root-context.xml에 추가합니다.
<!-- navermail설정 -->
<bean id="mailSender" class="org.springframework.mail.javamail.JavaMailSenderImpl">
<property name="host" value="smtp.naver.com"/> <!-- 메이서버 호스트 -->
<property name="port" value="465"/> <!-- 메이서버 포트번호 -->
<property name="username" value=""/> <!-- 자신의 이메일 아이디 -->
<property name="password" value=""/> <!-- 자신의 비밀번호 -->
<!-- 보안연결 SSL과 관련된 설정 -->
<property name="javaMailProperties">
<props>
<prop key="mail.smtp.auth">true</prop>
<prop key="mail.smtp.starttls.enable">true</prop>
<prop key="mail.smtps.checkserveridentity">true</prop>
<prop key="mail.smtps.ssl.trust">*</prop>
<prop key="mail.debug">true</prop>
<prop key="mail.smtp.socketFactory.class">javax.net.ssl.SSLSocketFactory</prop>
</props>
</property>
</bean>
4. join.js
인증번호 받기 클릭 시 입력한 이메일로 인증번호가 발생하도록 구현하였습니다. 이메일이 입력되지 않았을 경우에는
경고창을 출력합니다. 메일 발송에 성공했을 시에 아래에 HomeController.java에서 만든 6자리의 인증번호를 js안에 변수(email_auth_cd)에 저장합니다. 폼에 입력한 인증번호와 js안에 저장된 인증번호가 일치하지 않으면 경고창을 출력합니다.
/**
* 회원가입 관련 처리
*/
function fn_join(){
var f = $('#join_frm');
var formData = f.serialize();
$.ajax({
type : "POST",
url : "/join",
data : formData,
success: function(data){
if(data == "Y"){
alert("회원가입이 완료되었습니다.");
location.href="/"
}else{
alert("회원가입에 실패하였습니다.");
}
},
error: function(data){
alert("회원가입 에러 발생!");
console.log(data);
}
});
}
$(function() {
var email_auth_cd = '';
$('#join').click(function(){
if($('#id').val() == ""){
alert("아이디를 입력해주세요.");
return false;
}
if($('#nickname').val() == ""){
alert("닉네임을 입력해주세요.");
return false;
}
if($('#password').val() == ""){
alert("비밀번호를 입력해주세요.");
return false;
}
if($('#password').val() != $('#password_ck').val()){
alert("비밀번호가 일치하지 않습니다.");
return false;
}
if($('#email_auth_key').val() != email_auth_cd){
alert("인증번호가 일치하지 않습니다.");
return false;
}
fn_join();
});
$(".email_auth_btn").click(function(){
var email = $('#email').val();
if(email == ''){
alert("이메일을 입력해주세요.");
return false;
}
$.ajax({
type : "POST",
url : "/emailAuth",
data : {email : email},
success: function(data){
alert("인증번호가 발송되었습니다.");
email_auth_cd = data;
},
error: function(data){
alert("메일 발송에 실패했습니다.");
}
});
});
$('#id').focusout(function(){
var id = $('#id').val();
$.ajax({
type : "POST",
url : "/idCheck",
data : {id : id},
success: function(data){
console.log(data);
if(data == "Y"){
$('#id_ck').removeClass("dpn");
}else{
$('#id_ck').addClass("dpn");
}
},
error: function(data){
}
});
});
$('#nickname').focusout(function(){
var nickname = $('#nickname').val();
$.ajax({
type : "POST",
url : "/nicknameCheck",
data : {nickname : nickname},
success: function(data){
if(data == "Y"){
$('#nickname_ck').removeClass("dpn");
}else{
$('#nickname_ck').addClass("dpn");
}
},
error: function(data){
}
});
});
});
5. HomeCotroller.java
Math.random을 사용하여 6자리의 숫자를 만들어서 인증번호를 부여합니다.
setFrom에는 대표 이메일을 입력해주시면 됩니다.
@ResponseBody
@RequestMapping(value = "/emailAuth", method = RequestMethod.POST)
public String emailAuth(String email) {
Random random = new Random();
int checkNum = random.nextInt(888888) + 111111;
/* 이메일 보내기 */
String setFrom = "자신의 이메일을 입력해주세요";
String toMail = email;
String title = "회원가입 인증 이메일 입니다.";
String content =
"홈페이지를 방문해주셔서 감사합니다." +
"<br><br>" +
"인증 번호는 " + checkNum + "입니다." +
"<br>" +
"해당 인증번호를 인증번호 확인란에 기입하여 주세요.";
try {
MimeMessage message = mailSender.createMimeMessage();
MimeMessageHelper helper = new MimeMessageHelper(message, true, "utf-8");
helper.setFrom(setFrom);
helper.setTo(toMail);
helper.setSubject(title);
helper.setText(content,true);
mailSender.send(message);
}catch(Exception e) {
e.printStackTrace();
}
return Integer.toString(checkNum);
}
6. 테스트
만약 2차 인증을 사용하시는 사용자는 2차 인증에 들어가서 애플리케이션 비밀번호를 설정하고 그 비밀번호를 사용하셔야 합니다.
반응형