[Spring] Intellij로 Spring MVC Web 프로젝트 생성 방법 (Tomcat 서버, Log4j, Model and View 객체 설정)
딱지의겨울
·2021. 6. 4. 13:14
👾 개발 환경
- 운영체제: macOS BigSur
- 도구: IntelliJ IDEA ULTIMATE (2020.3 ver)
- 프레임워크: Spring + Maven
- 데이터베이스: Oracle
- 서버: Tomcat
1️⃣ 프로젝트 생성
(1) 'New Project' → 'Maven' 프로젝트 선택 → 'Create from archetype' 항목 체크 → 'webapp' 항목 체크 후 확인
(2) 프로젝트 이름 > 사용할 Maven 지정 후 Finish. 생성 후 pom.xml 이 자동으로 생성된다.
(3) main/java, resource 폴더가 생성이 안돼있어서 main 폴더 내에 java 디렉토리/resource 디렉토리를 추가했다. 디렉토리 추가를 클릭하면 Maven Source Directories 라고 아래에 뜨는데 거기에 java 폴더 선택 후 생성했다.
(4) 프로젝트 폴더 우클릭 > Add Framework Support > Spring MVC 선택후 추가
2️⃣ pom.xml 의존성 설정
- Spring, junit, lombok, log4j, servlet, oracle JDBC 등 필요한 라이브러리 의존성 설정 후 maven build 한다.
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>org.spdev</groupId>
<artifactId>spring-test</artifactId>
<version>1.0-SNAPSHOT</version>
<packaging>war</packaging>
<name>spring-test Maven Webapp</name>
<properties>
<java-version>1.8</java-version>
<org.springframework-version>5.2.3.RELEASE</org.springframework-version>
<org.aspectj-version>1.6.10</org.aspectj-version>
<org.slf4j-version>1.6.6</org.slf4j-version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>${org.springframework-version}</version>
<exclusions>
<exclusion>
<groupId>commons-logging</groupId>
<artifactId>commons-logging</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>${org.springframework-version}</version>
</dependency>
<dependency>
<groupId>org.aspectj</groupId>
<artifactId>aspectjrt</artifactId>
<version>${org.aspectj-version}</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>${org.slf4j-version}</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>jcl-over-slf4j</artifactId>
<version>${org.slf4j-version}</version>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
<version>${org.slf4j-version}</version>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
<exclusions>
<exclusion>
<groupId>javax.mail</groupId>
<artifactId>mail</artifactId>
</exclusion>
<exclusion>
<groupId>javax.jms</groupId>
<artifactId>jms</artifactId>
</exclusion>
<exclusion>
<groupId>com.sun.jdmk</groupId>
<artifactId>jmxtools</artifactId>
</exclusion>
<exclusion>
<groupId>com.sun.jmx</groupId>
<artifactId>jmxri</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>3.1.0</version>
</dependency>
<dependency>
<groupId>javax.servlet.jsp</groupId>
<artifactId>jsp-api</artifactId>
<version>2.1</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>jstl</artifactId>
<version>1.2</version>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-test</artifactId>
<version>${org.springframework-version}</version>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.18.0</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>com.oracle.database.jdbc</groupId>
<artifactId>ojdbc6</artifactId>
<version>11.2.0.4</version>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>2.5.1</version>
<configuration>
<source>1.8</source>
<target>1.8</target>
<compilerArgument>-Xlint:all</compilerArgument>
<showWarnings>true</showWarnings>
<showDeprecation>true</showDeprecation>
</configuration>
</plugin>
</plugins>
</build>
</project>
3️⃣ log4j 설정
로그를 남기기 위해 사용할 log4j.xml 파일을 resources 폴더에 생성.
📌log4j.xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE log4j:configuration PUBLIC "-//APACHE//DTD LOG4J 1.2//EN" "log4j.dtd">
<log4j:configuration>
<appender name="console" class="org.apache.log4j.ConsoleAppender">
<param name="Target" value="System.out"/>
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%-5p: %c - %m%n"/>
</layout>
</appender>
<logger name="org.springframework.core">
<level value="info"/>
</logger>
<logger name="org.springframework.beans">
<level value="info"/>
</logger>
<logger name="org.springframework.context">
<level value="info"/>
</logger>
<logger name="org.springframework.web">
<level value="info"/>
</logger>
<!-- Root Logger -->
<root>
<priority value="info"/>
<appender-ref ref="console"/>
</root>
</log4j:configuration>
4️⃣ Controller 추가 및 설정
(1) web.xml 에서 survlet-mapping의 url-pattern 을 / 로 변경
(2) java 폴더에 패키지 생성 > Controller 클래스 추가
(3) ViewResolver를 위한 views 폴더 추가: /WEB-INF/views/ , index.jsp 파일 이동
📌index.jsp
- Model and View 객체가 ${} (EL 표현식)을 읽어오지 못할 때 isELIgnored 설정을 Fasle 해주면 됨.
<%@page contentType="text/html;charset=UTF-8" language="java" %>
<!DOCTYPE html>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<html>
<head>
<%@ page isELIgnored="false" %>
<title>${title}</title>
</head>
<body>
<h2>${content}</h2>
</body>
</html>
(4) dispatcher-servlet.xml에 component-scan 설정, view 폴더 설정 추가
- mvc:annotation-driven Annotation 활성화
- context:component-scan component packcge 지정
- view resolver 폴더와 파일 형식 지정
- beans 에 각각 추가한 속성에 대한 링크는 꼭 빼먹지 말고 추가시키기. 선언 안되어있으면 "일치하는 와일드 카드 문자가 엄격하게 적용되지만 '----' 요소에 대한 선언을 찾을 수 없습니다." 라고 계속 오류 난다 🥲
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd">
<mvc:annotation-driven/> <!-- Annotation 활성화 -->
<context:component-scan base-package="org.sample.controller"/> <!-- Component Package 지정 -->
<!-- View Resolver 세팅 -->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/views/"/>
<property name="suffix" value=".jsp"/>
</bean>
</beans>
(5) SampleController 클래스 작성
📌SampleController.java
package org.sample.controller;
import lombok.extern.log4j.Log4j;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.servlet.ModelAndView;
@Controller
@Log4j
public class SampleController {
@RequestMapping("/")
public ModelAndView index(){
log.info("index controller start!!");
ModelAndView mav = new ModelAndView();
mav.addObject("title", "Spring Test");
mav.addObject("content", "Hello World!!");
mav.setViewName("index");
return mav;
}
}
5️⃣ Tomcat 서버 설정
(1) 화면 오른쪽 상단 'Add Configurations...' 클릭
(2) 'Templetes' → 'Tomcat Server' → 'Local' → 'Configure' 선택 후 Tomcat 저장되어있는 경로 지정
(3) Tomcat에 현재 프로젝트 추가
- 화면 오른쪽 상단 'Add Configurations...' → 상단 + 버튼 (Add New Configuration) 클릭
- Tomcat Server → Local 클릭
- 이름 지정
- Deployment tab > + 버튼 클릭 > 현재 프로젝트 선택
- Application Context: / 로 수정
(4) Tomcat 설정 완료 후 화면 상단에 추가된 모습
6️⃣ 실행
- ${title}, ${content} 데이터가 전달이 된 것을 확인할 수 있다.
- Log4j 실행 로그 확인
'Tools > Spring' 카테고리의 다른 글
[Spring] 스프링이 동작하는 과정 (의존성 주입 테스트) (0) | 2021.04.06 |
---|---|
[Spring] 스프링 기초: 의존성 주입 설정 (0) | 2021.04.06 |
[Spring] 스프링 프레임워크의 주요 특징 (0) | 2021.04.06 |