๐Ÿ“Œ 11์ฃผ์ฐจ ๊ณผ์ œ[Mission11]

API ์‚ฌ์šฉ์— ๋Œ€ํ•ด ๊ถ๊ธˆํ•œ ์ ์€ '#05_ํ•™์Šต_์งˆ์˜์‘๋‹ต' ์ฑ„๋„์— ์งˆ๋ฌธ ๋‚จ๊ฒจ์ฃผ์„ธ์š”!

ํ•„์ˆ˜ ๊ณผ์ œ

  • ๊ณผ์ œ ๊ธฐํ•œ
    • ๊ณผ์ œ ์ˆ˜ํ–‰ ๊ธฐ๊ฐ„ : 2023๋…„ 11์›” 30์ผ(๋ชฉ) ~ 2023๋…„ 12์›” 4์ผ(์›”)
    • ๋ฉ˜ํ‹ฐ ์ฝ”๋“œ ๋ฆฌ๋ทฐ ๊ธฐ๊ฐ„ : 2023๋…„ 12์›” 5์ผ(ํ™”) ~ 2023๋…„ 12์›” 6์ผ(์ˆ˜)
    • ๋ฉ˜ํ†  ์ฝ”๋“œ ๋ฆฌ๋ทฐ ๊ธฐ๊ฐ„ : 2023๋…„ 12์›” 5์ผ(ํ™”) ~ 2023๋…„ 12์›” 8์ผ(๊ธˆ)
    • ์ฝ”๋“œ ๋ฆฌ๋ทฐ ๋ฐ˜์˜ ๊ธฐ๊ฐ„ : 2023๋…„ 12์›” 11์ผ(์›”) ~ 2023๋…„ 12์›” 12์ผ(ํ™”)
  • ๋‚ด์šฉ
    • Vue.js์™€ ์˜ํ™” ๊ฒ€์ƒ‰ API๋ฅผ ํ™œ์šฉํ•ด ํ”„๋กœ์ ํŠธ๋ฅผ ๋งŒ๋“œ์„ธ์š”.

๊ธฐ๋ณธ ์š”๊ตฌ์‚ฌํ•ญ

  • ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ๋ฅผ ์‚ฌ์šฉํ•ด์•ผ ํ•ฉ๋‹ˆ๋‹ค!
  • ๊ฒ€์ƒ‰์–ด๋ฅผ ์ž…๋ ฅํ•ด ์˜ํ™”๋ฅผ ๊ฒ€์ƒ‰ํ•  ์ˆ˜ ์žˆ์–ด์•ผ ํ•ฉ๋‹ˆ๋‹ค!
  • ๊ฒ€์ƒ‰๋œ ๊ฒฐ๊ณผ๋ฅผ ํ†ตํ•ด ์˜ํ™”์˜ ์ƒ์„ธ ์ •๋ณด๋ฅผ ๋ณผ ์ˆ˜ ์žˆ์–ด์•ผ ํ•ฉ๋‹ˆ๋‹ค!
  • ํด๋ผ์ด์–ธํŠธ(๋ธŒ๋ผ์šฐ์ €)์—์„œ API Key(7035c60c)๊ฐ€ ๋…ธ์ถœ๋˜์ง€ ์•Š์•„์•ผ ํ•ฉ๋‹ˆ๋‹ค!
  • ์‹ค์ œ ์„œ๋น„์Šค๋กœ ๋ฐฐํฌํ•˜๊ณ  ์ ‘๊ทผ ๊ฐ€๋Šฅํ•œ ๋งํฌ๋ฅผ ์ถ”๊ฐ€ํ•ด์•ผ ํ•ฉ๋‹ˆ๋‹ค!

