Spring 회원가입시 이메일 인증 후 회원가입
Back-End/Spring 2019. 8. 6. 15:58
기본 구조 1. 메인페이지에서 "회원가입" 을 클릭 2. 이메일 인증 페이지에서 이메일을 작성후 인증코드 전송 버튼을 클릭 3. 입력한 이메일에 들어가서 메일로 도착한 인증코드를 인증코드 입력창에 입력함 4. 인증코드가 맞으면 회원가입 창으로 이동하고, 인증코드가 틀리면 경고창을 출력한 후에 다시 입력하게 한다. |
1. pom.xml에 이메일 관련 라이브러리를 추가함
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 | <!-- 메일 전송 --> <!-- https://mvnrepository.com/artifact/org.springframework/spring-context-support --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context-support</artifactId> <version>${org.springframework-version}</version> </dependency> <!-- https://mvnrepository.com/artifact/com.sun.mail/javax.mail --> <dependency> <groupId>com.sun.mail</groupId> <artifactId>javax.mail</artifactId> <version>1.6.2</version> </dependency> <dependency> <groupId>javax.mail</groupId> <artifactId>mail</artifactId> <version>1.4</version> </dependency> | cs |
2. root-context.xml에 사용할 이메일에 대한 빈 작성 (나같은 경우는 gmail을 사용함)
1 2 3 4 5 6 7 8 9 10 11 12 13 | <!-- Gmail --> <bean id="mailSender" class="org.springframework.mail.javamail.JavaMailSenderImpl"> <property name="host" value="smtp.gmail.com" /> <property name="port" value="587" /> <property name="username" value="아이디@gmail.com" /> <property name="password" value="비밀번호" /> <property name="javaMailProperties"> <props> <prop key="mail.smtp.auth">true</prop> <prop key="mail.smtp.starttls.enable">true</prop> </props> </property> </bean> | cs |
3. view 파일들 작성
email.jsp (인증전 이메일 작성 페이지)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 | <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>Insert title here</title> </head> <body> <table border="1" width="300" height="300" align= "center"> <center> <span style="color: green; font-weight: bold;">이메일 인증 (이메일을 인증 받아야 다음 단계로 넘어갈 수 있습니다.)</span> <br> <br> <br> <br> <div style="text-align:center;"> <tr> <td> <center> <form action="auth.do" method="post"> <center> <br> <div> 이메일 : <input type="email" name="e_mail" placeholder=" 이메일주소를 입력하세요. "> </div> <br> <br> <button type="submit" name="submit">이메일 인증받기 (이메일 보내기)</button> </div> </td> </tr> </center> </table> </form> </center> </body> </html> | cs |
email_injeung.jsp (인증번호를 입력하는 jsp 페이지)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 | <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>Insert title here</title> </head> <body> <table border="1" width="300" height="300" align= "center"> <center> <span style="color: green; font-weight: bold;">입력한 이메일로 받은 인증번호를 입력하세요. (인증번호가 맞아야 다음 단계로 넘어가실 수 있습니다.)</span> <br> <br> <br> <br> <div style="text-align:center;"> <tr> <td> <center> <form action="join_injeung.do${dice}" method="post"> //받아온 인증코드를 컨트롤러로 넘겨서 일치하는지 확인 <center> <br> <div> 인증번호 입력 : <input type="number" name="email_injeung" placeholder=" 인증번호를 입력하세요. "> </div> <br> <br> <button type="submit" name="submit">인증번호 전송</button> </div> </td> </tr> </center> </table> </form> </center> </body> </html> | cs |
4. 컨트롤러 작성 (MemberController.java) 중 일부
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 | @Controller //컨트롤러 빈 선언 public class MemberController { @Inject //서비스를 호출하기 위해서 의존성을 주입 JavaMailSender mailSender; //메일 서비스를 사용하기 위해 의존성을 주입함. MemberService memberservice; //서비스를 호출하기 위해 의존성을 주입 //로깅을 위한 변수 private static final Logger logger= LoggerFactory.getLogger(MemberController.class); private static final String String = null; // mailSending 코드 @RequestMapping( value = "/member/auth.do" , method=RequestMethod.POST ) public ModelAndView mailSending(HttpServletRequest request, String e_mail, HttpServletResponse response_email) throws IOException { Random r = new Random(); int dice = r.nextInt(4589362) + 49311; //이메일로 받는 인증코드 부분 (난수) String setfrom = "dlgkstjq623@gamil.com"; String tomail = request.getParameter("e_mail"); // 받는 사람 이메일 String title = "회원가입 인증 이메일 입니다."; // 제목 String content = System.getProperty("line.separator")+ //한줄씩 줄간격을 두기위해 작성 System.getProperty("line.separator")+ "안녕하세요 회원님 저희 홈페이지를 찾아주셔서 감사합니다" +System.getProperty("line.separator")+ System.getProperty("line.separator")+ " 인증번호는 " +dice+ " 입니다. " +System.getProperty("line.separator")+ System.getProperty("line.separator")+ "받으신 인증번호를 홈페이지에 입력해 주시면 다음으로 넘어갑니다."; // 내용 try { MimeMessage message = mailSender.createMimeMessage(); MimeMessageHelper messageHelper = new MimeMessageHelper(message, true, "UTF-8"); messageHelper.setFrom(setfrom); // 보내는사람 생략하면 정상작동을 안함 messageHelper.setTo(tomail); // 받는사람 이메일 messageHelper.setSubject(title); // 메일제목은 생략이 가능하다 messageHelper.setText(content); // 메일 내용 mailSender.send(message); } catch (Exception e) { System.out.println(e); } ModelAndView mv = new ModelAndView(); //ModelAndView로 보낼 페이지를 지정하고, 보낼 값을 지정한다. mv.setViewName("/member/email_injeung"); //뷰의이름 mv.addObject("dice", dice); System.out.println("mv : "+mv); response_email.setContentType("text/html; charset=UTF-8"); PrintWriter out_email = response_email.getWriter(); out_email.println("<script>alert('이메일이 발송되었습니다. 인증번호를 입력해주세요.');</script>"); out_email.flush(); return mv; } //이메일 인증 페이지 맵핑 메소드 @RequestMapping("/member/email.do") public String email() { return "member/email"; } //이메일로 받은 인증번호를 입력하고 전송 버튼을 누르면 맵핑되는 메소드. //내가 입력한 인증번호와 메일로 입력한 인증번호가 맞는지 확인해서 맞으면 회원가입 페이지로 넘어가고, //틀리면 다시 원래 페이지로 돌아오는 메소드 @RequestMapping(value = "/member/join_injeung.do{dice}", method = RequestMethod.POST) public ModelAndView join_injeung(String email_injeung, @PathVariable String dice, HttpServletResponse response_equals) throws IOException { System.out.println("마지막 : email_injeung : "+email_injeung); System.out.println("마지막 : dice : "+dice); //페이지이동과 자료를 동시에 하기위해 ModelAndView를 사용해서 이동할 페이지와 자료를 담음 ModelAndView mv = new ModelAndView(); mv.setViewName("/member/join.do"); mv.addObject("e_mail",email_injeung); if (email_injeung.equals(dice)) { //인증번호가 일치할 경우 인증번호가 맞다는 창을 출력하고 회원가입창으로 이동함 mv.setViewName("member/join"); mv.addObject("e_mail",email_injeung); //만약 인증번호가 같다면 이메일을 회원가입 페이지로 같이 넘겨서 이메일을 //한번더 입력할 필요가 없게 한다. response_equals.setContentType("text/html; charset=UTF-8"); PrintWriter out_equals = response_equals.getWriter(); out_equals.println("<script>alert('인증번호가 일치하였습니다. 회원가입창으로 이동합니다.');</script>"); out_equals.flush(); return mv; }else if (email_injeung != dice) { ModelAndView mv2 = new ModelAndView(); mv2.setViewName("member/email_injeung"); response_equals.setContentType("text/html; charset=UTF-8"); PrintWriter out_equals = response_equals.getWriter(); out_equals.println("<script>alert('인증번호가 일치하지않습니다. 인증번호를 다시 입력해주세요.'); history.go(-1);</script>"); out_equals.flush(); return mv2; } return mv; } | cs |
5. MailHandler.java
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 | package com.example.hansub_project; import java.io.UnsupportedEncodingException; import javax.activation.DataSource; import javax.mail.MessagingException; import javax.mail.internet.MimeMessage; import org.springframework.mail.javamail.JavaMailSender; import org.springframework.mail.javamail.MimeMessageHelper; public class MailHandler { private JavaMailSender mailSender; private MimeMessage message; private MimeMessageHelper messageHelper; public MailHandler(JavaMailSender mailSender) throws MessagingException { this.mailSender = mailSender; message = this.mailSender.createMimeMessage(); messageHelper = new MimeMessageHelper(message, true, "UTF-8"); } public void setSubject(String subject) throws MessagingException { messageHelper.setSubject(subject); // 이메일 타이틀 } public void setText(String htmlContent) throws MessagingException { messageHelper.setText(htmlContent, true); // 이메일 TEXT 부분 } public void setFrom(String email, String name) throws UnsupportedEncodingException, MessagingException { messageHelper.setFrom(email, name); // 보내는 사람 이메일 } public void setTo(String email) throws MessagingException { messageHelper.setTo(email); //받는 사람 이메일 } public void addInline(String contentId, DataSource dataSource) throws MessagingException { messageHelper.addInline(contentId, dataSource); } public void send() { try { mailSender.send(message); }catch (Exception e) { e.printStackTrace(); } } } | cs |
6. MemberDTO
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 | package com.example.hansub_project.model.member.dto; import java.util.Date; public class MemberDTO { private String user_id; //아이디 private String member_pass; //비밀번호 private String e_mail; //이메일 private Date join_date; //가입일자 public String getUser_id() { return user_id; } public void setUser_id(String user_id) { this.user_id = user_id; } public String getMember_pass() { return member_pass; } public void setMember_pass(String member_pass) { this.member_pass = member_pass; } public String getE_mail() { return e_mail; } public void setE_mail(String e_mail) { this.e_mail = e_mail; } public Date getJoin_date() { return join_date; } public void setJoin_date(Date join_date) { this.join_date = join_date; } @Override public String toString() { return "MemberDTO [user_id=" + user_id + ", member_pass=" + member_pass + ", e_mail=" + e_mail + ", join_date=" + join_date + "]"; } } | cs |
7. 서비스 , dao, mapper
MemberService.java
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 | package com.example.hansub_project.service.member; import java.util.List; import java.util.Map; import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpSession; import com.example.hansub_project.model.member.dto.MemberDTO; public interface MemberService { public void join (Map<String, Object>map,MemberDTO dto); //회원가입 관련 public boolean loginCheck(MemberDTO dto, HttpSession session); //로그인 관련 public String find_idCheck(MemberDTO dto); //아이디 찾기 관련 public String find_passCheck(MemberDTO dto); //비밀번호 찾기 관련 public void authentication(MemberDTO dto); //회원 인증관련 메소드 public void pass_change(Map<String, Object> map, MemberDTO dto)throws Exception; //비밀번호 변경 public boolean email_check(String e_mail) throws Exception; //이메일 중복확인을 하는 메소드 public boolean join_id_check(String user_id) throws Exception; //회원가입시 아이디를 체크하는 메소드 public List<MemberDTO> member_profile(String user_id) throws Exception; //회원의 프로필을 볼 수 있는 메소드 } | cs |
MemberServiceImpl.java
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 | package com.example.hansub_project.service.member; import java.io.PrintWriter; import java.util.List; import java.util.Map; import javax.inject.Inject; import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpSession; import org.springframework.mail.javamail.JavaMailSender; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; import com.example.hansub_project.MailHandler; import com.example.hansub_project.model.member.dao.MemberDAO; import com.example.hansub_project.model.member.dto.MemberDTO; @Service //서비스 빈 선언 public class MemberSerivceImpl implements MemberService { @Inject MemberDAO memberdao; //dao를 사용하기 위해 의존성을 주입 private JavaMailSender mailSender; @Override //회원가입 메소드, Map과 dto를 갖이 넘김 public void join(Map<String, Object>map,MemberDTO dto) { memberdao.join(map,dto); } @Override //로그인 관련 메소드 (세션에 아이디와 비밀번호를 저장) public boolean loginCheck(MemberDTO dto, HttpSession session) { boolean result = memberdao.loginCheck(dto); if(result) { //로그인 성공 session.setAttribute("user_id", dto.getUser_id()); session.setAttribute("member_pass", dto.getMember_pass()); System.out.println(session.getAttribute("user_id")); System.out.println(session.getAttribute("member_pass")); } return result; } //아이디 찾기 @Override public String find_idCheck(MemberDTO dto) { String id = memberdao.find_idCheck(dto); return id; } //비밀번호 찾기 @Override public String find_passCheck(MemberDTO dto) { String pass = memberdao.find_passCheck(dto); return pass; } @Override public void authentication(MemberDTO dto) { memberdao.authentication(dto); } @Override public void pass_change(Map<String, Object> map, MemberDTO dto) throws Exception { memberdao.pass_change(map,dto); } //이메일 중복 확인 @Override public boolean email_check(String e_mail) throws Exception{ boolean result = memberdao.email_check(e_mail); return result; } //아이디 중복 확인 @Override public boolean join_id_check(String user_id) throws Exception { boolean result = memberdao.join_id_check(user_id); return result; } //자신의 프로필을 볼 수 있게 하는 메소드 @Override public List<MemberDTO> member_profile(String user_id) throws Exception{ return memberdao.member_profile(user_id); } } | cs |
MemberDAO.java
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 | package com.example.hansub_project.model.member.dao; import java.util.HashMap; import java.util.List; import java.util.Map; import com.example.hansub_project.model.member.dto.MemberDTO; public interface MemberDAO { public void join(Map<String, Object>map,MemberDTO dto); //회원가입 관련 public boolean loginCheck(MemberDTO dto); //로그인 관련 public String find_idCheck(MemberDTO dto); //아이디 찾기 public String find_passCheck(MemberDTO dto); //비밀번호 찾기 public void authentication(MemberDTO dto); //소셜 로그인 회원인증 관련 메소드 public void pass_change(Map<String, Object> map, MemberDTO dto)throws Exception; //비밀번호 변경 public boolean email_check(String e_mail) throws Exception; //이메일 중복 확인 public boolean join_id_check(String user_id)throws Exception; //아이디 중복 확인 public List<MemberDTO> member_profile(String user_id) throws Exception; //회원의 프로필 정보를 확인할 수 있는 메소드 } | cs |
MemberDAOImpl.java
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 | package com.example.hansub_project.model.member.dao; import java.util.HashMap; import java.util.List; import java.util.Map; import javax.inject.Inject; import javax.mail.Session; import org.apache.ibatis.session.SqlSession; import org.springframework.stereotype.Repository; import com.example.hansub_project.model.member.dto.MemberDTO; @Repository public class MemberDAOImpl implements MemberDAO { @Inject SqlSession sqlSession; //회원가입 관련 메소드 @Override public void join(Map<String, Object>map, MemberDTO dto) { map.get("user_id"); map.get("member_pass"); map.get("e_mail"); sqlSession.insert("member.insertUser",map); } //로그인관련 메소드 @Override public boolean loginCheck(MemberDTO dto) { String name =sqlSession.selectOne("member.login_check", dto); //조건식 ? true일때의 값 : false일때의 값 return (name==null) ? false : true; } //아이디 찾기 관련 메소드 @Override public String find_idCheck(MemberDTO dto) { String id = sqlSession.selectOne("member.find_id_check", dto); return id; } //비밀번호 찾기 관련 메소드 @Override public String find_passCheck(MemberDTO dto) { String pass = sqlSession.selectOne("member.find_pass_check", dto); return pass; } //회원 인증 관련 메소드 //버튼을 클릭한 회원의 정보를 회원 테이블에 저장해서 사용할 수 있게 함 @Override public void authentication(MemberDTO dto) { sqlSession.insert("member.authentication", dto); } @Override public void pass_change(Map<String, Object> map, MemberDTO dto)throws Exception{ map.get("member_pass"); map.get("e_mail"); sqlSession.update("member.pass_change", map); } @Override public boolean email_check(String e_mail) throws Exception { String email =sqlSession.selectOne("member.email_check", e_mail); //조건식 ? true일때의 값 : false일때의 값 return (email==null) ? true : false; } @Override public boolean join_id_check(String user_id) throws Exception { String user_id1 =sqlSession.selectOne("member.join_id_check", user_id); //조건식 ? true일때의 값 : false일때의 값 return (user_id1==null) ? true : false; } //회원의 프로필 정보를 리턴한다. @Override public List<MemberDTO> member_profile(String user_id) throws Exception { return sqlSession.selectList("member.member_profile", user_id); } } | cs |
memberMapper.xml
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 | <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <!-- 다른 mapper와 중복되지 않도록 네임스페이스 기재 --> <!-- 회원가입 --> <mapper namespace="member"> <!-- 회원가입 mapper --> <insert id="insertUser" parameterType="hashMap"> insert into member (USER_ID, MEMBER_PASS, E_MAIL) values (#{user_id}, #{member_pass}, #{e_mail}) </insert> <!-- 로그인 관련 mapper--> <select id = "login_check" parameterType= "com.example.hansub_project.model.member.dto.MemberDTO" resultType="String"> select user_id from member where user_id=#{user_id} and member_pass=#{member_pass} </select> <!-- 아이디 찾기 관련 mapper --> <select id = "find_id_check" parameterType= "com.example.hansub_project.model.member.dto.MemberDTO" resultType="String"> select user_id from member where e_mail=#{e_mail} </select> <!-- 비밀번호 찾기 관련 mapper --> <select id = "find_pass_check" parameterType= "com.example.hansub_project.model.member.dto.MemberDTO" resultType="String"> select member_pass from member where user_id=#{user_id} and e_mail=#{e_mail} </select> <!-- 소셜 로그인 관련 mapper --> <!-- 소셜 로그인 한 후에 회원 인증 버튼을 누르면 소셜 로그인 api에서 받아온 정보를 데이터 베이스의 member테이블에 저장하도록 하는 쿼리 --> <insert id="authentication" parameterType="com.example.hansub_project.model.member.dto.MemberDTO"> insert into member (USER_ID, MEMBER_PASS, E_MAIL) values (#{user_id}, 0, #{e_mail}) </insert> <!-- 비밀번호 변경 관련 mapper --> <update id = "pass_change" parameterType="hashMap"> update member set member_pass=#{member_pass} where e_mail=#{e_mail} </update> <!-- 이메일 중복확인 관련 mapper--> <select id = "email_check" resultType="String"> select e_mail from member where e_mail=#{e_mail} </select> <!-- 아이디 중복확인 관련 mapper--> <select id = "join_id_check" resultType="String"> select user_id from member where user_id=#{user_id} </select> <!-- 회원 프로필 확인 mapper --> <select id = "member_profile" resultType="com.example.hansub_project.model.member.dto.MemberDTO"> select user_id, e_mail, join_date from member where user_id=#{user_id} </select> </mapper> | cs |
'Back-End > Spring' 카테고리의 다른 글
Spring 게시판 목록 (내 프로젝트에 적용) (0) | 2019.08.09 |
---|---|
Spring 이메일 발송 (0) | 2019.08.07 |
Spring 에서 Bean 등록 방법 (0) | 2019.08.05 |
스프링 - 핸드폰 문자 보내기 구현해보기 (1) | 2019.07.31 |
스프링 - 페이스북 로그인 구현 (페이스북 아이디로 로그인) (0) | 2019.07.30 |