1. κ°μ
μ΄λ² νλͺ©μμλ μ€νλ§ λΆνΈ κ²μνμ κΈ μμΈλ³΄κΈ° νμ΄μ§λ₯Ό λ§λλ λ°©λ²μ λν΄ μ€λͺ νκ² μ΅λλ€. κΈ μμΈλ³΄κΈ° νμ΄μ§λ μ¬μ©μκ° κ²μνμμ ν΄λ¦ν κΈμ λ΄μ©κ³Ό κ΄λ ¨λ μ 보λ₯Ό μμΈν 보μ¬μ£Όλ μν μ ν©λλ€. μ΄ νμ΄μ§λ μ¬μ©μμκ² μ’ λ νλΆν κ²½νμ μ 곡νκ³ , λ λ§μ μ 보λ₯Ό μ 곡νμ¬ μ¬μ©μκ° κΈμ λ μ μ΄ν΄νκ³ μνΈμμ©ν μ μλλ‘ λμμ€λλ€.
λ€μ νλͺ©μμλ νλ©΄ κ΅¬μ± μμ, κΈ μμΈ μ 보 νμ, λκΈ λͺ©λ‘ νμ, λκΈ μμ± κΈ°λ₯μ λν΄ μμΈν μμλ³΄κ² μ΅λλ€. μ΄ κ³Όμ μ ν΅ν΄ μ€νλ§ λΆνΈλ₯Ό μ¬μ©νμ¬ κ°λ¨νκ³ μ€μ©μ μΈ κ²μνμ λ§λ€ μ μλ λ°©λ²μ μ΅ν μ μμ΅λλ€.
2. νλ©΄ κ΅¬μ± μμ
κΈ μμΈλ³΄κΈ° νμ΄μ§λ κΈ°λ³Έμ μΌλ‘ λ€μκ³Ό κ°μ κ΅¬μ± μμλ‘ μ΄λ£¨μ΄μ§λλ€:
- μ λͺ©: κΈμ μ λͺ©μ λνλ λλ€. μ£Όλ‘ h1 νκ·Έλ₯Ό μ¬μ©νμ¬ ν° κΈμ¨λ‘ νμν©λλ€.
- μμ±μ: κΈμ μμ±ν μ¬μ©μμ μ 보λ₯Ό νμν©λλ€. μμ±μμ λλ€μμ΄λ μμ΄λλ₯Ό 보μ¬μ€ μ μμ΅λλ€.
- μμ±μΌ: κΈμ΄ μμ±λ λ μ§μ μκ°μ νμν©λλ€.
- λ΄μ©: κΈμ λ΄μ©μ μμΈν 보μ¬μ€λλ€. κΈ΄ λ΄μ©μΌ κ²½μ° μ€ν¬λ‘€μ ν΅ν΄ λ΄μ©μ λ³Ό μ μλλ‘ κ΅¬νν μ μμ΅λλ€.
- μ΄λ―Έμ§: κΈμ 첨λΆλ μ΄λ―Έμ§λ₯Ό νμν μ μμ΅λλ€. μΌλ°μ μΌλ‘ μ΄λ―Έμ§ νμμΈ jpg, png λ±μ μ§μν©λλ€.
- λκΈ λͺ©λ‘: ν΄λΉ κΈμ μμ±λ λκΈλ€μ 보μ¬μ€λλ€. λκΈμ μμ±μ, μμ±μΌ, λ΄μ© λ±μ μ 보λ₯Ό ν¬ν¨νμ¬ νμν μ μμ΅λλ€.
- λκΈ μμ± νΌ: μ¬μ©μκ° λκΈμ μμ±ν μ μλ νΌμ μ 곡ν©λλ€. μμ±μ μ΄λ¦, λ΄μ© μ λ ₯λ, μμ± λ²νΌ λ±μ μμλ‘ κ΅¬μ±λ μ μμ΅λλ€.
μ΄λ¬ν νλ©΄ κ΅¬μ± μμλ€μ μ‘°ν©νμ¬ κΈ μμΈλ³΄κΈ° νμ΄μ§λ₯Ό μμ±ν μ μμ΅λλ€. μ΄μ΄μ§λ νλͺ©λ€μμλ κ°κ°μ κ΅¬μ± μμμ λν΄ μμΈν μ€λͺ νκ³ , μ€νλ§ λΆνΈλ₯Ό μ¬μ©νμ¬ μ΄λ»κ² ꡬνν μ μλμ§ μμλ³΄κ² μ΅λλ€.
3. κΈ μμΈ μ 보 νμ
κΈ μμΈλ³΄κΈ° νμ΄μ§μμλ κΈμ μ λͺ©, μμ±μ, μμ±μΌ, λ΄μ© λ±μ μ 보λ₯Ό νμν΄μΌ ν©λλ€. μ΄λ¬ν μ 보λ€μ λ°μ΄ν°λ² μ΄μ€λ‘λΆν° κ°μ ΈμμΌ νλ©°, μ€νλ§ λΆνΈλ₯Ό μ¬μ©νμ¬ κ°λ¨νκ² κ΅¬νν μ μμ΅λλ€.
λ¨Όμ , κΈμ μ λͺ©μ h1 νκ·Έλ₯Ό μ¬μ©νμ¬ ν° κΈμ¨λ‘ νμν μ μμ΅λλ€. μ€νλ§ λΆνΈλ Thymeleaf ν νλ¦Ώ μμ§μ κΈ°λ³ΈμΌλ‘ μ 곡νλ―λ‘, ν νλ¦Ώ νμΌμμ λ€μκ³Ό κ°μ΄ μ λͺ©μ νμν μ μμ΅λλ€:
<h1 th:text="${post.title}"></h1>
μ μ½λμμ post.title
μ 컨νΈλ‘€λ¬μμ μ λ¬λ κΈμ μ λͺ©μ λνλ
λλ€. μ΄λ κ² νλ©΄ μ λͺ©μ΄ λμ μΌλ‘ νμλλ©°, μ¬μ©μκ° ν΄λ¦ν κΈμ μ λͺ©μ΄ h1 νκ·Έ λ΄μ νμλ©λλ€.
λ€μμΌλ‘, μμ±μμ μμ±μΌμ κΈμ μ 보λ₯Ό κ°μ Έμμ νμν΄μΌ ν©λλ€. λ§μ°¬κ°μ§λ‘ Thymeleafλ₯Ό μ΄μ©νμ¬ μ 보λ₯Ό νμν μ μμ΅λλ€. μλ₯Ό λ€μ΄, μμ±μμ μμ΄λλ₯Ό νμνλ €λ©΄ λ€μκ³Ό κ°μ΄ μ½λλ₯Ό μμ±ν μ μμ΅λλ€:
<p>μμ±μ: <span th:text="${post.author}"></span></p>
μ μ½λμμ post.author
λ 컨νΈλ‘€λ¬μμ μ λ¬λ κΈμ μμ±μλ₯Ό λνλ
λλ€. μ΄λ κ² νλ©΄ μμ±μ μ λ³΄κ° λμ μΌλ‘ νμλλ©°, μ¬μ©μκ° ν΄λ¦ν κΈμ μμ±μκ° span
νκ·Έ λ΄μ νμλ©λλ€. μμ±μΌ μμ λμΌν λ°©μμΌλ‘ νμν μ μμ΅λλ€.
λ§μ§λ§μΌλ‘, κΈμ λ΄μ©μ νμνκΈ° μν΄μλ div
νκ·Έλ p
νκ·Έ λ±μ μ¬μ©νμ¬ λ΄μ©μ λ¬Άμ΄μ€ μ μμ΅λλ€. μ€ν¬λ‘€μ ν΅ν΄ κΈ΄ λ΄μ©μ λ³Ό μ μλλ‘ μ€νμΌμ μ μ©ν μλ μμ΅λλ€.
<div th:text="${post.content}"></div>
μ μ½λμμ post.content
λ 컨νΈλ‘€λ¬μμ μ λ¬λ κΈμ λ΄μ©μ λνλ
λλ€. μ΄λ κ² νλ©΄ κΈμ λ΄μ©μ΄ λμ μΌλ‘ νμλλ©°, μ¬μ©μκ° ν΄λ¦ν κΈμ λ΄μ©μ΄ div
νκ·Έ λ΄μ νμλ©λλ€.
μμ κ°μ λ°©λ²μΌλ‘ κΈμ μ λͺ©, μμ±μ, μμ±μΌ, λ΄μ© λ±μ μ 보λ₯Ό λμ μΌλ‘ νμν μ μμ΅λλ€. μ΄λ¬ν μ 보λ€μ λ°μ΄ν°λ² μ΄μ€μμ κ°μ Έμμ μ¬μ©μμκ² μ 곡ν΄μΌ νλ―λ‘, μ€νλ§ λΆνΈμμλ 컨νΈλ‘€λ¬λ₯Ό ν΅ν΄ λ°μ΄ν°λ₯Ό μ λ¬νλ λ°©μμΌλ‘ ꡬνν μ μμ΅λλ€.
4. λκΈ λͺ©λ‘ νμ
κΈ μμΈλ³΄κΈ° νμ΄μ§μμλ ν΄λΉ κΈμ μμ±λ λκΈ λͺ©λ‘μ νμν΄μΌ ν©λλ€. μ΄λ₯Ό μν΄μλ λ°μ΄ν°λ² μ΄μ€λ‘λΆν° λκΈ λ°μ΄ν°λ₯Ό κ°μ ΈμμΌ νλ©°, μ€νλ§ λΆνΈλ₯Ό μ¬μ©νμ¬ κ΅¬νν μ μμ΅λλ€.
λκΈ λͺ©λ‘μ νμνκΈ° μν΄μλ 리μ€νΈ ννλ‘ κ°κ°μ λκΈμ νμν΄μΌ ν©λλ€. μ€νλ§ λΆνΈμ Thymeleaf ν νλ¦Ώ μμ§μ μ¬μ©νμ¬ λ€μκ³Ό κ°μ ννλ‘ λκΈ λͺ©λ‘μ νμν μ μμ΅λλ€:
<h2>λκΈ λͺ©λ‘</h2>
<div th:each="comment : ${comments}">
<p>μμ±μ: <span th:text="${comment.author}"></span></p>
<p>μμ±μΌ: <span th:text="${comment.date}"></span></p>
<p><span th:text="${comment.content}"></span></p>
</div>
μ μ½λμμ comments
λ 컨νΈλ‘€λ¬μμ μ λ¬λ λκΈ λͺ©λ‘ λ°μ΄ν°λ₯Ό λνλ
λλ€. th:each
λλ ν°λΈλ₯Ό μ¬μ©νμ¬ comments
리μ€νΈ λ΄μ κ°κ°μ λκΈμ λν΄ λ°λ³΅μ μΌλ‘ νμν μ μμ΅λλ€. κ°κ°μ λκΈμ μμ±μ, μμ±μΌ, λ΄μ© λ±μ μ 보λ₯Ό ν¬ν¨νλ©°, Thymeleafλ₯Ό μ¬μ©νμ¬ λμ μΌλ‘ νμλ©λλ€.
μ μ½λλ₯Ό μ€ννλ©΄, ν΄λΉ κΈμ μμ±λ λκΈλ€μ΄ μμλλ‘ λμ΄λμ΄ νλ©΄μ 보μ¬μ§κ² λ©λλ€. μ¬μ©μλ λκΈ μμ±μ, μμ±μΌ, λ΄μ© λ±μ μ 보λ₯Ό νμΈν μ μμΌλ©°, νμν κ²½μ° μ€ν¬λ‘€μ ν΅ν΄ λ λ§μ λκΈμ λ³Ό μ μλλ‘ κ΅¬νν μ μμ΅λλ€.
λ€μμΌλ‘, μ¬μ©μκ° λκΈμ μμ±ν μ μλ νΌμ νμν΄μΌ ν©λλ€. νΌμ λ€μκ³Ό κ°μ ννλ‘ λ§λ€ μ μμ΅λλ€:
<h3>λκΈ μμ±</h3>
<form action="/comment" method="POST">
<input type="text" name="author" placeholder="μμ±μ" required>
<textarea name="content" placeholder="λκΈ λ΄μ©" required></textarea>
<button type="submit">μμ±νκΈ°</button>
</form>
μ μ½λμμ /comment
κ²½λ‘λ‘ POST
μμ²μ 보λ΄λ©΄μ λκΈμ μμ±νλ νΌμ΄ ꡬνλ©λλ€. μμ±μμ λ΄μ©μ μ
λ ₯ν μ μλ μ
λ ₯λμ΄ μ 곡λλ©°, μμ±νκΈ° λ²νΌμ ν΄λ¦νλ©΄ νΌ λ°μ΄ν°κ° μλ²λ‘ μ μ‘λ©λλ€.
μμ κ°μ λ°©μμΌλ‘ λκΈ λͺ©λ‘μ νμνκ³ , λκΈ μμ± νΌμ μ 곡ν μ μμ΅λλ€. μ΄λ κ² κ΅¬νλ λκΈ λͺ©λ‘ νμ΄μ§λ μ¬μ©μκ° κΈμ λκΈμ νμΈνκ³ μμ±ν μ μλλ‘ λμμ€λλ€.
5. λκΈ μμ± κΈ°λ₯
κΈ μμΈλ³΄κΈ° νμ΄μ§μμλ μ¬μ©μκ° λκΈμ μμ±ν μ μλ κΈ°λ₯μ μ 곡ν΄μΌ ν©λλ€. μ΄λ₯Ό μν΄ μ€νλ§ λΆνΈλ₯Ό μ¬μ©νμ¬ λκΈ μμ± κΈ°λ₯μ ꡬνν μ μμ΅λλ€.
λκΈμ μμ±νκΈ° μν΄ μ¬μ©μλ μμ±μ μ΄λ¦κ³Ό λκΈ λ΄μ©μ μ λ ₯ν΄μΌ ν©λλ€. μ΄λ₯Ό μν΄ νΌμ μ 곡νμ¬ μ¬μ©μκ° μ λ ₯λμ μνλ μ 보λ₯Ό μμ±ν μ μλλ‘ ν΄μΌ ν©λλ€. μ€νλ§ λΆνΈμμλ λ€μκ³Ό κ°μ ννλ‘ λκΈ μμ± νΌμ ꡬνν μ μμ΅λλ€:
<h3>λκΈ μμ±</h3>
<form action="/post/{{postId}}/comments" method="POST">
<input type="text" name="author" placeholder="μμ±μ" required>
<textarea name="content" placeholder="λκΈ λ΄μ©" required></textarea>
<button type="submit">μμ±νκΈ°</button>
</form>
μ μ½λμμ /post/{{postId}}/comments
κ²½λ‘λ‘ POST
μμ²μ 보λ΄λ©΄μ λκΈμ μμ±νλ νΌμ΄ ꡬνλ©λλ€. {{postId}}
λ μ€μ κΈμ ID κ°μΌλ‘ λ체λμ΄μΌ ν©λλ€.
μ νΌμμ μμ±μμ λκΈ λ΄μ©μ μ λ ₯ν μ μλ μ λ ₯λμ΄ μ 곡λ©λλ€. μ¬μ©μλ μ΄λ¦κ³Ό λ΄μ©μ μ λ ₯ν ν μμ±νκΈ° λ²νΌμ ν΄λ¦νμ¬ λκΈμ μμ±ν μ μμ΅λλ€. μμ±νκΈ° λ²νΌμ ν΄λ¦νλ©΄ νΌ λ°μ΄ν°κ° μλ²λ‘ μ μ‘λ©λλ€.
λκΈ μμ± κΈ°λ₯μ ꡬννκΈ° μν΄μλ 컨νΈλ‘€λ¬μμ ν΄λΉ κ²½λ‘μ λν POST μμ²μ μ²λ¦¬νλ νΈλ€λ¬ λ©μλλ₯Ό μμ±ν΄μΌ ν©λλ€. μλ₯Ό λ€μ΄, λ€μκ³Ό κ°μ ννλ‘ νΈλ€λ¬ λ©μλλ₯Ό μμ±ν μ μμ΅λλ€:
@PostMapping("/post/{postId}/comments")
public String addComment(@PathVariable Long postId, Comment comment) {
// λκΈ λ°μ΄ν° μ²λ¦¬ λ‘μ§
// ...
return "redirect:/post/" + postId; // μμ±ν κΈλ‘ 리λ€μ΄λ νΈ
}
μ μ½λμμ @PostMapping("/post/{postId}/comments")
μ΄λ
Έν
μ΄μ
μ ν΄λΉ κ²½λ‘λ‘ λ€μ΄μ€λ POST μμ²μ μ²λ¦¬νλ νΈλ€λ¬ λ©μλμμ λνλ
λλ€. @PathVariable
μ΄λ
Έν
μ΄μ
μ μ¬μ©νμ¬ postId
κ°μ κ°μ Έμμ μ¬μ©ν μ μμΌλ©°, Comment
κ°μ²΄λ μ¬μ©μκ° μμ±ν λκΈ λ°μ΄ν°λ₯Ό λνλ
λλ€.
νΈλ€λ¬ λ©μλμμλ λκΈ λ°μ΄ν°λ₯Ό μ²λ¦¬ν μ μλ λ‘μ§μ ꡬνν΄μΌ ν©λλ€. μλ₯Ό λ€μ΄, λ°μ΄ν°λ² μ΄μ€μ λκΈμ μ μ₯νκ±°λ, κΈ μμΈλ³΄κΈ° νμ΄μ§λ‘ 리λ€μ΄λ νΈνλ λ±μ μμ μ μνν μ μμ΅λλ€. μ΄λ₯Ό μν΄μλ λ°μ΄ν°λ² μ΄μ€ μ²λ¦¬λ νμν μλΉμ€ ν΄λμ€λ₯Ό μ£Όμ νμ¬ μ¬μ©ν μ μμ΅λλ€.
μμ κ°μ λ°©μμΌλ‘ λκΈ μμ± κΈ°λ₯μ ꡬνν μ μμ΅λλ€. μ¬μ©μλ λκΈ μμ± νΌμ ν΅ν΄ μνλ μ 보λ₯Ό μ λ ₯ν ν μμ±νκΈ° λ²νΌμ ν΄λ¦νμ¬ λκΈμ μμ±ν μ μμ΅λλ€. μμ±ν λκΈμ μλ²μμ μ²λ¦¬λλ©°, μ¬μ©μλ μμ±λ λκΈμ νμΈν μ μμ΅λλ€.
λκΈ