data:image/s3,"s3://crabby-images/97251/9725198539d3b86b3cbdcd8d6f46a20cd9fad41e" alt="사진 업로드 샘플링 1"
data:image/s3,"s3://crabby-images/10412/104121e62fda68e1f60d45c9627bdb3a3ae506e6" alt="notion image"
https://github.com/kdit-2024/spring-fileupload
머스태치 쓰려면 (머스태치 라이브러리)
implementation 'org.springframework.boot:spring-boot-starter-mustache'
기초 세팅
data:image/s3,"s3://crabby-images/613fb/613fbe5af208d49ce3ace763f6f974fe84c496d3" alt="notion image"
data:image/s3,"s3://crabby-images/563ab/563ab0f21aa032aa3a9135d6a2b14f026c9a0e9f" alt="notion image"
yml
data:image/s3,"s3://crabby-images/66c38/66c3861e8a2a036fb013d9c38ec265ca03d80295" alt="notion image"
server: servlet: encoding: charset: utf-8 force: true spring: mustache: servlet: expose-session-attributes: true expose-request-attributes: true datasource: driver-class-name: org.h2.Driver url: jdbc:h2:mem:test;MODE=MySQL username: sa password: h2: console: enabled: true jpa: hibernate: ddl-auto: create show-sql: true properties: hibernate: format_sql: true
그림 그리기 - 아주 간단하게 디자인
data:image/s3,"s3://crabby-images/d9785/d9785c35f03c62a727127d77c3283d976b4c9ba8" alt="notion image"
[ index.mustache ] - 사진 업로드가 되면 이 페이지로 리다이렉션 할 것
<!doctype html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Document</title> </head> <body> <h1>메인페이지</h1> <hr> <ul> <li> <a href="/">메인페이지</a> </li> <li> <a href="/uploadForm">사진 등록 페이지</a> </li> <li> <a href="/uploadCheck">사진 확인 페이지</a> </li> </ul> </body> </html>
ul 링크.. 네이게이션이 있어야 한다!
[ uploadForm 사진 등록 페이지 ]
<!doctype html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Document</title> </head> <body> <h1>사진등록페이지</h1> <hr> <ul> <li> <a href="/">메인페이지</a> </li> <li> <a href="/uploadForm">사진 등록 페이지</a> </li> <li> <a href="/uploadCheck">사진 확인 페이지</a> </li> </ul> <form action="/upload" method="post" enctype="multipart/form-data"> <input type="text" name="title" placeholder="사진제목..."> <input type="file" name="imgFile"> <button>사진업로드</button> </form> </body> </html>
[ uploadCheck 사진 확인 페이지 ]
<!doctype html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Document</title> </head> <body> <h1>사진확인페이지</h1> <hr> <ul> <li> <a href="/">메인페이지</a> </li> <li> <a href="/uploadForm">사진 등록 페이지</a> </li> <li> <a href="/uploadCheck">사진 확인 페이지</a> </li> </ul> <img src="#" width="500" height="500" alt="사진없음"> </body> </html>
[ 화면 확인 ]
data:image/s3,"s3://crabby-images/283d9/283d99cec3cf5df3372992b417f9d79ece8ee9b6" alt="notion image"
data:image/s3,"s3://crabby-images/f4b7f/f4b7f45472dd586f4903e9660fc753f0cfa93906" alt="notion image"
data:image/s3,"s3://crabby-images/fb1fd/fb1fde89b6be2fec0bf4bfe7a828ef2bd521d8be" alt="notion image"
사진 업로드하기
[ pic 패키지 생성 ]
data:image/s3,"s3://crabby-images/8e0d4/8e0d42f1b427cd493acc8ae61ac00ecfe0421108" alt="notion image"
[ PicController ]
package com.mtcoding.fileapp.pic; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.GetMapping; @Controller public class PicController { @GetMapping("/") public String index() { return "index"; } @GetMapping("/uploadForm") public String uploadForm() { return "uploadForm"; } @GetMapping("/uploadCheck") public String uploadCheck() { return "uploadCheck"; } }
Share article