[Project] 자바 프로젝트 리팩토링 : Library Service(3) [Singleton 오류 해결 및 User 기능 리팩토링]

2023. 4. 12. 00:33·◈ Refactoring/Mini : Library Service📚
728x90


 

[Project] 자바 프로젝트 리팩토링 : Library Service(2) [Singleton 패턴 적용 및 Dao 분리]

[Project] 자바 프로젝트 리팩토링 : Library Service(1) [인터페이스 구분, 데이터 영속화, Lombok 적용] - 자바 프로젝트 리팩토링 : Library Service(1) 학원 다닐 때 만들었던 프로젝트들을 하나하나 리팩토링

yermi.tistory.com


- 자바 프로젝트 리팩토링 : Library Service(3)

동작이 잘하는지 테스트 겸 콘솔 실행을 하였는데 데이터가 3번 불러와졌다.
인스턴스 초기화 시점 때문에 그런 줄 알았으나, Singleton을 잘못 적용해서 그랬다.

각기 다른 인스턴스를 불러왔다. / Singleton이 의미 없어졌다..⭐

 

Singleton 디자인 패턴에 대한 이해가 부족한 탓에 발생한 오류..😥
이번 기회에 Singleton에 대해 좀 더 심도 깊게 이해하게 되었다.
// 기존 코드
private static UserDao userDao;

private UserDao() {}

public static UserDao getInstance() { // 이 부분이 문제였다
    return userDao ? null ? new UserDao() : userDao;
}

/* 변경 내용 */
private static UserDao userDao = new UserDao();

private UserDao() {}

public static UserDao getInstance() {
    return userDao;
}

이제 같은 데이터를 불러온다.


 

[JAVA] 멤버변수의 초기화 시기와 순서 [클래스변수와 인스턴스변수의 초기화 순서]

1. 멤버변수의 초기화 시기와 순서 클래스변수의 초기화 시점 : 클래스가 처음 로딩될 때 단 한 번 초기화 된다. 인스턴스변수의 초기화 시점 : 인스턴스가 생성될 때마다 각 인스턴스 별로 초기

yermi.tistory.com


- User 기능 리팩토링

제일 먼저 리팩토링한 기능은 회원 기능이였다. (구현의 난이도가 대여 > 도서 > 유저 순이였다.)
구현부인 service와 저장부인 dao를 분리하였고, 변수명이나 로직을 깔끔하게 정리하였다.

기존 계정생성 코드
dao와 service로 분리

 

기존 계정정보를 찾아오는 findUserbyID 메서드 또한 dao 안에서 조회할 수 있도록 바꾸었다.

findUserByID 메서드를 dao 안으로 넣었다. / 기존 코드(좌), 변경된 코드(우)

 

로직 상 가장 많이 바뀌었던 부분은 권한 부여 부분이였다.
당시에는 처음 만드는 것이다 보니 깔끔하지 못한 로직이였는데 간결하고 가독성 있게 변경하였다.

User를 변수로 받아 코드를 간결하게 변경하였다. / 기존 코드(좌), 변경된 코드(우)


- UserDao.java

import java.io.FileOutputStream;
import java.io.ObjectOutputStream;
import java.util.List;

import domain.User;
import util.DataUtil;

public class UserDao {
	
	// Singleton 패턴 적용
	private static UserDao userDao;
	
	private UserDao() {}
	
	public static UserDao getInstance() {
		return userDao == null ? new UserDao() : userDao;
	}
	
	private static List<User> users;
	
	// User 데이터 초기화
	static { users = DataUtil.initUsers(); }
	
	
	// 계정정보 목록조회
	public List<User> listUser() {
		return users;
	}
	
	// 계정정보 조회
	public User getUser(int id) { 
		for (User u : users) {
			if (u.getId() == id) {
				return u;
			}
		}
		return null;
	}
	
	// 계정정보 생성
	public void regUser(User user) {
		users.add(user);
		saveUser();
	}
	
	// 계정정보 수정
	public void modifyUser(User user) {
		User u = getUser(user.getId());
		u.setName(user.getName());
		u.setBirth(user.getBirth());
		u.setPhone(user.getPhone());
		saveUser();
	}
	
	// 계정정보 삭제
	public void removeUser(User user) {
		users.remove(user);
		saveUser();
	}
	