์„ ํƒ ์š”๊ตฌ์‚ฌํ•ญ

  • Vue Composition API๋ฅผ ์‚ฌ์šฉํ•ด ๋ณด์„ธ์š”.
  • API ์š”์ฒญ(Request)์— ๋Œ€ํ•œ ๋กœ๋”ฉ ์• ๋‹ˆ๋ฉ”์ด์…˜์„ ์ถ”๊ฐ€ํ•ด ๋ณด์„ธ์š”.
  • ์˜ํ™” ์ƒ์„ธ ๊ฒ€์ƒ‰์œผ๋กœ ์ถœ๋ ฅํ•  ์˜ํ™” ํฌ์Šคํ„ฐ๋ฅผ ๋” ๋†’์€ ํ•ด์ƒ๋„ ์‚ฌ์šฉํ•ด ๋ณด์„ธ์š”.
    • ์˜ํ™” ํฌ์Šคํ„ฐ ์ฃผ์†Œ์— ํฌํ•จ๋œ SX300๋ฅผ SX700๊ณผ ๊ฐ™์ด ๋” ํฐ ์ˆซ์ž๋กœ ์ˆ˜์ •ํ•ด ์š”์ฒญํ•˜์„ธ์š”.
    • ์‹ค์‹œ๊ฐ„์œผ๋กœ ์ด๋ฏธ์ง€์˜ ํฌ๊ธฐ๋ฅผ ๋‹ค๋ฅด๊ฒŒ ์š”์ฒญํ•˜๋Š” ๊ฒƒ์ด ์–ด๋–ค ์›๋ฆฌ๋กœ ๊ฐ€๋Šฅํ•œ์ง€ ์กฐ์‚ฌํ•ด ๋ณด์„ธ์š”.
  • ์š”์ฒญ ์ฃผ์†Œ์— HTTP๊ฐ€ ์•„๋‹Œ HTTPS ํ”„๋กœํ† ์ฝœ์„ ์‚ฌ์šฉํ•ด์•ผ ํ•˜๋Š” ์ด์œ ๋ฅผ ์กฐ์‚ฌํ•ด ๋ณด์„ธ์š”.
  • Bootstrap, Tailwind ๊ฐ™์€ UI ํ”„๋ ˆ์ž„์›Œํฌ๋ฅผ ์‚ฌ์šฉํ•˜๊ฑฐ๋‚˜ ํ˜น์€ ์ง์ ‘ ํ”„๋กœ์ ํŠธ๋ฅผ ์˜ˆ์˜๊ฒŒ ๋งŒ๋“ค์–ด ๋ณด์„ธ์š”.
  • Open Graph ํ˜น์€ Twitter Cards๋กœ ๋ฉ”ํƒ€ ์ •๋ณด๋ฅผ ์ œ๊ณตํ•ด ๋ณด์„ธ์š”.

API ์‚ฌ์šฉ๋ฒ•

  • ์ฐธ๊ณ  ์‚ฌ์ดํŠธ: The Open Movie Database
  • ์š”์ฒญ ์ฃผ์†Œ: https://omdbapi.com
  • Method: GET
  • API_KEY: 7035c60c

์˜ํ™” ๋ชฉ๋ก ๊ฒ€์ƒ‰

ํŒŒ๋ผ๋ฏธํ„ฐ ํ•„์ˆ˜ ์„ค๋ช… ๊ธฐ๋ณธ๊ฐ’ ์œ ํšจ ๊ฐ’
s ์˜ˆ ๊ฒ€์ƒ‰ํ•  ์˜ํ™” ์ œ๋ชฉ
y ์˜ํ™” ์ถœ์‹œ ๋…„๋„
page ๊ฒ€์ƒ‰ ๊ฒฐ๊ณผ ํŽ˜์ด์ง€ 1 1~100

์š”์ฒญ ์˜ˆ์‹œ:

https://omdbapi.com?apikey=7035c60c&s=frozen&page=3

์‘๋‹ต ํƒ€์ž…:

interface ResponseValue {
  Search: Search
  totalResults: string
  Response: string
}
interface Search {
  Title: string
  Year: string
  imdbID: string
  Type: string
  Poster: string
}

