전체 글374 Multi-Thread 환경에서 싱글톤 패턴으로 구현했을 경우 발생할 수 있는 문제 Servlet과 Servlet Container Servlet은 Servlet Container가 시작할 때, 인스턴스를 하나만 생성하도록 다음과 같이 클래스를 정의했습니다. /** * 클라이언트로부터 모든 요청을 수신하는 서블릿 컨테이너 */ @Slf4j @WebServlet(name = "dispatcher", urlPatterns = "/", loadOnStartup = 1) public class DispatcherServlet extends HttpServlet { private Map requestMap; @Override public void init() { requestMap = new HashMap(); requestMap.put("/boards", new ShowBoardsControl.. 2023. 5. 29. Initialized DataBase / 톰캣(Tomcat) 실행 시 데이터베이스 초기화 Initialized DataBase 해당 글은 테스트 환경을 구성하기 위한 글입니다. 톰캣이 실행될 때마다 다음과 같은 작업이 자동화 됩니다. 기존 테이블을 모두 삭제 DROP TABLE … 테이블 생성 CREATE TABLE … 샘플 데이터 추가 INSERT INTO board (…) VALUES (…) 필자의 환경은 다음과 같습니다. Window Intellij Gradle Tomcat 9.0 MySQL 8.0 Gradle 의존성 추가 sql을 읽어 데이터베이스에 대한 초기화 작업을 하기 위해 스프링 프레임워크에서 제공하는 기능을 활용합니다. 관련된 모든 의존성에 대해서 기재했습니다. build.gradle implementation 'org.springframework:spring-core:5.3.. 2023. 5. 23. SQL Injection(SQL 삽입) SQL Injection(SQL 삽입)? SQL Injection은 악의적인 SQL문을 실행되게 함으로써 데이터 베이스를 비정상적으로 조작하는 코드 인젝션 공격 방법입니다. 주로 사용자(Client)가 입력한 데이터를 서버에서 필터링, 이스케이핑 작업을 스킵했을 때 발생할 수 있습니다. 다음과 같은 users 테이블과 데이터가 있습니다. 1. users 테이블 CREATE TABLE users ( id INT PRIMARY KEY, name VARCHAR(50), age INT, email VARCHAR(100), password VARCHAR(50) ); 2. users 테이블의 데이터 아래와 같은 로그인 화면에 로그인을 시도해보겠습니다. 그렇다면, 사용자는 다음과 같이 입력한다고 가정해보겠습니다. U.. 2023. 5. 22. 데이터 베이스 커넥션 객체를 전역변수로 선언한다면? 데이터 베이스 커넥션 해당 글은 데이터베이스 커넥션 풀 (DBCP)에 대해서는 다루지 않습니다. 웹 애플리케이션과 데이터베이스는 서로 다른 시스템이며, 데이터베이스 드라이버를 사용하여 데이터베이스에 연결해야 합니다. 데이터베이스 연결의 생애주기는 다음과 같습니다. 데이터베이스 드라이버를 사용하여 데이터베이스 연결 열기 데이터를 읽고 쓰기 위해 TCP 소켓 열기 TCP 소켓을 사용하여 데이터 통신 데이터베이스 연결 닫기 TCP 소켓 닫기 위와 같이 데이터베이스 연결을 수립하고, 해제하는 과정은 비용이 많이 들어가는 작업입니다. DAO 클래스의 Connection 객체 아래 설명할 코드는 데이터베이스 접근 로직을 담당하는 DAO 클래스입니다. 주의깊게 봐야할 점은 전역변수로 관리하고 있는 Connection.. 2023. 5. 21. ENUM 활용한 Refactoring - 파일 확장자에 대한 유효성 검사는 어떻게 할까? ENUM 활용한 Refactoring - 파일 확장자에 대한 유효성 검사는 어떻게 할까? > 현재 게시판을 주제로 한 프로젝트를 진행 중에 있습니다. 해당 게시판에서 파일의 업로드 개수는 최대 3개까지 가능합니다. 파일 확장자에 대한 유효성 검사를 진행한다고 가정해봅시다. 업로드 가능한 파일의 확장자는 다음과 같습니다. png, jpeg, bmp, gif, jpg, docs 이러한 요구사항이 있을때, 어떻게 유효성 검사를 하면 좋을지 고민해보았습니다. 다음과 같이 설계한 File 이라는 도메인 객체에서 유효성 검증을 진행했습니다. public class File { private final long FileIdx; private final String FileName; private final long .. 2023. 5. 21. 어떻게 하면 가독성 좋은 코드 코드가 될까? - 원시값을 포장한 도메인 객체 어떻게 하면 가독성 좋은 코드 코드가 될까? - 원시값을 포장한 도메인 객체 게시판을 주제로 한 프로젝트를 진행 중에 있습니다. 요구사항을 분석 후 도메인 객체를 아래와 같이 설계했습니다. public class Board { private final long boardId = 0; private final String category; private final String title; private final String writer; private final String content; private final String password; private final int hit = 0; private final LocalDateTime regDate = LocalDateTime.now(); publ.. 2023. 5. 21. 어떻게 하면 가독성 좋은 코드 코드가 될까? - 빌더 패턴(Builder Pattern) 어떻게 하면 가독성 좋은 코드 코드가 될까? - 빌더 패턴(Builder Pattern) 게시판을 주제로 한 프로젝트를 진행 중에 있습니다. 요구사항을 분석 후 도메인 객체를 아래와 같이 설계했습니다. public class Board { private final long boardId = 0; private final String category; private final String title; private final String writer; private final String content; private final String password; private final int hit = 0; private final LocalDateTime regDate = LocalDateTime.now(.. 2023. 5. 18. Why Override equals(), hashCode() Method? / 왜 equals, hashCode를 재정의할까? Why Override equals(), hashCode() Method? 일반화하는 것은 아니지만, 대부분의 웹 개발자라면, equals() 메서드를 재정의하는 이유에 대해서 알고 있을 것이다. 이부분에 대해서 정리해보자. Java에서 모든 클래스는 Object 클래스를 상속받는다. Object 클래스의 메서드 중 equals() 메서드가 정의되어 있으며, 이는 모든 클래스가 해당 메서드를 사용할 수 있다는 의미이다. 그렇다면, Object 클래스의 equals() 메서드에 대해서 알고가자. Object Class boolean equals(Object o) 이 메서드는 두 개의 참조 주소를 기반으로 객체가 동일한지 여부를 확인하는 데 사용된다. 두 객체가 동일한 경우 true를 반환하고 그렇지 않으면.. 2023. 5. 13. 전략 패턴(Strategy Pattern) RPG 게임에서의 캐릭터 구현 초기 요구사항은 다음과 같다. 전사의 등장 무기로 Sword(검)을 가진 전사(Warrior)가 존재하며, attack()을 사용해서 공격할 수 있다. 그렇다면, 다음과 같이 클래스를 생성할 수 있을 것이다. SwordWarrior Class void attack() public class SwordWarrior { public void name() { System.out.println("전사입니다."); } public void attack() { System.out.println("검을 휘둘러 공격합니다."); } } public class Application { public static void main(String[] args) { SwordWarrior sword.. 2023. 5. 13. 이전 1 2 3 4 5 6 7 8 ··· 42 다음