	// 계정권한 변경
	public void updateAuth(User user) {
		User u = getUser(user.getId());
		u.setAdmin(user.isAdmin());
		u.setBlacklist(user.isBlacklist());
		saveUser();
	}
	
	// User 데이터 저장
	private void saveUser() {
		ObjectOutputStream oos;
		try {
		oos = new ObjectOutputStream(new FileOutputStream("users.ser"));
		oos.writeObject(users);
		} catch (Exception e) {
			e.printStackTrace();
		}
	}

}

- UserServiceImpl.java

package service.user;

import static util.LibUtil.convert;
import static util.LibUtil.convertLeft;
import static util.LibUtil.nextInt;
import static util.LibUtil.nextLine;

import java.util.List;

import dao.RentDao;
import dao.UserDao;
import domain.Rent;
import domain.User;
import util.LibUtil;
import util.StringUtil;

public class UserServiceImpl implements UserService {
	
	private UserDao userDao = UserDao.getInstance();
	private RentDao rentDao = RentDao.getInstance();
	
	List<Rent> rents = rentDao.listRent();
	
	@Override
	public void listUser() {
		List<User> users = userDao.listUser();
		
		LibUtil.userIndex();
		for (User user : users) {
			System.out.print("│  " + convertLeft(StringUtil.userNameLength(user), 13) + "   │    ");
			System.out.print(convert(user.getBirth(), 6) + "    │ ");
			System.out.print(convert(user.getPhone(), 13) + " │  ");
			System.out.print(convertLeft(userState(user), 10) + "  │");
			System.out.printf("%n──────────────────────────────────────────────────────────────────%n");
		}
	}

	private String userState(User user) {
		if ( user.isAdmin() ) {
			return "  관리자";
		} else if ( user.isBlacklist() ) {
			return "블랙리스트";
		} else {
			return "";
		}
	}
	
	@Override
	public void regUser() {
		User user = new User();
		user.setName(nextLine("이름 > ", true, false));
		user.setBirth(StringUtil.birthLength(nextLine("생년월일[ex)921024] > ", false, true)));
		user.setPhone(StringUtil.pnLength(nextLine("전화번호[ex)01086940273] > ", false, true)));
		user.setId(nextInt("ID > "));
		user.setPw(nextLine("PW > "));
		
		userDao.regUser(user);

		System.out.println("계정생성이 완료되었습니다.");
	}

	@Override
	public void modifyUser() {
		User user = userDao.getUser(nextInt("수정할 계정의 ID > "));
		
		if ( user != null ) {
			System.out.println(user);

			user.setName(nextLine("Enter the name to be replaced. > ", true, false));
			user.setBirth(nextLine("Enter the birth to be replaced. > ", false, true));
			user.setPhone(StringUtil.pnLength(nextLine("Enter the P.N to be replaced. >", false, true)));
			
			userDao.modifyUser(user);
			System.out.println("수정 완료 되었습니다.");
			
		} else {
			System.out.println("등록된 적 없는 ID입니다.");
		}
	}

	@Override
	public void removeUser() {
		int id = nextInt("삭제할 회원의 ID를 입력하세요 > ");
		User user = userDao.getUser(id);
		int userID = 0;
		for (Rent r : rents) { // Rent 수정 시 변경 예정
			if ( user.getId() == r.getUserID() ) {
				userID = r.getUserID();
				break;
			}
		}
		// userID가 없는 아이디일 경우
		if ( user == null ) {
			System.out.println("잘못된 ID입니다.");
		}
		// 대여 중인 도서가 있는 경우
		else if ( userID != 0 ) {
			System.out.println("대여 중인 도서가 있습니다.");
		}
		// 관리자 계정일 경우
		else if ( user.isAdmin() ) {
			System.out.println("해당 계정은 관리자 계정입니다.");
		} else {
			userDao.removeUser(user);
			System.out.println("**삭제완료**");
		}
	}

