From 43fbeb68d28311131864232fc8272298c0cecd2a Mon Sep 17 00:00:00 2001
From: HyunsuChoi <mysj923@ajou.ac.kr>
Date: Mon, 17 Jul 2023 15:20:16 +0900
Subject: [PATCH] musicSearch

---
 ?                                             |  0
 .../controller/MyWebController.java           | 45 +++++++++++++++++++
 .../kr/ajousw/myspringweb/dto/MusicList.java  | 18 ++++++++
 ...EATE DATABASE webdev default character.sql |  1 +
 src/main/resources/application.properties     |  5 +--
 5 files changed, 66 insertions(+), 3 deletions(-)
 create mode 100644 ?
 create mode 100644 src/main/java/kr/ajousw/myspringweb/controller/MyWebController.java
 create mode 100644 src/main/java/kr/ajousw/myspringweb/dto/MusicList.java
 create mode 100644 src/main/resources/CREATE DATABASE webdev default character.sql

diff --git a/? b/?
new file mode 100644
index 0000000..e69de29
diff --git a/src/main/java/kr/ajousw/myspringweb/controller/MyWebController.java b/src/main/java/kr/ajousw/myspringweb/controller/MyWebController.java
new file mode 100644
index 0000000..d1a51e9
--- /dev/null
+++ b/src/main/java/kr/ajousw/myspringweb/controller/MyWebController.java
@@ -0,0 +1,45 @@
+package kr.ajousw.myspringweb.controller;
+
+import java.io.IOException;
+import org.springframework.web.bind.annotation.GetMapping;
+import org.springframework.web.bind.annotation.PathVariable;
+import org.springframework.web.bind.annotation.RequestParam;
+import org.springframework.web.bind.annotation.RestController;
+import org.springframework.web.client.RestTemplate;
+import com.fasterxml.jackson.databind.ObjectMapper;
+import kr.ajousw.myspringweb.dto.MusicList;
+
+@RestController
+public class MyWebController {
+    @GetMapping(value="/musicSearch/{term}")
+    public MusicList musicSearchByPath(@PathVariable String term) {
+        RestTemplate restTemplate = new RestTemplate();
+        try { 
+            String url = "https://itunes.apple.com/search?term=" + term + "&entity=album";
+            String response = restTemplate.getForObject(url, String.class);
+            ObjectMapper mapper = new ObjectMapper();
+            MusicList list = mapper.readValue(response, MusicList.class);
+            System.out.println(list.getResultCount());
+            return list;
+        } catch(IOException e) {
+            System.out.println(e.toString());
+            return null;
+        }
+    }
+
+    @GetMapping(value="musicSearch")
+    public MusicList musicSearchByParam(@RequestParam String term){
+        RestTemplate restTemplate = new RestTemplate();
+        try { 
+            String url = "https://itunes.apple.com/search?term=" + term + "&entity=album";
+            String response = restTemplate.getForObject(url, String.class);
+            ObjectMapper mapper = new ObjectMapper();
+            MusicList list = mapper.readValue(response, MusicList.class);
+            System.out.println(list.getResultCount());
+            return list;
+        } catch(IOException e) {
+            System.out.println(e.toString());
+            return null;
+        }
+    }
+}
\ No newline at end of file
diff --git a/src/main/java/kr/ajousw/myspringweb/dto/MusicList.java b/src/main/java/kr/ajousw/myspringweb/dto/MusicList.java
new file mode 100644
index 0000000..e025724
--- /dev/null
+++ b/src/main/java/kr/ajousw/myspringweb/dto/MusicList.java
@@ -0,0 +1,18 @@
+package kr.ajousw.myspringweb.dto;
+
+import lombok.Getter;
+import lombok.Setter;
+import lombok.ToString;
+import java.util.List;
+import java.util.Map;
+
+
+@Getter
+@Setter
+@ToString
+
+public class MusicList {
+    private Integer resultCount;
+    private List<Map<String, Object>> results;
+
+}
\ No newline at end of file
diff --git a/src/main/resources/CREATE DATABASE webdev default character.sql b/src/main/resources/CREATE DATABASE webdev default character.sql
new file mode 100644
index 0000000..4e84d92
--- /dev/null
+++ b/src/main/resources/CREATE DATABASE webdev default character.sql	
@@ -0,0 +1 @@
+CREATE DATABASE webdev default character set utf8 collate utf8_general_ci
\ No newline at end of file
diff --git a/src/main/resources/application.properties b/src/main/resources/application.properties
index 7e45864..a118e48 100644
--- a/src/main/resources/application.properties
+++ b/src/main/resources/application.properties
@@ -1,7 +1,6 @@
-server.port = 8098
+server.port = 13131
 spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
-spring.datasource.url=jdbc:mysql://210.107.196.163:44698/webdev?serverTimezone=
-UTC
+spring.datasource.url=jdbc:mysql://210.107.196.163:44698/webdev?serverTimezone=UTC
 spring.datasource.username=root
 spring.datasource.password=mysj923
 spring.jpa.properties.hibernate.show_sql=true
-- 
GitLab