DB 설정하기

  • 이 블로그의 글은 JAVA DB 엔지니어링 과정 수업을 위해 작성된 글입니다.
  • 이미지로 인해 글이 길어질 수 있습니다.

1. MySQL DB(스키마) 생성

 - MySQL Workbench를 실행하여 root 또는 DB 생성 권한이 있는 다른 아이디로 접속합니다.

 - 접속 과정은 다음을 참고하세요.


 - 접속 후 화면


 - Schemas 탭에서 좌측 SHEMAS 빈 여백에 우클릭 후 Create Schema를 클릭합니다.


 - Schema 이름 입력 후 Apply를 눌러 Schema(DB)를 생성합니다. 

 - 참고

      • DB 종류에 따라 Schema와 DB를 취급하는 방식이 다릅니다.

      • MySQL에서는 Schema와 DB가 같은 것으로 취급합니다. 


2. 테이블 생성하기

 - 회원 테이블, 게시판 테이블, 파일 테이블을 생성합니다.

 - 회원 테이블(memeber)의 속성은 다음과 같습니다.

    • 모든 속성은 필수 항목입니다.
    • 아이디(id) : 기본키로 문자열로 되어 있으며 최대 15까지로 설정했습니다.
    • 비밀번호(pw) : 문자열로 되어 있으며 암호화로 인해 최대 255자까지로 설정했습니다.
    • 성별(gender) : 문자 1자로 되어 있으며 남자는 'M', 여자는 'F'로 저장합니다.
    • 이메일(email) : 문자열로 되어 있습니다.
    • 권한(authority) : 문자열로 되어 있으며 최대 45자까지 설정 가능하고 기본값은 'USER' 입니다.

 - 회원 테이블의 DDL은 다음과 같습니다.

