Toggle navigation
Toggle navigation
This project
Loading...
Sign in
박정민
/
TFT
Go to a project
Toggle navigation
Toggle navigation pinning
Projects
Groups
Snippets
Help
Project
Activity
Repository
Pipelines
Graphs
Issues
0
Merge Requests
0
Wiki
Snippets
Network
Create a new issue
Builds
Commits
Issue Boards
Authored by
hellowhales
2021-11-30 02:16:28 +0900
Browse Files
Options
Browse Files
Download
Email Patches
Plain Diff
Commit
abbd29250f6e488dfbb10cdc9a2d1dc66bdaa4b3
abbd2925
1 parent
39dae057
APIhandelr Alpha version
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
93 additions
and
66 deletions
APIhandler.js
models/Festival.js
server.js
APIhandler.js
View file @
abbd292
let
request
=
require
(
'request'
);
let
options
=
{
'method'
:
'GET'
,
'url'
:
'http://api.visitkorea.or.kr/openapi/service/rest/KorService/areaBasedList?ServiceKey=
2lFkvQJYgzOOhwUKiUt8aZVNpd1PpBOf%2FfMNW17cl25DE0GUEDddeR9iGnuSUpggjUoIUgamfhcvnKQ3eH1dA
w%3D%3D&contentTypeId=15&areaCode=&sigunguCode=&cat1=&cat2=&cat3=&listYN=Y&MobileOS=ETC&MobileApp=TourAPI3.0_Guide&arrange=C&numOfRows=12&pageNo=1&_type=json'
,
'url'
:
'http://api.visitkorea.or.kr/openapi/service/rest/KorService/areaBasedList?ServiceKey=
3zrQDvoNwUV9Se%2BHZv8DjCCNWRGJisQ7jjHP6LsbJqoRQ2cJpQKrHUGC4uslgXSVO9Dzb06BSC3kp9BunvIPS
w%3D%3D&contentTypeId=15&areaCode=&sigunguCode=&cat1=&cat2=&cat3=&listYN=Y&MobileOS=ETC&MobileApp=TourAPI3.0_Guide&arrange=C&numOfRows=12&pageNo=1&_type=json'
,
'headers'
:
{
}
};
...
...
@@ -18,7 +18,7 @@ for(i in info['response']['body']['items']['item']){
'public'
:
{
'method'
:
'GET'
,
'url'
:
'http://api.visitkorea.or.kr/openapi/service/rest/KorService/detailCommon?'
+
'ServiceKey='
+
'
2lFkvQJYgzOOhwUKiUt8aZVNpd1PpBOf%2FfMNW17cl25DE0GUEDddeR9iGnuSUpggjUoIUgamfhcvnKQ3eH1dA
w%3D%3D'
+
'ServiceKey='
+
'
3zrQDvoNwUV9Se%2BHZv8DjCCNWRGJisQ7jjHP6LsbJqoRQ2cJpQKrHUGC4uslgXSVO9Dzb06BSC3kp9BunvIPS
w%3D%3D'
+
'&contentTypeId='
+
'15'
+
'&contentId='
+
+
contentId
[
i
]
+
'&MobileOS=ETC&MobileApp=TourAPI3.0_Guide&defaultYN=Y&firstImageYN=Y&areacodeYN=Y&catcodeYN=Y&addrinfoYN=Y&mapinfoYN=Y&overviewYN=Y&transGuideYN=Y&_type=json'
,
...
...
@@ -27,7 +27,7 @@ for(i in info['response']['body']['items']['item']){
'detail'
:
{
'method'
:
'GET'
,
'url'
:
'http://api.visitkorea.or.kr/openapi/service/rest/KorService/detailIntro?'
+
'ServiceKey='
+
'
2lFkvQJYgzOOhwUKiUt8aZVNpd1PpBOf%2FfMNW17cl25DE0GUEDddeR9iGnuSUpggjUoIUgamfhcvnKQ3eH1dA
w%3D%3D'
+
'ServiceKey='
+
'
3zrQDvoNwUV9Se%2BHZv8DjCCNWRGJisQ7jjHP6LsbJqoRQ2cJpQKrHUGC4uslgXSVO9Dzb06BSC3kp9BunvIPS
w%3D%3D'
+
'&contentTypeId='
+
'15'
+
'&contentId='
+
contentId
[
i
]
+
'&MobileOS=ETC&MobileApp=TourAPI3.0_Guide&introYN=Y&_type=json'
,
...
...
@@ -36,7 +36,7 @@ for(i in info['response']['body']['items']['item']){
'weather'
:
{
'method'
:
'GET'
,
'url'
:
'http://apis.data.go.kr/1360000/VilageFcstInfoService_2.0/getVilageFcst?'
+
'serviceKey='
+
'
2lFkvQJYgzOOhwUKiUt8aZVNpd1PpBOf%2FfMNW17cl25DE0GUEDddeR9iGnuSUpggjUoIUgamfhcvnKQ3eH1dA
w%3D%3D'
+
'serviceKey='
+
'
3zrQDvoNwUV9Se%2BHZv8DjCCNWRGJisQ7jjHP6LsbJqoRQ2cJpQKrHUGC4uslgXSVO9Dzb06BSC3kp9BunvIPS
w%3D%3D'
+
'&pageNo='
+
'1'
+
'&numOfRows='
+
'50'
+
'&dataType='
+
'JSON'
...
...
models/Festival.js
View file @
abbd292
...
...
@@ -6,12 +6,25 @@ const festivalSchema = new Schema({
addr
:
String
,
tel
:
String
,
mapx
:
Number
,
mapy
:
Number
mapy
:
Number
,
eventstartdate
:
String
,
eventenddate
:
String
,
overview
:
String
,
firstimage
:
String
,
homepage
:
String
,
district
:
String
,
city
:
String
,
temparature
:
Number
,
weathers
:
String
// weather : {
// date1: { weather : String, temp : Number},
// date2: { weather : String, temp : Number},
// date3: { weather : String, temp : Number},
// }
},
{
timestamps
:
true
}
);
versionKey
:
false
});
module
.
exports
=
mongoose
.
model
(
'Festival'
,
festivalSchema
);
...
...
server.js
View file @
abbd292
...
...
@@ -2,15 +2,20 @@ const express = require('express');
const
mongoose
=
require
(
'mongoose'
);
const
db
=
require
(
'mongodb'
);
const
Festival
=
require
(
'./models/Festival'
);
const
request
=
require
(
'request-promise-native'
);
require
(
"dotenv"
).
config
({
path
:
"variables.env"
});
const
COORDINATES
=
require
(
'./coordinates'
);
const
COORDINATES
=
require
(
'./coordinates'
)
[
'COORDINATES'
]
;
const
DISTRICT
=
[
"서울특별시"
,
"부산광역시"
,
"울산광역시"
,
"대구광역시"
,
"대전광역시"
,
"인천광역시"
,
"광주광역시"
,
"세종특별자치시"
,
"제주특별자치도"
,
"경기도"
,
"강원도"
,
"충청북도"
,
"충청남도"
,
"경상북도"
,
"경상남도"
,
"전라북도"
,
"전라남도"
]
const
WEATHERTYPE
=
[
'맑음'
,
'비'
,
'비/눈'
,
'눈'
,
'소나기'
];
function
parseDistrict
(
addr
)
{
const
words
=
addr
.
split
(
" "
);
if
(
DISTRICT
.
includes
(
words
[
0
])
)
{
...
...
@@ -19,18 +24,18 @@ function parseDistrict(addr) {
return
[];
}
}
function
leftPad
(
value
)
{
if
(
value
>=
10
)
{
return
value
;
}
return
`0
${
value
}
`
;
}
let
request
=
require
(
'request-promise-native'
);
let
options
=
{
'method'
:
'GET'
,
'url'
:
'http://api.visitkorea.or.kr/openapi/service/rest/KorService/areaBasedList'
+
'?ServiceKey='
+
'2lFkvQJYgzOOhwUKiUt8aZVNpd1PpBOf%2FfMNW17cl25DE0GUEDddeR9iGnuSUpggjUoIUgamfhcvnKQ3eH1dAw%3D%3D'
+
'&contentTypeId=15&areaCode=&sigunguCode=&cat1=&cat2=&cat3=&listYN=Y&MobileOS=ETC&MobileApp=TourAPI3.0_Guide&arrange=C&numOfRows=12'
+
'&pageNo='
+
1
+
'&_type=json'
,
setInterval
(()
=>
{
//여기에 밑에 애들 들어감
},
86400000
);
'headers'
:
{}
};
var
today
=
new
Date
();
var
yesterday
=
new
Date
();
yesterday
.
setDate
(
yesterday
.
getDate
()
-
1
);
let
todayString
=
""
+
(
today
.
getFullYear
())
+
leftPad
(
today
.
getMonth
()
+
1
)
+
leftPad
(
today
.
getDate
());
let
yesterdayString
=
""
+
(
yesterday
.
getFullYear
())
+
leftPad
(
yesterday
.
getMonth
()
+
1
)
+
leftPad
(
yesterday
.
getDate
()
-
1
);
var
todayTime
=
leftPad
(
today
.
getHours
())
+
"00"
;
mongoose
.
connect
(
process
.
env
.
MONGODB_URL
,{
useNewUrlParser
:
true
},(
err
)
=>
{
if
(
err
)
{
...
...
@@ -41,6 +46,19 @@ mongoose.connect(process.env.MONGODB_URL,{useNewUrlParser:true},(err)=>{
console
.
log
(
err
+
"Reset Failed!"
);
}
else
{
console
.
log
(
result
+
"Reset Success!"
);
for
(
let
i
=
1
;
i
<=
5
;
i
++
)
{
let
options
=
{
'method'
:
'GET'
,
'url'
:
'http://api.visitkorea.or.kr/openapi/service/rest/KorService/areaBasedList'
+
'?ServiceKey='
+
'3zrQDvoNwUV9Se%2BHZv8DjCCNWRGJisQ7jjHP6LsbJqoRQ2cJpQKrHUGC4uslgXSVO9Dzb06BSC3kp9BunvIPSw%3D%3D'
+
'&contentTypeId=15&areaCode=&sigunguCode=&cat1=&cat2=&cat3=&listYN=Y&MobileOS=ETC&MobileApp=TourAPI3.0_Guide&arrange=C&numOfRows=12'
+
'&pageNo='
+
i
+
'&_type=json'
,
'headers'
:
{}
};
request
(
options
,
async
function
(
error
,
response
,
body
)
{
if
(
error
)
{
throw
new
Error
(
error
);
...
...
@@ -69,15 +87,7 @@ mongoose.connect(process.env.MONGODB_URL,{useNewUrlParser:true},(err)=>{
},
'weather'
:
{
'method'
:
'GET'
,
'url'
:
'http://apis.data.go.kr/1360000/VilageFcstInfoService_2.0/getVilageFcst?'
+
'serviceKey='
+
'2lFkvQJYgzOOhwUKiUt8aZVNpd1PpBOf%2FfMNW17cl25DE0GUEDddeR9iGnuSUpggjUoIUgamfhcvnKQ3eH1dAw%3D%3D'
+
'&pageNo='
+
'1'
+
'&numOfRows='
+
'50'
+
'&dataType='
+
'JSON'
+
'&base_date='
+
'20211129'
+
'&base_time='
+
'0500'
+
'&nx='
+
'55'
+
'&ny='
+
'127'
,
'url'
:
''
,
'headers'
:
{}
}
};
...
...
@@ -85,9 +95,11 @@ mongoose.connect(process.env.MONGODB_URL,{useNewUrlParser:true},(err)=>{
if
(
error
)
{
throw
new
Error
(
error
);
}
let
toSave
=
true
;
let
pinfo
=
JSON
.
parse
(
body
);
let
distriction
=
parseDistrict
(
pinfo
[
'response'
][
'body'
][
'items'
][
'item'
][
'addr1'
]);
if
(
!
distriction
)
reject
(
"탈출"
);
if
(
distriction
.
length
==
0
)
toSave
=
false
;
const
newFestival
=
new
Festival
();
newFestival
.
title
=
pinfo
[
'response'
][
'body'
][
'items'
][
'item'
][
'title'
];
...
...
@@ -99,7 +111,7 @@ mongoose.connect(process.env.MONGODB_URL,{useNewUrlParser:true},(err)=>{
newFestival
.
firstimage
=
pinfo
[
'response'
][
'body'
][
'items'
][
'item'
][
'firstimage'
];
newFestival
.
homepage
=
pinfo
[
'response'
][
'body'
][
'items'
][
'item'
][
'homepage'
];
newFestival
.
district
=
distriction
[
0
];
// 광역시/도
newFestival
.
city
=
parseDistrict
[
1
];
// 시군구
newFestival
.
city
=
distriction
[
1
];
// 시군구
await
request
(
Info
.
detail
,
function
(
error
,
response
,
body
)
{
if
(
error
)
{
...
...
@@ -108,51 +120,53 @@ mongoose.connect(process.env.MONGODB_URL,{useNewUrlParser:true},(err)=>{
let
dinfo
=
JSON
.
parse
(
body
);
newFestival
.
eventstartdate
=
dinfo
[
'response'
][
'body'
][
'items'
][
'item'
][
'eventstartdate'
];
newFestival
.
eventenddate
=
dinfo
[
'response'
][
'body'
][
'items'
][
'item'
][
'eventenddate'
];
if
(
newFestival
.
eventenddate
<
todayString
)
toSave
=
false
;
});
// let [nx, ny] = COORDINATES[distriction[0]][distriction[1]];
// Info.weather.url = 'http://apis.data.go.kr/1360000/VilageFcstInfoService_2.0/getVilageFcst?'
// + 'serviceKey=' + '2lFkvQJYgzOOhwUKiUt8aZVNpd1PpBOf%2FfMNW17cl25DE0GUEDddeR9iGnuSUpggjUoIUgamfhcvnKQ3eH1dAw%3D%3D'
// + '&pageNo=' + '1'
// + '&numOfRows=' + '50'
// + '&dataType=' + 'JSON'
// + '&base_date=' + '20211129'
// + '&base_time=' + '0500'
// + '&nx=' + nx
// + '&ny=' + ny;
// await request(Info.weather, function (error, response, body) {
// if (error) {
// throw new Error(error);
// }
// let winfo = JSON.parse(body);
// for( let item of winfo['response']['body']['items']['item'] ) {
// if(item['category']=='TMP') {
// console.log('온도: '+item['fcstValue']);
// } else if(item['category']=='PTY') {
// let weather_code = item['fcstValue']
// if (weather_code == '1'){ console.log('날씨 : 비');}
// else if (weather_code == '2'){ console.log('날씨 :비/눈') ;}
// else if (weather_code == '3'){ console.log('날씨 :눈') ;}
// else if (weather_code == '4'){ console.log('날씨 :소나기') ;}
// else{console.log('날씨 :맑음') ;}
// }
// }
// });
let
[
nx
,
ny
]
=
COORDINATES
[
distriction
[
0
]][
distriction
[
1
]];
let
curDate
=
(
'0500'
<
todayTime
?
todayString
:
yesterdayString
);
Info
.
weather
.
url
=
'http://apis.data.go.kr/1360000/VilageFcstInfoService_2.0/getVilageFcst?'
+
'serviceKey='
+
'2lFkvQJYgzOOhwUKiUt8aZVNpd1PpBOf%2FfMNW17cl25DE0GUEDddeR9iGnuSUpggjUoIUgamfhcvnKQ3eH1dAw%3D%3D'
+
'&pageNo='
+
'1'
+
'&numOfRows='
+
'2000'
+
'&dataType='
+
'JSON'
+
'&base_date='
+
'20211129'
+
'&base_time='
+
'0500'
+
'&nx='
+
nx
+
'&ny='
+
ny
;
await
request
(
Info
.
weather
,
function
(
error
,
response
,
body
)
{
if
(
error
)
{
throw
new
Error
(
error
);
}
let
winfo
=
JSON
.
parse
(
body
);
let
weathers
=
{};
for
(
let
item
of
winfo
[
'response'
][
'body'
][
'items'
][
'item'
]
)
{
if
(
item
[
'fcstTime'
]
===
'1200'
)
{
// 최고기온 + 날씨
let
fcstDate
=
item
[
'fcstDate'
];
if
(
!
weathers
[
fcstDate
])
weathers
[
fcstDate
]
=
{};
if
(
item
[
'category'
]
==
'TMP'
)
{
weathers
[
fcstDate
][
'temp'
]
=
item
[
'fcstValue'
];
}
else
if
(
item
[
'category'
]
==
'PTY'
)
{
weathers
[
fcstDate
][
'weather'
]
=
WEATHERTYPE
[
item
[
'fcstValue'
]];
}
}
}
newFestival
.
weathers
=
JSON
.
stringify
(
weathers
);
});
if
(
toSave
)
await
newFestival
.
save
().
then
((
festival
)
=>
{
console
.
log
(
festival
,
"Save success!"
);
});
})
/*.catch(error => {
console.log(error);
});*/
})
}
});
}
}
});
}
});
\ No newline at end of file
...
...
Please
register
or
login
to post a comment