9. React 구성하기

이번에는 SpringBoot와 React를 이용해 볼 예정이다.

환경 = OSX , JAVA8, Visual Studio code

VScode에 대해 환경을 설치하는 방법은 gradle_error_solution 하단에 Visual Studio Code 설치법에 대해 언급했다.(Maven도 가능하니 따라서 하면 됨)

스프링 부트를 통해 서버 API 구축, UI를 REACT에서 담당

Front-end : React
Back-end : SpringBoot

이제 SpringBoot 웹 프로젝트 생성해보자!

1. code 에서 ++p 누른다.

  • spring initializr: Generate Maven 생성

  • Java 선택

  • Package , Artifact id 설정

  • SpringBoot Version 선택

  • Dependency : DevTools, Spring Web Starter Web 선택

    • DevTools : 코드가 변경되면 자동으로 Rebuild를 지원해준다.

  • 생성

2. Project를 한번 실행해 본다.

JSP 와 JSTL을 사용하기 위해 라이브러리를 추가

pom.xml > dependencies 내부에

SpringBoot를 실행해 본다. 방법: vscode terminal에서 'mvn spring-boot:run' 입력하면 서버가 실행됨

3. React 환경 추가

  1. 터미널에서 'npm init' >> package.json 생성 (질문들이 나오는데 전부 enter)

  2. react 의존 라이브러리 설치

4. webpack 설정

webpack을 통해 react 개발 할 때, 자바스크립트 기능과 jsp에 포함할 .js파일 생성가능 프로젝트의 루트경로에 webpack.config.js 파일을 만든다.

  • 코드 내용

    • React 소스 경로를 src/main/jsx로 설정

    • MainPage와 Page1Page.jsx 빌드

    • 빌드 결과 js 파일들을 src/main/webapp/js/react아래 [페이지 이름].bundle.js 로 설정

5. 서버 코드 개발

  1. MainController.java 파일을 생성한다.

    ~~~

    package com.example.demo.Controller;

import org.springframework.stereotype.Controller; import org.springframework.ui.Model; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.PathVariable;

@Controller public class MainController{

}

src main webapp jsp css

<%@ page language="java" contentType="text/html; charset=utf-8"%> <!doctype html>

${pageName}

</html>

.main { font-size: 1.5em; border-bottom:solid 1px black; } .page1 { font-size:0.8em; background-color:orange; }

// custom.css 파일 import import '../webapp/css/custom.css';

import React from 'react'; import ReactDom from 'react-dom';

class MainPage extends React.Component { render(){ return demo 메인페이지; } } ReactDom.render(,document.getElementById('root'));

// custom.css 파일 import import '../webapp/css/custom.css';

import React from 'react'; import ReactDom from 'react-dom';

class Page1Page extends React.Component { render(){ return demo page1페이지; } } ReactDom.render(,document.getElementById('root'));

node_modules/.bin/webpack --watch -d -d : 개발 시 -p : 운영 시

"script": { "test": "echo \"Error: no test specified\" && exit1", "start": "mvn spring-boot:run", "watch": "node_modules/.bin/webpack --watch -d" }

~~~ 이제 빌드를 할 때, 'npm run watch'로 하면 되고, 'npm run start'로 서버를 실행 할 수 있다.

  • 해당버전은 OSX 대상이므로 윈도우는 위 부분을 수정해주어야 됨!!

빌드가 이루어 졌기 때문에 이지 우리가 만든 페이지를 확인할 수 있다.

해당 경로로 들어가면 작성한 jsx파일로 작성한 모습이 보인다.

PS

Template에 조언사항을 적어놓았습니다. 확인하시면 좀 더 쉽게 이해하실 수 있습니다.

Gyoogle 님의 글에서 OSX에서 사용할 때로 변경해 놓았습니다.

Window를 사용하시는 분은 Gyoogle에서 참고해주세요 :)

Last updated

Was this helpful?