푸터 화면 구성 - footer.jsp
<%@ 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>
<!-- footer start -->
<footer>
<div id="in--wrap">
<div class="footer--top">
<div class="footer--logo">
<img src="/img/footer_logo.png" alt="하단 로고">
</div>
<div class="footer--tems">
<span><a href="">이용약관</a></span> <span> | </span> <span><a href="">개인정보처리방침</a></span>
</div>
</div>
<div class="footer--middle">상호 : (주)시네데이트 | 대표자 : 김근호 | 소재지 : 부산광역시 부산진구 중앙대로
749 범향빌딩 3층 | 개인정보관리책임자 : 변영준 | 이메일 :
cinedate@gmail.com | 전화번호 : 070-6975-5478</div>
<span class="copyright eng">copyright ⓒ 2024 cinedate. all rights reserved.</span>
</div>
</footer>
<!-- footer end -->
</body>
</html>
* TODO List
- 링크 연결
회원가입 기능 구현 - SignUpDTO
package com.tenco.movie.dto;
import com.tenco.movie.repository.model.User;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.ToString;
@Data
@AllArgsConstructor
@NoArgsConstructor
@Builder
@ToString
public class SignUpDTO {
private String loginId;
private String name;
private String password;
private String enterPassword;
private String email;
private String phoneNum;
private String year;
private String month;
private String day;
private String gender;
// 2단계 로직 - User Object
public User toUser() {
return User.builder()
.loginId(this.loginId)
.name(this.name)
.password(this.password)
.email(this.email)
.phoneNum(this.phoneNum)
.birthDay(year + "-" + month + "-" + day)
.gender(this.gender)
.build();
}
}
회원가입 기능 구현 - UserController
@PostMapping("/signUp")
public String signUpPage(SignUpDTO dto) {
System.out.println("회원가입 들어왔니?");
// 아이디 유효성 검사
// 아이디 비어져있을 때
if (dto.getLoginId() == null) {
throw new DataDeliveryException(Define.ENTER_YOUR_ID, HttpStatus.BAD_REQUEST);
}
// 아이디 빈칸일 때
if (dto.getLoginId().trim().isEmpty()) {
throw new DataDeliveryException(Define.ENTER_ID_TRIM, HttpStatus.BAD_REQUEST);
}
// 아이디 글자 제한
// if (dto.getLoginId().length() < 7 || dto.getLoginId().length() > 16) {
// throw new DataDeliveryException(Define.ENTER_ID_LENGTH, HttpStatus.BAD_REQUEST);
// }
// 아이디 중복 검사
// if (!dto.getLoginId().equals(dto.getLoginId())) {
// throw new DataDeliveryException(Define.DUPLICATION_ID, HttpStatus.BAD_REQUEST);
// }
// 이름 유효성 검사
// 이름 비어져있을 때
if (dto.getName() == null) {
throw new DataDeliveryException(Define.ENTER_YOUR_NAME, HttpStatus.BAD_REQUEST);
}
// 이름 빈칸
if (dto.getName().trim().isEmpty()) {
throw new DataDeliveryException(Define.ENTER_NAME_TRIM, HttpStatus.BAD_REQUEST);
}
// 비밀번호 유효성 검사
// 비밀번호가 없거나 비어 있을 때
if (dto.getPassword() == null || dto.getPassword().trim().isEmpty()) {
throw new DataDeliveryException(Define.ENTER_YOUR_PASSWORD, HttpStatus.BAD_REQUEST);
}
// 비밀번호 글자 제한
if (dto.getPassword().length() < 8 || dto.getPassword().length() > 20) {
throw new DataDeliveryException(Define.ENTER_PASSWORD_LENGTH, HttpStatus.BAD_REQUEST);
}
// 비밀번호 영어 포함
if (!dto.getPassword().matches(".*[A-Za-z].*")) {
throw new DataDeliveryException(Define.ENTER_PASSWORD_CHAR, HttpStatus.BAD_REQUEST);
}
// 비밀번호
if (!dto.getPassword().matches(".*\\d.*")) {
throw new DataDeliveryException(Define.ENTER_PASSWORD_NUM, HttpStatus.BAD_REQUEST);
}
// 비밀번호 특수 문자
if (!dto.getPassword().matches(".*[!@#$%^&*(),.?\":{}|<>].*")) {
throw new DataDeliveryException(Define.ENTER_PASSWORD_SPECIAL_CHAR, HttpStatus.BAD_REQUEST);
}
// 비밀번호 중복 검사
// if (!dto.getPassword().equals(dto.getEnterPassword())) {
// throw new DataDeliveryException(Define.NOT_VALIDATE_PASSWORD, HttpStatus.BAD_REQUEST);
// }
// 이메일 유효성 검사
// 이메일이 없거나 빈칸일 때
if (dto.getEmail() == null || dto.getEmail().trim().isEmpty()) {
throw new DataDeliveryException(Define.ENTER_YOUR_EMAIL, HttpStatus.BAD_REQUEST);
}
// 휴대폰 번호 유효성 검사
// 휴대폰 번호가 없거나 빈킨일 때
if (dto.getPhoneNum() == null || dto.getPhoneNum().trim().isEmpty()) {
throw new DataDeliveryException(Define.ENTER_YOUR_PHONE_NUM, HttpStatus.BAD_REQUEST);
}
// 휴대폰 번호가 10~11자가 아닐 때
if (!dto.getPhoneNum().matches("\\d{10,11}")) {
throw new DataDeliveryException(Define.NOT_VALIDATE_PHONE_NUM, HttpStatus.BAD_REQUEST);
}
// 휴대폰 번호 중복 검사
// if (!dto.getPhoneNum().equals(dto.getPhoneNum())) {
// throw new DataDeliveryException(Define.DUPLICATION_PASSWORD, HttpStatus.BAD_REQUEST);
// }
// 성별 유효성 검사
if (dto.getGender() == null || (!dto.getGender().equals("여") && !dto.getGender().equals("남"))) {
throw new DataDeliveryException(Define.ENTER_YOUR_GENDER, HttpStatus.BAD_REQUEST);
}
System.out.println("여기까지는 왔나?");
userService.createUser(dto);
System.out.println("여기는...?");
return "redirect:/user/signIn";
}
회원가입 기능 구현 - UserService
/**
* 회원 가입 기능
*
* @param dto
*/
@Transactional
public void createUser(SignUpDTO dto) {
System.out.println("여기로 왔냐");
int result = 0;
try {
System.out.println("여긴왔낭리ㅏㅓㅇ너ㅏㅣㅎ이ㅏㄴ");
result = userRepository.insert(dto.toUser());
System.out.println("성공했늬");
} catch (DataDeliveryException e) {
throw new DataDeliveryException(Define.DUPLICATION_NAME, HttpStatus.INTERNAL_SERVER_ERROR);
} catch (Exception e) {
throw new RedirectException(Define.UNKNOWN_ERROR, HttpStatus.SERVICE_UNAVAILABLE);
}
if (result != 1) {
throw new DataDeliveryException(Define.FAIL_TO_CREATE_USER, HttpStatus.INTERNAL_SERVER_ERROR);
}
}
회원가입 기능 구현 - UserRepository
package com.tenco.movie.repository.interfaces;
import java.util.List;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import com.tenco.movie.repository.model.User;
@Mapper
public interface UserRepository {
int insert(User user);
int updateById(User user);
int deleteById();
User findById(); // loginId
User findPassword();
List<User> findAll();
public User findByUsernameAndPassword(@Param("loginId") String loginId, @Param("password") String password);
public User findByLoginId(@Param("loginId") String loginId);
// 아이디 중복 검사
User isLoginIdDuplicated(String username);
// 휴대폰 번호 중복 검사
User isPhoneNumDuplicated(String phoneNum);
}
* TODO List
- 회원가입 예외처리 재확인
728x90
'My Proect > 파이널 프로젝트 - CineDate' 카테고리의 다른 글
10일차 - 소셜 로그인 API 구현 ( 구글, 네이버, 카카오 ) (2) | 2024.09.03 |
---|---|
8일차 - 아이디, 비밀번호 찾기 화면 및 기능 구현 (3) | 2024.09.02 |
5일차 - 회원가입 기능 구현 (2) | 2024.09.02 |
3일차 - 로그인 기능 구현 (0) | 2024.08.27 |
1일차 회원가입, 로그인 화면 구현 (1) | 2024.08.27 |