์‘๋‹ต ์˜ˆ์‹œ:

  • Search: ์˜ํ™” ๋ชฉ๋ก, 1ํŽ˜์ด์ง€(page) ๋‹น ์ตœ๋Œ€ 10๊ฐœ
  • totalResults: ๊ฒ€์ƒ‰ ๊ฐ€๋Šฅํ•œ ๋ชจ๋“  ์˜ํ™” ๊ฐœ์ˆ˜
  • Response: ์ •์ƒ์ ์ธ ์‘๋‹ต ์—ฌ๋ถ€
{
  "Search": [
    {
      "Title": "Frozen",
      "Year": "2013",
      "imdbID": "tt2294629",
      "Type": "movie",
      "Poster": "https://m.media-amazon.com/images/M/MV5BMjA0YjYy...eQXVyNDg4NjY5OTQ@._V1_SX300.jpg"
    },
    "...์ตœ๋Œ€10๊ฐœ"
  ],
  "totalResults": "263",
  "Response": "True"
}

์˜ํ™” ์ƒ์„ธ ๊ฒ€์ƒ‰

ํŒŒ๋ผ๋ฏธํ„ฐ ํ•„์ˆ˜ ์„ค๋ช… ๊ธฐ๋ณธ๊ฐ’ ์œ ํšจ ๊ฐ’
i ์˜ˆ ๊ฒ€์ƒ‰ํ•  ์˜ํ™” ์•„์ด๋””(imdbID)
plot ์˜ํ™” ์ค„๊ฑฐ๋ฆฌ ๊ธธ์ด short full

์š”์ฒญ ์˜ˆ์‹œ:

https://omdbapi.com?apikey=7035c60c&i=tt4520988&plot=full

์‘๋‹ต ํƒ€์ž…:

interface ResponseValue {
  Title: string
  Year: string
  Rated: string
  Released: string
  Runtime: string
  Genre: string
  Director: string
  Writer: string
  Actors: string
  Plot: string
  Language: string
  Country: string
  Awards: string
  Poster: string
  Ratings: {
    Source: string
    Value: string
  }[]
  Metascore: string
  imdbRating: string
  imdbVotes: string
  imdbID: string
  Type: string
  DVD: string
  BoxOffice: string
  Production: string
  Website: string
  Response: string
}

์‘๋‹ต ์˜ˆ์‹œ:

{
  "Title": "Frozen II",
  "Year": "2019",
  "Rated": "PG",
  "Released": "22 Nov 2019",
  "Runtime": "103 min",
  "Genre": "Animation, Adventure, Comedy",
  "Director": "Chris Buck, Jennifer Lee",
  "Writer": "Jennifer Lee, Hans Christian Andersen, Chris Buck",
  "Actors": "Kristen Bell, Idina Menzel, Josh Gad",
  "Plot": "Having harnessed her ever-growing power after lifting the dreadful curse of the eternal winter in Frozen (2013),",
  "Language": "English",
  "Country": "United States",
  "Awards": "Nominated for 1 Oscar. 17 wins & 90 nominations total",
  "Poster": "https://m.media-amazon.com/images/M/MV5BMjA0YjYy...eQXVyNDg4NjY5OTQ@._V1_SX300.jpg",
  "Ratings": [
    {
      "Source": "Internet Movie Database",
      "Value": "6.8/10"
    },
    {
      "Source": "Rotten Tomatoes",
      "Value": "77%"
    },
    {
      "Source": "Metacritic",
      "Value": "64/100"
    }
  ],
  "Metascore": "64",
  "imdbRating": "6.8",
  "imdbVotes": "151,940",
  "imdbID": "tt4520988",
  "Type": "movie",
  "DVD": "22 Nov 2019",
  "BoxOffice": "$477,373,578",
  "Production": "Walt Disney Animation, Walt Disney Pictures",
  "Website": "N/A",
  "Response": "True"
}