	@Override
	public void updateAdmin(int id) {
		User user = userDao.getUser(id);
		
		if ( user != null ) {
			if( user.isBlacklist() ) {
				System.out.println("해당 계정은 블랙리스트입니다.");
			} else if ( !user.isAdmin() ) {
				user.setAdmin(true);
				System.out.printf("%s님께 관리자 권한을 부여하였습니다.%n", user.getName());
			} else {
				user.setAdmin(false);
				System.out.printf("%s님의 관리자 권한을 회수하였습니다.%n", user.getName());
			}
			userDao.updateAuth(user);
		} else {
			System.out.println("ID를 확인해주세요.");
		}
	}

	@Override
	public void updateBlackList(int id) {
		User user = userDao.getUser(id);
		
		if ( user != null ) {
			if( user.isAdmin() ) {
				System.out.println("관리자 계정입니다.");
			} else if ( !user.isBlacklist() ) {
				user.setBlacklist(true);
				System.out.printf("%s님이 블랙리스트로 등록 되었습니다.%n", user.getName());
			} else {
				user.setBlacklist(false);
				System.out.println("블랙리스트가 해제되었습니다.");
			}
			userDao.updateAuth(user);
		} else {
			System.out.println("ID를 확인해주세요.");
		}
	}

	@Override
	public int login(int id, String pw) {
		User user = userDao.getUser(id);
		
		if ( user != null ) {
			if ( user.getPw().equals(pw) ) {
				// 관리자 계정일 경우
				if ( user.isAdmin() ) {
					System.out.println();
					System.out.println("관리자 계정입니다.");
					return 1;
				}
				// 일반 계정일 경우
				else {
					System.out.println();
					System.out.printf("%s님, 안녕하세요.%n", user.getName());
					return 2;
				}
			}
		}
		// ID가 존재하지 않는 경우, PW가 일치하지 않는 경우
		System.out.println();
		System.out.println("ID 또는 pw를 확인해주세요.");
		return 0;
	}

}

Library Service : User 기능 리팩토링

- 기존의 코드

 

GitHub - kycasdzxc/human_project: 휴먼교육센터에서 진행한 프로젝트 🏫

휴먼교육센터에서 진행한 프로젝트 🏫. Contribute to kycasdzxc/human_project development by creating an account on GitHub.

github.com

- 리팩토링 코드

 

GitHub - kycasdzxc/LibraryService: Java Project 리팩토링 : Library Service 📚

Java Project 리팩토링 : Library Service 📚. Contribute to kycasdzxc/LibraryService development by creating an account on GitHub.

github.com


- Next) 자바 프로젝트 리팩토링 : Library Service(4)

 

[Project] 자바 프로젝트 리팩토링 : Library Service(4) [오버로딩을 활용한 도서정보 조회 기능 수정]

[Project] 자바 프로젝트 리팩토링 : Library Service(3) [Singleton 오류 해결 및 User 기능 리팩토링] [Project] 자바 프로젝트 리팩토링 : Library Service(2) [Singleton 패턴 적용 및 Dao 분리] [Project] 자바 프로젝트

yermi.tistory.com


728x90
'◈ Refactoring/Mini : Library Service📚' 카테고리의 다른 글
  • [Project] 자바 프로젝트 리팩토링 : Library Service(5) [Book 기능 리팩토링]
  • [Project] 자바 프로젝트 리팩토링 : Library Service(4) [오버로딩을 활용한 도서정보 조회 기능 수정]
  • [Project] 자바 프로젝트 리팩토링 : Library Service(2) [Singleton 패턴 적용 및 Dao 분리]
  • [Project] 자바 프로젝트 리팩토링 : Library Service(1) [인터페이스 구분, 데이터 영속화, Lombok 적용]