1
2
3
4
5
6
7
8
9
CREATE TABLE `member` (
  `id` varchar(15NOT NULL,
  `pw` varchar(255NOT NULL,
  `gender` varchar(1NOT NULL DEFAULT 'M',
  `email` varchar(45NOT NULL,
  `name` varchar(45NOT NULL DEFAULT ' ',
  `authority` varchar(45NOT NULL DEFAULT 'USER',
  PRIMARY KEY (`id`)
ENGINE=InnoDB DEFAULT CHARSET=utf8;
cs


 - 게시판 테이블(board)의 속성은 다음과 같습니다.

    • 번호(num) : 정수로 기본키이며 정보 추가 시 자동으로 증가합니다.
    • 제목(title) : 문자열로 되어 있으며 최대 255까지로 설정했습니다.
    • 내용(contents) : 긴 문자열로 되어 있습니다.(LONG TEXT)
    • 작성자(writer) : 문자열로 되어 있으며 최대 15까지로 설정되어 있습니다. 그리고 회원 테이블의 기본키인 아이디와 외래키로 연결되어 있습니다.
    • 등록일(registered) : DATETIME으로 되어 있으며 등록할 당시의 시간을 저장합니다.
    • 조회수(views) : 정수로 되어있습니다.
    • 게시글 등록 여부(valid) : 문자 1자로 되어 있으며 게시글이 게시된 상태면 'I', 삭제된 상태면 'D'로 저장합니다.
    • 게시판 테이블의 DDL은 다음과 같습니다.
1
2
3
4
5
6
7
8
9
10
11
12
13
CREATE TABLE `board` (
  `num` int(11NOT NULL AUTO_INCREMENT,
  `title` varchar(255NOT NULL,
  `contents` longtext NOT NULL,
  `writer` varchar(15NOT NULL,
  `registered` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP,
  `views` int(11NOT NULL DEFAULT '0',
  `valid` varchar(1NOT NULL DEFAULT 'I',
  PRIMARY KEY (`num`),
  KEY `writer_idx` (`writer`),
  CONSTRAINT `writer` FOREIGN KEY (`writer`REFERENCES `member` (`id`)
ENGINE=InnoDB AUTO_INCREMENT=40 DEFAULT CHARSET=utf8;
cs

 - 파일 테이블(file)의 속성은 다음과 같습니다.

  • 번호(num) : 정수로 기본키이며 정보 추가 시 자동으로 증가합니다.
  • 게시글 번호(board) : 정수로 되어 있습니다. 그리고 게시판 테이블의 기본키인 게시판 번호와 외래키로 연결되어 있습니다.
  • 첨부파일명(name) : 문자열로 되어 있으며 최대 255자까지로 설정되어 있으며, NULL 값을 허용하지 않습니다.
  • 상태(state) : 문자로 되어 있으며 기본값이 'I'이고 삭제되면 'D'를 저장합니다.
  • 파일 테이블의 DDL은 다음과 같습니다.
1
2
3
4
5
6
7
8
9
CREATE TABLE `file` (
  `num` int(11NOT NULL AUTO_INCREMENT,
  `board` int(11NOT NULL,
  `name` varchar(255NOT NULL,
  `state` varchar(1NOT NULL DEFAULT 'I',
  PRIMARY KEY (`num`),
  KEY `board_idx` (`board`),
  CONSTRAINT `board` FOREIGN KEY (`board`REFERENCES `board` (`num`)
ENGINE=InnoDB AUTO_INCREMENT=40 DEFAULT CHARSET=utf8;
cs

 - Schemas탭에서 테이블을 생성할 DB를 선택합니다.(spring)


 - 위의 회원테이블, 게시판 테이블, 파일 테이블에 대한 DDL를 이용하여 테이블을 생성합니다.

 - 빈 SQL FILE에 DDL을 복사하여 붙여넣고 실행합니다.

 - Schemas탭에서 새로고침 후 DB를 더블클릭한 후 Tables를 살펴보면 회원 테이블과 게시판 테이블이 생성된 것을 확인할 수 있습니다.

수고하셨습니다.

템플릿 설정하기(타일즈)

  • 이 블로그의 글은 JAVA DB 엔지니어링 과정 수업을 위해 작성된 글입니다.

  • 이미지로 인해 글이 길어질 수 있습니다.

  1. 타일즈 의존성 추가 (pom.xml)

  2. View Resolver 등록 (servlet-context.xml)

  3. 타일즈 설정 추가

  4. 기본 레이아웃 설정

  5. 적용

  6. git 관리

타일즈 의존성 추가

  • pom.xml 파일 안 <proertiies> 태그 안에 스프링 프레임워크 버전 수정

1
<org.springframework-version>5.1.8.RELEASE</org.springframework-version>
cs

  • pom.xml 파일안 <proertiies> 태그 안에 타일즈 버전 추가

1
<org.apache.tiles-version>3.0.8</org.apache.tiles-version>
cs


  • pom.xml 파일 안 <dependencies> 태그 안에 의존성 추가

    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
    <!-- Tiles -->
    <dependency>
        <groupId>org.apache.tiles</groupId>
        <artifactId>tiles-servlet</artifactId>
        <version>${org.apache.tiles-version}</version>
    </dependency>
    <dependency>
        <groupId>org.apache.tiles</groupId>
        <artifactId>tiles-api</artifactId>
        <version>${org.apache.tiles-version}</version>
    </dependency>
    <dependency>
        <groupId>org.apache.tiles</groupId>
        <artifactId>tiles-jsp</artifactId>
        <version>${org.apache.tiles-version}</version>
    </dependency>
    <dependency>
        <groupId>org.apache.tiles</groupId>
        <artifactId>tiles-core</artifactId>
        <version>${org.apache.tiles-version}</version>
    </dependency> 
    <dependency>
        <groupId>org.apache.tiles</groupId>
        <artifactId>tiles-template</artifactId>
        <version>${org.apache.tiles-version}</version>
    </dependency>
    cs


  • 위 단계에서 다음과 같은 에러가 나올 시

    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
    Failure to transfer commons-beanutils:commons-beanutils:jar:1.8.0 from https://repo.maven.apache.org/maven2 was cached in the local repository, resolution will not be reattempted until the update interval of central has elapsed or updates are forced. Original error: Could not transfer artifact commons-beanutils:commons-beanutils:jar:1.8.0 from/to central (https://repo.maven.apache.org/maven2): The operation was cancelled.
    org.eclipse.aether.transfer.ArtifactTransferException: Failure to transfer commons-beanutils:commons-beanutils:jar:1.8.0 from https://repo.maven.apache.org/maven2 was cached in the local repository, resolution will not be reattempted until the update interval of central has elapsed or updates are forced. Original error: Could not transfer artifact commons-beanutils:commons-beanutils:jar:1.8.0 from/to central (https://repo.maven.apache.org/maven2): The operation was cancelled.
        at org.eclipse.aether.internal.impl.DefaultUpdateCheckManager.newException(DefaultUpdateCheckManager.java:226)
        at org.eclipse.aether.internal.impl.DefaultUpdateCheckManager.checkArtifact(DefaultUpdateCheckManager.java:192)
        at org.eclipse.aether.internal.impl.DefaultArtifactResolver.gatherDownloads(DefaultArtifactResolver.java:564)
        at org.eclipse.aether.internal.impl.DefaultArtifactResolver.performDownloads(DefaultArtifactResolver.java:482)
        at org.eclipse.aether.internal.impl.DefaultArtifactResolver.resolve(DefaultArtifactResolver.java:400)
        at org.eclipse.aether.internal.impl.DefaultArtifactResolver.resolveArtifacts(DefaultArtifactResolver.java:225)
        at org.eclipse.aether.internal.impl.DefaultRepositorySystem.resolveDependencies(DefaultRepositorySystem.java:335)
        at org.apache.maven.project.DefaultProjectDependenciesResolver.resolve(DefaultProjectDependenciesResolver.java:202)
        at org.apache.maven.project.DefaultProjectBuilder.resolveDependencies(DefaultProjectBuilder.java:225)
        at org.apache.maven.project.DefaultProjectBuilder.build(DefaultProjectBuilder.java:198)
        at org.apache.maven.project.DefaultProjectBuilder.build(DefaultProjectBuilder.java:122)
        at org.eclipse.m2e.core.internal.embedder.MavenImpl.readMavenProject(MavenImpl.java:630)
        at org.eclipse.m2e.core.internal.project.registry.DefaultMavenDependencyResolver.resolveProjectDependencies(DefaultMavenDependencyResolver.java:63)
        at org.eclipse.m2e.core.internal.project.registry.ProjectRegistryManager.refreshPhase2(ProjectRegistryManager.java:551)
        at org.eclipse.m2e.core.internal.project.registry.ProjectRegistryManager.lambda$2(ProjectRegistryManager.java:515)
        at org.eclipse.m2e.core.internal.embedder.MavenExecutionContext.executeBare(MavenExecutionContext.java:177)
        at org.eclipse.m2e.core.internal.embedder.MavenExecutionContext.execute(MavenExecutionContext.java:151)
        at org.eclipse.m2e.core.internal.project.registry.ProjectRegistryManager.refresh(ProjectRegistryManager.java:513)
        at org.eclipse.m2e.core.internal.project.registry.ProjectRegistryManager.refresh(ProjectRegistryManager.java:365)
        at org.eclipse.m2e.core.internal.project.registry.ProjectRegistryManager.refresh(ProjectRegistryManager.java:312)
        at org.eclipse.m2e.core.internal.builder.MavenBuilder$BuildMethod.getProjectFacade(MavenBuilder.java:155)
        at org.eclipse.m2e.core.internal.builder.MavenBuilder$BuildMethod$1.call(MavenBuilder.java:90)
        at org.eclipse.m2e.core.internal.embedder.MavenExecutionContext.executeBare(MavenExecutionContext.java:177)
        at org.eclipse.m2e.core.internal.embedder.MavenExecutionContext.execute(MavenExecutionContext.java:151)
        at org.eclipse.m2e.core.internal.embedder.MavenExecutionContext.execute(MavenExecutionContext.java:99)
        at org.eclipse.m2e.core.internal.builder.MavenBuilder$BuildMethod.execute(MavenBuilder.java:87)
        at org.eclipse.m2e.core.internal.builder.MavenBuilder.build(MavenBuilder.java:201)
        at org.eclipse.core.internal.events.BuildManager$2.run(BuildManager.java:833)
        at org.eclipse.core.runtime.SafeRunner.run(SafeRunner.java:45)
        at org.eclipse.core.internal.events.BuildManager.basicBuild(BuildManager.java:220)
        at org.eclipse.core.internal.events.BuildManager.basicBuild(BuildManager.java:263)
        at org.eclipse.core.internal.events.BuildManager$1.run(BuildManager.java:316)
        at org.eclipse.core.runtime.SafeRunner.run(SafeRunner.java:45)
        at org.eclipse.core.internal.events.BuildManager.basicBuild(BuildManager.java:319)
        at org.eclipse.core.internal.events.BuildManager.basicBuildLoop(BuildManager.java:371)
        at org.eclipse.core.internal.events.BuildManager.build(BuildManager.java:392)
        at org.eclipse.core.internal.events.AutoBuildJob.doBuild(AutoBuildJob.java:154)
        at org.eclipse.core.internal.events.AutoBuildJob.run(AutoBuildJob.java:244)
        at org.eclipse.core.internal.jobs.Worker.run(Worker.java:63)
    cs
  • pom.xml 파일 안 <dependencies> 태그 안에 다음 의존성 추가

    1
    2
    3
    4
    5
    <dependency>
        <groupId>commons-beanutils</groupId>
        <artifactId>commons-beanutils</artifactId>
        <version>1.8.3</version>
    </dependency>

    cs


View Resolver 등록 (servlet-context.xml)

  • servlet-context.xml에 다음 코드를 추가

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    <beans:bean id="tilesViewResolver" class="org.springframework.web.servlet.view.UrlBasedViewResolver">
        <beans:property name="viewClass" value="org.springframework.web.servlet.view.tiles3.TilesView" />
        <beans:property name="order" value="1" /><!-- 순서를 우선으로 지정 -->
    </beans:bean>
         
    <beans:bean id="tilesConfigurer" class="org.springframework.web.servlet.view.tiles3.TilesConfigurer">
        <beans:property name="definitions">
            <beans:list>
                <beans:value>/WEB-INF/spring/tiles-def.xml</beans:value>
            </beans:list>
        </beans:property>
    </beans:bean>

    cs


타일즈 설정 추가

  • WEB-INF > spring 폴더에 tiles-def.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
    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE tiles-definitions PUBLIC
           "-//Apache Software Foundation//DTD Tiles Configuration 3.0//EN"
           "http://tiles.apache.org/dtds/tiles-config_3_0.dtd">
     
    <tiles-definitions>
        <!-- (1) 레이아웃을 적용하지않는화면-->    
        <definition name=".login" template="/WEB-INF/views/layout/loginLayout.jsp">
            <put-attribute name="title" value="" />
            <put-attribute name="header" value="/WEB-INF/views/common/header.jsp" />
            <put-attribute name="menu" value="" />        
            <put-attribute name="footer" value="" />
        </definition>
     
        <!-- (2) 레이아웃을 적용하는화면-->
        <definition name=".root" template="/WEB-INF/views/layout/baseLayout.jsp">
            <put-attribute name="title" value="" />
            <put-attribute name="header" value="/WEB-INF/views/common/header.jsp" />
            <put-attribute name="menu" value="/WEB-INF/views/common/menu.jsp" />        
            <put-attribute name="footer" value="/WEB-INF/views/common/footer.jsp" />
        </definition>
        
        <!-- (1) -->    
        <definition name="/login/*" extends=".login">
          <put-attribute name="body" value="/WEB-INF/views/login/{1}.jsp" />
        </definition>
     
        <!-- (2) -->
       <definition name="/*/*" extends=".root">      
          <put-attribute name="body" value="/WEB-INF/views/{1}/{2}.jsp" />
        </definition>
    </tiles-definitions>

    cs



기본 레이아웃 설정

  • 위에서 설정한 경로에 jsp 파일 생성

  • baseLayout.jsp

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    <%@ page language="java" contentType="text/html; charset=UTF-8"
        pageEncoding="UTF-8"%>
    <%@ taglib prefix="tiles" uri="http://tiles.apache.org/tags-tiles"%>
    <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
     
    <html>
    <head>
    <title>스프링</title>
    <jsp:include page="/WEB-INF/views/include/head.jsp"></jsp:include>
    </head>
    <body>
        <tiles:insertAttribute name="header"/>
        <div class="container">        
            <tiles:insertAttribute name="body" />
        </div>                                                  
        <tiles:insertAttribute name="footer" />
    </body>
    </html>
    cs
  • 폴더 구조

적용

  • 컨트롤러를 다음과 같이 수정

    1
    2
    3
    4
    5
    6
    @RequestMapping(value= {"/main/home","/home.do"})
    public ModelAndView openTilesView(ModelAndView mv) throws Exception{
        mv.setViewName("/main/home");
        mv.addObject("setHeader""타일즈");
        return mv;
    }

    cs


git 관리

  • GitKraken 실행

  • 커밋 후 푸쉬


자세한 각 jsp 파일 내용 확인




출처: https://epthffh.tistory.com/entry/스프링-타일즈-Spring-Tile-설정해보기 [물고기 개발자의 블로그]

인코딩 설정하기

  • 이 블로그의 글은 JAVA DB 엔지니어링 과정 수업을 위해 작성된 글입니다.

  • 이미지로 인해 글이 길어질 수 있습니다.

  1. web.xml 파일 수정

  2. STS 인코딩 설정

  3. jsp 파일 인코딩 설정

  4. GitHub에 커밋 후 push

web.xml 파일 수정

  • src/main/webapp/WEB-INF/web.xml 파일 클릭 > Source 클릭 후 아래 코드를 추가

<filter>
   <filter-name>encoding</filter-name>
<filter-class>
org.springframework.web.filter.CharacterEncodingFilter
</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>UTF-8</param-value>
   </init-param>
</filter>
   
<filter-mapping>
<filter-name>encoding</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>



STS Workspace 인코딩 설정

  • 메뉴 Window > Preferences 클릭


  • General > Workspace 클릭 >Text file encoding> Other에서 UTF-8 설정 후 Apply



jsp 파일 인코딩 설정

  • src > main > webapp > WEB-INF > views > home.jsp 파일 제일 상단에 아래 코드를 추가 후 서버 실행

  • <%@ page language="java" contentType="text/html; charset=UTF-8"
       pageEncoding="UTF-8"%>


GitHub에 커밋 후 push

  • GitKraken 실행

  • 변경사항 선택 후 Stage all changes 클릭


  • 커밋 내용 입력 후 커밋 클릭


  • push 클릭



스프링 프로젝트 시작하기

  • 이 블로그의 글은 JAVA DB 엔지니어링 과정 수업을 위해 작성된 글입니다.

  • 이미지로 인해 글이 길어질 수 있습니다.

  1. github에 저장소 생성하기

  2. 내 PC에 저장소 클론하기

  3. 스프링 프로젝트 생성하기

  4. 프로젝트 실행하기

github에 저장소 생성하기


  • 저장소 이름 입력

  • 링크 복사



내 PC에 저장소 클론하기

  • GitKraken 실행

  • 메뉴 File > Clone Repo 클릭

  • Clone > GitHub.com > 저장소 선택 후 Browse 클릭


  • PC에 연결한 폴더를 선택 후 폴더선택 클릭


  • Clone the repo! 클릭


  • Open Now 클릭 > Initialize 클릭


  • Push 클릭 > Submit 클릭



스프링 프로젝트 생성하기

  • STS 실행

  • File > New > Spring Legacy Project 클릭


  • Use default location 클릭 해제 후 Browse... 클릭


  • 클론을 통해 생성된 폴더 선택


  • 프로젝트명 기입 후 Spring MVC Project 선택 후 Next 클릭, Yes 클릭(STS 실행 후 처음만 뜸)


  • 프로젝트 패키지명 기입 후 Finish 클릭: kr.green.spring


프로젝트 실행하기

  • 프로젝트 우클릭 > Run As > Run on Server 선택


  • Finish 클릭


  • 액세스 허용 클릭(방화벽 설정에 따라 안 뜰수도 있으며, 한번 설정하면 이후에 뜨지 않음)


  • 실행 결과

GitHub에 Push하기

  • GitKraken 실행

  • .gitignore파일 생성

    • 아무파일이나 우클릭 > ignore > 'ignore 파일명 클릭'


    • ignore 클릭

  • .gitignore파일 클릭 > Edit this file 클릭 후 다음 코드 추가

  • # Created by https://www.gitignore.io/api/java,java-web
    # Edit at https://www.gitignore.io/?templates=java,java-web

    ### Java ###
    # Compiled class file
    *.class

    # Log file
    *.log

    # BlueJ files
    *.ctxt

    # Mobile Tools for Java (J2ME)
    .mtj.tmp/

    # Package Files #
    *.jar
    *.war
    *.nar
    *.ear
    *.zip
    *.tar.gz
    *.rar

    # virtual machine crash logs, see http://www.java.com/en/download/help/error_hotspot.xml
    hs_err_pid*

    ### Java-Web ###
    ## ignoring target file
    target/

    # End of https://www.gitignore.io/api/java,java-web
  • Stage File 클릭 > Save and stage 클릭


  • 커밋 내용 작성 후 커밋 클릭


  • Stage all changes 클릭하여 커밋내용 작성 후 커밋


  • Push클릭하여 온라인 저장소에 저장



수고하셨습니다.!!!


+ Recent posts