Banner

My Tech Blog (๋งŒ๋“ค๊ธฐ)

๋ถ์Šคํƒ(BookStack API) ์„ค์น˜ํ•˜๊ธฐ 1ํŽธhttps://awesomepossum.tistory.com/480 https://www.bookstackapp.com/ BookStackMulti-Lingual BookStack users can set their preferred language. Thanks to great community contributors, current languages built into BookStack include EN, FR, DE, ES, " data-og-host="awesomepossum.tistory.com" data-og-source-url="https://awesomepossum.tistory.com/480" data-og-url="https://aweso..
๊พธ๋ฏธ๊ธฐ ๋ผ๊ณ  ํ•˜๊ธฐ์—๋Š” ์†Œ์†Œํ•˜์ง€๋งŒ๋ถ€ํŠธ์ŠคํŠธ๋žฉ ์†์„ฑ ๊ณต๋ถ€ํ•˜๋Š” ์‹œ๊ฐ„ ๋„ค๋น„๊ฒŒ์ด์…˜๋ฐ” ์•„๋ž˜ ๋ฉ”์ธ ์˜์—ญ์— ๋ถ€ํŠธ์ŠคํŠธ๋žฉ์œผ๋กœ ์†Œ๊ฐœ๊ธ€ ์ถ”๊ฐ€main์˜์—ญ์ด๋ผ๊ณ  ํ•ด์•ผ ํ• ์ง€ content ์˜์—ญ์ด๋ผ๊ณ  ํ•ด์•ผ ํ• ์ง€ 1. ์†Œ๊ฐœ๊ธ€ ์ถ”๊ฐ€ `jumbotron`ํŽ˜์ด์ง€ ๋‚ด์—์„œ ๊ฐ•์กฐํ•˜๋Š” ํžˆ์–ด๋กœ ์„น์…˜์ด๊ณ  ํฐ ํ…์ŠคํŠธ์™€ ์—ฌ๋ฐฑ์„ ๊ธฐ๋ณธ์œผ๋กœ ํฌํ•จํ•จ๋ถ€ํŠธ์ŠคํŠธ๋žฉ 5์—์„œ๋Š” Jumbotron ํด๋ž˜์Šค๊ฐ€ ์ œ๊ฑฐ๋˜์—ˆ๊ธฐ ๋•Œ๋ฌธ์— ์•„๋ž˜์™€ ๊ฐ™์€ ํด๋ž˜์Šค๋ฅผ ์กฐํ•ฉํ•ด์„œ ๋น„์Šทํ•œ ํšจ๊ณผ๋ฅผ ์ˆ˜๋™์œผ๋กœ ๋‚ด์•ผ ํ•œ๋‹ค. `rounded`์š”์†Œ์˜ ๋ชจ์„œ๋ฆฌ๋ฅผ ๋‘ฅ๊ธ€๊ฒŒ ๋งŒ๋“ฌ  border-radius: 0.375rem (์•ฝ 6px)์—ฌ๊ธฐ์„œ rounded-circle, rounded-pill ์“ฐ๋ฉด ๋” ๊ทน๋‹จ์ ์œผ๋กœ(?) ๋‘ฅ๊ทผ ์Šคํƒ€์ผ ๊ฐ€๋Šฅ`display-4`ํ…์ŠคํŠธ๋ฅผ ํฌ๊ฒŒ ํ‘œ์‹œํ•˜๋Š” ํ—ค๋”ฉ ์Šคํƒ€์ผ๋ถ€ํŠธ์ŠคํŠธ๋žฉ์˜ ๋””์Šคํ”Œ๋ ˆ์ด ํด๋ž˜์Šค์ธ๋ฐ ..
1. BbsDAO ํด๋ž˜์Šค์— getBbs() ๋ฉ”์„œ๋“œ ๋งŒ๋“ค๊ธฐ `getBbs(int bbsID)` ๋ฉ”์„œ๋“œ๋Š” ํŠน์ • bbsID๋ฅผ ๊ธฐ๋ฐ˜์œผ๋กœ ๊ฒŒ์‹œ๊ธ€ ๋ฐ์ดํ„ฐ๋ฅผ ๋ฐ์ดํ„ฐ๋ฒ ์ด์Šค์—์„œ ์กฐํšŒํ•˜์—ฌ ๋ฐ˜ํ™˜ํ•œ๋‹ค.์ฆ‰ ํ•˜๋‚˜์˜ ๊ธ€ ๋‚ด์šฉ์„ ๋ถˆ๋Ÿฌ์˜ค๋Š” ๋ฉ”์„œ๋“œ์ด๋‹ค. ์ฒ˜์Œ์— ์ ์€ ์ฝ”๋“œ(ํ‹€๋ฆผ) public Bbs getBbs(int bbsID) { String SQL = "SELECT * FROM BBS WHERE bbsID = ?"; try (PreparedStatement psmt = conn.prepareStatement(SQL); ResultSet rs = psmt.executeQuery()) { psmt.setInt(1, bbsID); if (rs.next()) { ..
1. write.jsp ๊ธ€์“ฐ๊ธฐ ํŽ˜์ด์ง€ ๋งŒ๋“ค๊ธฐ ๋จผ์ € ๊ฒŒ์‹œ๊ธ€ ์ž‘์„ฑ ํŽ˜์ด์ง€ `write.jsp`๋ฅผ ๋งŒ๋“ค์–ด ์ฃผ๋ ค๊ณ  ํ•œ๋‹ค.`bbs.jsp`๋ฅผ ๋ณต์‚ฌํ•ด์„œ ๋ถ™์—ฌ ๋„ฃ๊ณ  ์ค‘๊ฐ„ ๋ถ€๋ถ„๋งŒ ์ˆ˜์ • ํ•ด ์ค„ ๊ฒƒ์ด๋‹ค. nav๋ฐ” ์•„๋ž˜ ๋ถ€๋ถ„์— ์ด๋ ‡๊ฒŒ ์ฝ”๋“œ๋ฅผ ์ž‘์„ฑBootstrap5 ์ด์šฉํ–ˆ๋‹ค. โšก `mt-5` margin-top: 5rem;  โšก ``ํƒœ๊ทธ์— `required` ์†์„ฑ ๋„ฃ์œผ๋ฉด ๋ธŒ๋ผ์šฐ์ €์—์„œ ์œ ํšจ์„ฑ ๊ฒ€์‚ฌ๋ฅผ ํ•จ. ํ…์ŠคํŠธ๋ฅผ ์ž…๋ ฅ ์•ˆ ํ•œ ์ฑ„๋กœ submit ํ•˜๋ฉด `์ด ์ž…๋ ฅ๋ž€์„ ์ž‘์„ฑํ•˜์„ธ์š”.` ๋ผ๋Š” ๊ฒฝ๊ณ  ๋ฉ”์„ธ์ง€๋ฅผ ๋„์šด๋‹ค.  โšก `form-control` ํด๋ž˜์Šค Bootstrap์—์„œ ์ œ๊ณตํ•˜๋Š” ํด๋ž˜์Šค ์ค‘ ํ•˜๋‚˜๋กœ, ์ž…๋ ฅ ํ•„๋“œ์˜ ์Šคํƒ€์ผ์„ ์‰ฝ๊ฒŒ ์ผ๊ด€์„ฑ ์žˆ๊ฒŒ ์ ์šฉํ•˜๊ธฐ ์œ„ํ•ด ์‚ฌ์šฉ๋จ.์ด๊ฑฐ ์“ฐ๋ฉด ์ž…๋ ฅ ํ•„๋“œ(input, textarea, select ๋“ฑ)๊ฐ€ ๊ธฐ๋ณธ..
[์—‘์…€] To Do List ๋Œ€์‹œ๋ณด๋“œ ๋งŒ๋“ค๊ธฐ 1๋จผ์ €  `์—ฐ๋„/์›”` ์„ ํƒ๋ชฉ๋ก,`์ฃผ๋ฒˆํ˜ธ`, `์ผ๋ฒˆํ˜ธ`, `์š”์ผ`, `ํ•ด์•ผํ• ์ผ(๋‚ ์งœ)` ๋ž€์„ ๋งŒ๋“ค์–ด์„œ ํ•ด๋‹น ์นธ์„ ์ฑ„์›Œ์ค€๋‹ค. ์œ„์˜ ํ‘œ๋ฅผ ๋งŒ๋“œ๋Š” ๋ฒ•์€ ์•„๋ž˜ ํฌ์ŠคํŒ… ์ฐธ์กฐ [์—‘์…€] ์ฑ„์šฐ๊ธฐ ํ•ธ๋“ค๊ณผ date, text ํ•จ์ˆ˜๋กœ ๋‚ ์งœawesomepossum.tistory.com 4. ์›”๋ณ„ ์ง„ํ–‰๋ฅ ์„ ๋ณด์—ฌ์ฃผ๋Š” ๋ฐ์ดํ„ฐ ๋ง‰๋Œ€๋งŒ๋“ค๊ธฐ์›”๋ณ„ ์ง„ํ–‰๋ฅ ์„ ๋ง‰๋Œ€ ๋ฐ” ํ˜•ํƒœ๋กœ ๋งŒ๋“ค๋ ค๋ฉด ๊ฐ `(ํ•ญ๋ชฉ์˜ ์ง„ํ–‰ ๊ฐœ์ˆ˜ / ๊ฐ ์›” ์ „์ฒด ์ผ์ˆ˜)` ๋ฅผ ๋จผ์ € ๊ณ„์‚ฐํ•ด์•ผ ํ•œ๋‹ค.  `2025๋…„ 1์›” ์ „์ฒด์˜ ์ผ ์ˆ˜`= 2025/02/01 - 2025/01/01=`๋‹ค์Œ๋‹ฌ 1์ผ - ์ด๋ฒˆ๋‹ฌ 1์ผ`  ์›”๋ณ„ ์ „์ฒด ์ผ์ˆ˜ = WEEKNUM(N14,2)-WEEKNUM(EOMONTH(N14,-1)+1,2)+1    ์ง„ํ–‰๋ฅ  ๋ฐ”๋ฅผ ๋„ฃ์„ ์…€์„์„ ..
์™„์„ฑ๋ณธ์˜ ๋ชจ์Šต์ œ๊ฐ€ ๋งŒ๋“ค To Do List ๋Œ€์‹œ๋ณด๋“œ์ž…๋‹ˆ๋‹ค. ์—ฌ๊ธฐ์„œ๋ถ€ํ„ฐ ์‹œ์ž‘ํ•ด๋ณผ๊ฒŒ์š” ์•„๋ž˜ ๋นˆ ์˜์—ญ์— ์ฒดํฌ๋ฐ•์Šค ๋งŒ๋“œ๋Š” ๊ฑฐ๋ถ€ํ„ฐ  ํ• ๊ฑฐ์˜ˆ์š” ๊ทธ ์ „๊นŒ์ง€ `์—ฐ๋„/์›”` ์„ ํƒ๋ชฉ๋ก,`์ฃผ๋ฒˆํ˜ธ`, `์ผ๋ฒˆํ˜ธ`, `์š”์ผ`, `ํ•ด์•ผํ• ์ผ(๋‚ ์งœ)` ๋ž€์„ ๋งŒ๋“œ๋Š” ์ž‘์—…์€ ์•„๋ž˜ ํฌ์ŠคํŒ… ์ฐธ์กฐ ํ•ด ์ฃผ์„ธ์š” [์—‘์…€] ์ฑ„์šฐ๊ธฐ ํ•ธ๋“ค๊ณผ date, text ํ•จ์ˆ˜๋กœ ๋‚ ์งœ์™€ ์š”์ผ ์ž๋™ ์ฑ„์šฐ๊ธฐ ํ•˜๋Š” ๋ฐฉ๋ฒ•์—‘์…€์— ๋‚ ์งœ ๋„ฃ์„๋•Œ 1๋ถ€ํ„ฐ 31์ผ๊นŒ์ง€ ํ•˜๋‚˜์”ฉ ์ž…๋ ฅํ•˜์ง€ ์•Š๊ณ  ์ž๋™์œผ๋กœ ์—ฐ์†๋œ ์ˆซ์ž ์ƒ์„ฑํ•˜๋Š” ๋ฐฉ๋ฒ• โšก1. ์—ฐ์†๋œ ์ˆซ์ž(๋‚ ์งœ) ์ž๋™ ์ฑ„์šฐ๊ธฐ ์ฒซ๋ฒˆ์งธ ์นธ๊ณผ ๋‘ ๋ฒˆ์งธ ์นธ์— 1,2 ๋ฅผ ์ ์–ด์ฃผ๊ณ  ๋‘ ์นธ์„ ๋ชจ๋‘ ์„ awesomepossum.tistory.com 1. ์ฒดํฌ ๋ฐ•์Šค ๋„ฃ๊ธฐ๋จผ์ €, ๋นˆ ๋ฐ•์Šค(๐Ÿ”ฒ) ๋ชจ์–‘์œผ๋กœ ์žˆ๋‹ค๊ฐ€ ๋งˆ์šฐ์Šค๋กœ ํด๋ฆญํ•˜๋ฉด ์ฒดํฌ ๋ฐ•์Šค(โ˜‘๏ธ)๊ฐ€ ๋˜๋Š” ๊ธฐ๋Šฅ์„ ์ถ”๊ฐ€ํ•ด ..
์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ ์ด๋ฒคํŠธ ๋ฆฌ์Šค๋„ˆ ๊ฐ„๋‹จํžˆ ํฌ์ŠคํŒ…ํ•˜๋ ค๊ณ  ์‹ฌํ”Œํ•œ To Do List๋ฅผ ๋งŒ๋“ค์–ด ๋ณด์•˜๋‹ค!    1. ๊ตฌ๊ธ€ํฐํŠธ, ์Šคํƒ€์ผ์‹œํŠธ, ์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ ์—ฐ๊ฒฐ- `style.css`์™€ `script.js` ์—ฐ๊ฒฐ- ๊ตฌ๊ธ€ ํฐํŠธ `Poppins`  ์‚ฌ์šฉํ•˜๊ธฐ ์œ„ํ•ด์„œ Embed Code๋ฅผ 2.  ์ „์ฒด  ์ ์šฉ๋  css ์„ค์ • & container์— ๋ฐฐ๊ฒฝ ์ถ”๊ฐ€โšก  ํฐํŠธ๋Š” ๊ตฌ๊ธ€ ํฐํŠธ `Poppins` ๋กœ ์„ค์ • โšก `box-sizing: border-box;`์š”์†Œ์˜ ํฌ๊ธฐ๋ฅผ ๊ณ„์‚ฐํ•  ๋•Œ `ํŒจ๋”ฉ(padding)`๊ณผ `ํ…Œ๋‘๋ฆฌ(border)`๊นŒ์ง€ ํฌํ•จํ•˜๋„๋ก ์„ค์ •ํ•˜๋Š” ์†์„ฑ. ๊ธฐ๋ณธ์ ์œผ๋กœ CSS์—์„œ box-sizing์˜ ๊ธฐ๋ณธ๊ฐ’์€ `content-box`์ด๋‹ค. `content-box`๋Š” ์š”์†Œ์˜ `width`์™€ `height`๊ฐ€ ์ฝ˜ํ…์ธ  ์˜์—ญ..
โœ… session ๊ด€๋ฆฌโœ… logout.jspโœ… main.jsp ๋งŒ๋“ค๊ธฐ ์ง€๊ธˆ๊นŒ์ง€ ํšŒ์›๊ฐ€์ž…, ๋กœ๊ทธ์ธ ๊ธฐ๋Šฅ๊นŒ์ง€ ๊ตฌํ˜„ํ•ด๋ณด์•˜๋‹ค.์ด์ œ ์„ธ์…˜ ๊ด€๋ฆฌ๋ฅผ ํ•ด ๋ณด์ž. `session` ์ด๋ž€ ํ˜„์žฌ ์ ‘์†ํ•œ ํšŒ์›์—๊ฒŒ ํ• ๋‹นํ•ด์ฃผ๋Š” ๊ณ ์œ ํ•œ ์•„์ด๋””์ด๋‹ค.๋กœ๊ทธ์ธ์— ์„ฑ๊ณตํ•œ ํšŒ์›์—๊ฒŒ ๊ฐ๊ฐ `session`์„ ๋ถ€์—ฌํ•ด์ฃผ๋Š” ๊ณผ์ •์„ ๊ตฌํ˜„ํ•ด๋ณด์ž. `loginAction.jsp`์— `session`์„ ์„ค์ •ํ•ด์ฃผ๋Š” `session.setAttribute()` ์ฝ”๋“œ ํ•œ ์ค„ ํƒ€์ดํ•‘!`joinAction.jsp`์—๋„ ์ฝ”๋“œ ๋ณต๋ถ™ํ•ด์„œ ๋„ฃ์–ด ์ค€๋‹ค.๋กœ๊ทธ์ธ ์„ฑ๊ณตํ•œ ํšŒ์›์—๊ฒŒ ์„ธ์…˜ ๋ถ€์—ฌํ•˜๊ณ  ๋ฉ”์ธ ํŽ˜์ด์ง€๋กœ ๋„˜์–ด๊ฐ€๊ฒŒ๋” ํ•ด ์ค€๋‹ค. ์ด๋ ‡๊ฒŒ ์„ธ์…˜์„ ์„ค์ •ํ•ด ์ฃผ์—ˆ๋‹ค. ์„ธ์…˜์€ ํ•ด์ œ ํ•˜๊ธฐ ์ „๊นŒ์ง€๋Š” ์œ ํšจํ•˜๊ธฐ ๋•Œ๋ฌธ์— ํ• ๋‹นํ•œ ์„ธ์…˜์„ ํ•ด์ œํ•  ์ˆ˜ ์žˆ๋Š” ๋กœ๊ทธ์•„์›ƒ ํŽ˜์ด์ง€๋„ ๋งŒ๋“ค์–ด ์ฃผ์ž. `joinAc..
์ธ์ ˆ๋ฏธ์˜€๋˜๊ฒƒ
'๋งŒ๋“ค๊ธฐ' ํƒœ๊ทธ์˜ ๊ธ€ ๋ชฉ๋ก
์ƒ๋‹จ์œผ๋กœ