예르미(yermi)
예르미(yermi)
끊임없이 제 자신을 계발하는 개발자입니다👨🏻‍💻
  • 예르미(yermi)
    예르미의 코딩노트
    예르미(yermi)
  • 전체
    오늘
    어제
    • 분류 전체보기 (937)
      • ◎ Java (133)
        • Java☕ (93)
        • JSP📋 (26)
        • Applet🧳 (6)
        • Interview👨🏻‍🏫 (8)
      • ◎ JavaScript (48)
        • JavaScript🦎 (25)
        • jQuery🌊 (8)
        • React🌐 (2)
        • Vue.js🔰 (6)
        • Node.js🫒 (3)
        • Google App Script🐑 (4)
      • ◎ HTML5+CSS3 (17)
        • HTML5📝 (8)
        • CSS3🎨 (9)
      • ──────────── (0)
      • ▣ Framework (67)
        • Spring🍃 (36)
        • Spring Boot🍀 (12)
        • Bootstrap💜 (3)
        • Selenium🌕 (6)
        • MyBatis🐣 (10)
      • ▣ Tools (47)
        • API🎯 (18)
        • Library🎲 (15)
        • JitPack🚀 (3)
        • Jenkins👨🏻 (7)
        • Thymeleaf🌿 (4)
      • ▣ Server (32)
        • Apache Tomcat🐱 (14)
        • Apache HTTP Server🛡️ (1)
        • Nginx🧶 (7)
        • OracleXE💿 (4)
        • VisualSVN📡 (4)
      • ▣ OS : 운영체제 (18)
        • cmd : 명령프롬프트💻 (10)
        • Linux🐧 (8)
      • ▣ SQL : Database (56)
        • Oracle SQL🏮 (26)
        • PL SQL💾 (9)
        • MySQL🐬 (6)
        • MariaDB🦦 (6)
        • H2 Database🔠 (3)
        • SQL 실전문제🐌 (6)
      • ────────── (0)
      • ◈ Human Project (86)
        • Mini : Library Service📚 (15)
        • 화면 설계 [HTML]🐯 (10)
        • 서버 프로그램 구현🦁 (15)
        • Team : 여수어때🛫 (19)
        • Custom : Student🏫 (9)
        • Custom : Board📖 (18)
      • ◈ Yermi Project (40)
        • 조사모아(Josa-moa)📬 (5)
        • Riddle-Game🧩 (6)
        • 맛있을 지도🍚 (2)
        • 어디 가! 박대리!🙋🏻‍♂️ (5)
        • 조크베어🐻‍❄️ (4)
        • Looks Like Thirty🦉 (2)
        • Toy Project💎 (12)
        • 오픈소스 파헤치기🪐 (4)
      • ◈ Refactoring (15)
        • Mini : Library Service📚 (8)
        • 서버 프로그램 구현🦁 (1)
        • Team : 여수어때🛫 (0)
        • 쿼리 튜닝일지🔧 (6)
      • ◈ Coding Test (89)
        • 백준(BOJ)👨🏻‍💻 (70)
        • 프로그래머스😎 (2)
        • 코드트리🌳 (7)
        • 알고리즘(Algorithm)🎡 (10)
      • ◈ Study (102)
        • 기초튼튼 개발지식🥔 (25)
        • HTTP 웹 지식💡 (4)
        • 클린코드(Clean Code)🩺 (1)
        • 디자인패턴(GoF)🥞 (12)
        • 다이어그램(Diagram)📈 (4)
        • 파이썬(Python)🐍 (16)
        • 에러노트(Error Note)🧱 (34)
        • 웹 보안(Web Security)🔐 (6)
      • ◈ 공부모임 (39)
        • 혼공학습단⏰ (18)
        • 코드트리 챌린지👊🏻 (2)
        • 개발도서 100독👟 (8)
        • 나는 리뷰어다🌾 (11)
      • ◈ 자격증 공부 (37)
        • 정보처리기사🔱 (16)
        • 정보처리산업기사🔅 (9)
        • 컴퓨터활용능력 1급📼 (12)
      • ─────────── (0)
      • ◐ 기타 (113)
        • 알아두면 좋은 팁(tip)✨ (46)
        • 개발자의 일상🎈 (44)
        • 개발도서 서평🔍 (10)
        • 개발관련 세미나🎤 (2)
        • 블로그 꾸미기🎀 (9)
        • 사도신경 프로젝트🎚️ (2)
  • 인기 글

  • 최근 댓글

  • 태그

    html
    Error Note
    jsp
    백준 티어
    Database
    Project
    javascript
    프로그래밍
    SQL
    일상
    코딩
    spring
    자바스크립트
    백준
    Java
    꿀팁
    CSS
    코딩 테스트
    Oracle
    BOJ
  • 250x250
  • hELLO· Designed By정상우.v4.10.3
예르미(yermi)
[Project] 자바 프로젝트 리팩토링 : Library Service(3) [Singleton 오류 해결 및 User 기능 리팩토링]
상단으로

티스토리툴바