Open API
Open API 를 이용하기 위해서는 먼저 관련 API 에 대한 인증 키를 발급 받아야 하며 이는 API 별로 상이할 수 있다. HSP 에서는 인증키 관리를 단말이 아닌 Operation Admin 페이지에서 할 수 있도록 메뉴를 제공하고 있고, 다수개의 인증 키를 입력 받아 API 별 하루 요청 제한에 대한 대응을 할 수 있도록 구현되어 있다. (만약 하루에 500 건 한도가 존재하는 API 이면 다수개의 인증 키를 추가하여 500 건 이상의 요청을 할 수 있게 한다.)
getAddress
Address 는 찾고자 하는 주소의 특정 단어를 2 글자 이상으로 전달하여 검색하고 그 검색 결과를 전달 받는 API 이다.
Address 는 도로명주소 안내시스템에서 제공하는 Open API 를 이용하여 구현하고 있으며 해당 API 를 호출 하기 위한 인증 키는 도로명주소 안내시스템 개발자센터에서 신청 하여 발급받을 수 있다.
API 요청 시 주의할 점은 Chrome 브라우저에서는 해당 페이지가 열리지 않으므로 다른 브라우저 (IE) 를 이용해서 신청 해야 하며, 신청 하여 얻은 인증키는 HSP 의 Operation Admin 에서 등록하여 관리할 수 있다. Address 의 경우 하루에 요청할 수 있는 API 요청이 무제한이므로 다수개의 인증 키를 넣을 필요는 없다.
address 요청 시 필요한 인자 정보는 아래와 같으며 해당 API 에 대한 자세한 세부내용이 필요할 경우는 웹사이트인 도로명주소 안내시스템에서 확인할 수 있다.
No | Name | Descriptions |
---|---|---|
1 | keyword | 검색어 |
2 | pageNo | 현재 페이지 번호 |
3 | perPage | 페이지당 출력할 결과 수 |
Example
String page = "1";
String perPage = "10";
// 3.10.18 이상
DAPOpenApi.address(activity, keyword, page, perPage, {
// TODO
}) {
// TODO
}
// 3.10.18 이하
DAPOpenApi.address(keyword, page, perPage) { result, value ->
when (result) {
OnResultListener.TRUE -> {
// TODO
}
else -> {
// TODO
}
}
}
String page = "1";
String perPage = "10";
// 3.10.18 이상
DAPOpenApi.address(activity, keyword, page, perPage, result -> {
// TODO
}, e -> {
// TODO
});
// 3.10.18 이하
DAPOpenApi.address(keyword, page, perPage, (result, value) -> {
switch (result) {
case OnResultListener.TRUE:
// TODO
break;
default:
// TODO
break;
}
});
Result
"results": {
"common": {
"errorMessage": "정상",
"countPerPage": "10",
"totalCount": "1",
"errorCode": "0",
"currentPage": "1"
},
"juso": [{
"detBdNmList": "B 동,파인에비뉴",
"engAddr": "100, Eulji-ro, Jung-gu, Seoul",
"rn": "을지로",
"emdNm": "을지로 2 가",
"zipNo": "04551",
"roadAddrPart2": " (을지로 2 가)",
"emdNo": "02",
"sggNm": "중구",
"jibunAddr": "서울특별시 중구 을지로 2 가 203 파인에비뉴",
"siNm": "서울특별시",
"roadAddrPart1": "서울특별시 중구 을지로 100",
"bdNm": "파인에비뉴",
"admCd": "1114010500",
"udrtYn": "0",
"lnbrMnnm": "203",
"roadAddr": "서울특별시 중구 을지로 100 (을지로 2 가)",
"lnbrSlno": "0",
"buldMnnm": "100",
"bdKdcd": "0",
"liNm": "",
"rnMgtSn": "111403101006",
"mtYn": "0",
"bdMgtSn": "1114010500101450000000001",
"buldSlno": "0"
}]
}
}
Table. address 오류 메시지
메시지 | 조치방법 |
---|---|
시스템에러 | 도로명주소 도움센터로 문의 하기 |
승인되지 않은 키 입니다. | 정확한 승인 키를 입력하세요 (검색 API 승인키 사용불가) |
정상적인 경로로 접속하시기 바랍니다. | 요청변수 중 returnUrl 항목이 없습니다. 요청 변수를 다시 확인하세요 |
검색어가 입력되지 않았습니다. | 검색 어를 입력해주세요 |
주소를 상세히 입력해 주시기 바랍니다. | 시도 명으로 검색이 불가 합니다. |
검색 어는 두 글자 이상 입력되어야 합니다. | 한 글자만으로는 검색이 불가합니다. |
검색 어는 문자와 숫자 같이 입력되어야 합니다. | 숫자만으로는 검색이 불가합니다. |
검색어가 너무 깁니다. (한글 40 자 영문, 숫자 80 자 이하) | 80 글자를 초과하는 검색 어는 검색이 불가합니다. |
검색어에 너무 긴 숫자가 포함되어 있습니다. | 10 자리를 초과하는 숫자가 포함된 검색 어는 검색이 불가합니다. |
특수문자 + 숫자만으로는 검색이 불가능 합니다. | 특수문자와 숫자만으로 이루어진 검색 어는 검색이 불가합니다. |
Table. 주소항목 설명
출력변수명 | 타입 | 필수여부 | 설명 |
---|---|---|---|
roadFullAddr | String | Y | 전체 도로명 주소 |
roadAddrPart1 | String | Y | 도로명 주소 (참고항목 제외) |
roadAddrPart2 | String | N | 도로명 주소 (참고항목 제외) |
jibunAddr | String | Y | 지번주소 |
engAddr | String | Y | 도로명 주소 (영문) |
zipNo | String | Y | 우편번호 |
addrDetail | String | N | 고객 입력 상세 주소 |
admCd | String | Y | 행정구역코드 |
rnMgtSn | String | Y | 도로명코드 |
bdMgtSn | String | Y | 건물관리번호 |
detBdNmList | String | N | 상세건물명 |
bdNm | String | N | 건물명 |
bdKdcd | String | N | 공동주택 여부 (1:공통주택, 0: 비공동주택) |
siNm | String | Y | 시도명 |
sggNm | String | Y | 시군구명 |
emdNm | String | Y | 읍면동명 |
liNm | String | N | 법정리명 |
rn | String | Y | 도로명 |
udrtYn | String | Y | 지하여부 (0: 지상, 1: 지하) |
buldMnnm | Number | Y | 건물본번 |
buldSlno | Number | Y | 건물부번 |
mtYn | String | Y | 산 여부 (0: 대지, 1: 산) |
lnbrMnnm | Number | Y | 지번본번 (번지) |
lnbrSlno | Number | Y | 지번부번 (호) |
emdNo | String | Y | 읍/면/동 일련번호 |
getWeather
Weather 는 GPS 의 위도 / 경도 정보를 전달하여 해당 위치의 날씨 정보를 검색해 그 결과를 전달 받는 API 이다.
Weather 는 공공데이터 포털에서 제공하는 동네예보정보조회서비스를 이용하여 구현하고 있으며 해당 사이트에서 Open API 를 호출하기 위한 인증 키도 신청 가능 하다. 신청 후 얻은 인증 키는 HSP 의 Operation 서버에 등록하여 관리할 수 있으며, 다수 개의 인증 키를 입력 시에는 사용하고 있는 인증키가 하루에 요청할 수 있는 제한을 초과 하였을 때 다음 인증 키를 사용하여 재 호출 하도록 설계되었다.
Weather 요청 시 필요한 인자는 아래와 같으며 인자에 대한 세부 내용은 관련 웹 페이지인 동네예보정보조회서비스에서 확인할 수 있다.
Table. Weather 인자 정보
No | Name | Descriptions |
---|---|---|
1 | latitude | 위도 |
2 | longitude | 경도 |
3 | pageNo | 현재 페이지 번호 |
4 | perPage | 페이지당 출력할 결과 수 |
Example
val longitude = DATA
// 3.10.18 이상
DAPOpenApi.weather(activity, latitude, longitude, "1", "10", {
// TODO
}) {
// TODO
}
// 3.10.18 이하
DAPOpenApi.weather(latitude, longitude, "1", "10") { result, value ->
when (result) {
OnResultListener.TRUE -> {
// TODO
}
else -> {
// TODO
}
}
}
double longitude = DATA;
// 3.10.18 이상
DAPOpenApi.weather(latitude, longitude, "1", "10", result -> {
// TODO
}, e -> {
// TODO
});
// 3.10.18 이하
DAPOpenApi.weather(latitude, longitude, "1", "10", (result, value) -> {
// TODO
});
API 요청 시 응답 받는 데이터는 형태는 아래와 같으며 response -> header -> resultCode 항목에서 API 요청이 제대로 이루어 졌는지 확인할 수 있다.
Result
"response":{
"header":{
"resultCode":"0000",
"resultMsg":"OK"
},
"body":{
"items":{
"item":[{
"baseDate":20151013,
"baseTime":1600,
"category":"LGT",
"nx":55,
"ny":127,
"obsrValue":0
}]
},
"numOfRows":10,
"pageNo":1,
"totalCount":10
}
}
}
Table. Weather 결과 정보
Code | Message | Descriptions |
---|---|---|
0000 | 성공 | |
01 | Application Error | 제공기관 서비스 제공 상태가 원활하지 않습니다. |
02 | DB Error | 제공기관 서비스 제공 상태가 원활하지 않습니다. |
03 | No Data | 데이터 없음 오류 |
04 | HTTP Error | 제공기관 서비스 제공 상태가 원활하지 않습니다. |
05 | Service Timeout | 제공기관 서비스 제공 상태가 원활하지 않습니다. |
10 | Invalid Parameter Error | Open API 요청 시 Service Key 파라 미터가 누락되었습니다. |
11 | 필수 요청 파라 미터가 없음 | 요청 하신 Open API 의 필수 파라 미터가 누락되었습니다. |
12 | 해당 오픈 API 서비스가 없거나 폐기됨 | Open API 호출 시 URL 이 잘못 됨 |
20 | 서비스 접근 오류 | 활용승인이 나지 않은 Open API 호출 |
22 | 서비스 요청 제한 횟수 초과 에러 | 일일 활용 건수가 초과 함 (활용건수 증가 필요) |
30 | 등록되지 않은 서비스 키 | 잘못된 서비스 키를 사용하였거나 서비스 키를 URL 인코딩 하지 않음 |
31 | 기한 만료된 서비스 키 | Open API 사용 기간이 만료됨 |
32 | 등록되지 않은 도메인명 또는 IP 주소 | 활용 신청한 서버의 IP 와 실제 Open API 호출한 서버가 다름 |
Table. 아이템 항목 설명
항목(영문) | 항목(국문 | 크기 | 구분 | 샘플 | 설명 |
---|---|---|---|---|---|
baseDate | 발표일자 | 8 | 1 | 20181212 | 발표일 |
baseTime | 발표시각 | 6 | 1 | 0600 | 발표 시간 |
nx | 예보지점 x 좌표 | 2 | 0 | 59 | 입력한 예보지점 X 좌표 |
ny | 예보지점 y 좌표 | 2 | 0 | 125 | 입력한 예보지점 Y 좌표 |
category | 자료구분코드 | 3 | 1 | LGT | 자료구분코드 |
obsrValue | 실황 값 | 2 | 0 | 0 | RN1, T1H, UUU, VVV, WSD 실수로 제공 |
Table. 초 단기 실황 코드 값
항목 값 | 항목 명 | 단위 | 압축비트수 |
---|---|---|---|
T1H | 기온 | °C | 10 |
RN1 | 1 시간 강수량 | mm | 8 |
SKY | 하늘 상태 | 코드 값 | 4 |
UUU | 동서 바람 성분 | m/s | 12 |
VVV | 남북 바람 성분 | m/s | 12 |
REH | 습도 | % | 8 |
PTY | 강수형태 | 코드 값 | 4 |
LGT | 낙뢰 | 코드 값 | 4 |
VEC | 풍향 | 0 | 10 |
WSD | 풍속 | 1 | 10 |
Table. 하늘(SKY) 상태 코드 값
코드 | 맑음 | 구름조금 | 구름많음 | 흐림 |
---|---|---|---|---|
SKY | 1 | 2 | 3 | 4 |
Table. 강수형태 (PTY) 상태 코드 값
코드 | 없음 | 비 | 진눈개비 | 눈 |
---|---|---|---|---|
PTY | 1 | 2 | 3 | 4 |
Table. 강수량 (RN1, R06) 범주 및 표시 방법 (값)
범주 | 문자열 표시 | GRIB 저장 값 |
---|---|---|
0.1mm 미만 | 0mm 또는 없음 | 0 |
0.1mm 이상 1mm 미만 | 1mm 미만 | 1 |
1mm 이상 5mm 미만 | 14mm | 5 |
5mm 이상 10mm 미만 | 59mm | 10 |
10mm 이상 20mm 미만 | 1019mm | 20 |
20mm 이상 40mm 미만 | 2039mm | 40 |
40mm 이상 70mm 미만 | 4069mm | 70 |
70mm 이상 | 70mm 이상 | 100 |
Table. 적설 (S06) 범주 및 표시방법 (값)
범주 | 문자열 표시 | GRIB 저장 값 |
---|---|---|
0.1cm 미만 | 0cm 또는 없음 | 0 |
0.1cm 이상 1cm 미만 | 1cm 미만 | 1 |
1cm 이상 5cm 미만 | 14cm | 5 |
5cm 이상 10cm 미만 | 59cm | 10 |
10cm 이상 20cm 미만 | 1019cm | 20 |
20cm 이상 | 20cm 이상 | 100 |
Table. 낙뢰코드 (LGT) 정보
코드 | 없음 | 있음 |
---|---|---|
LGT | 0 | 1 |
Table. 풍속 정보
코드 | + | - |
---|---|---|
UUU | 동 | 서 |
VVV | 북 | 남 |
getAir
Air 는 지정한 주소 (구) 위치의 공기 질을 반환하는 API 이며 공공데이터 포털에서 제공하는 대기오염정보조회서비스를 이용하여 구현하고 있다. API 를 호출하기 위한 인증 키도 해당 사이트에서 신청 가능 하며 신청 후 얻은 인증 키는 HSP 의 Operation 서버에 등록하여 관리할 수 있다.
다수 개의 인증 키를 입력 시에는 사용하고 있는 인증키가 하루에 요청할 수 있는 제한을 초과 하였을 때 다음 인증 키를 사용하여 재 호출 하도록 설계되었다.
Air 요청 시 필요한 인자는 아래와 같으며 인자에 대한 세부 내용은 관련 웹 페이지인 대기오염정보조회서비스 에서 확인할 수 있다.
Table. getAir 인자 정보
No | Name | Descriptions |
---|---|---|
1 | keyword | 주소 (구 정보) |
2 | pageNo | 현재 페이지 번호 |
3 | perPage | 페이지당 출력할 결과 수 |
Example
val page: String
val perPage: String
// 3.10.18 이상
DAPOpenApi.air(activity, keyword, page, perPage, {
// TODO
}) {
// TODO
}
// 3.10.18 이하
DAPOpenApi.air(keyword, page, perPage) { result, value ->
when (result) {
OnResultListener.TRUE -> {
// TODO
}
else -> {
// TODO
}
}
}
String page;
String perPage;
// 3.10.18 이상
DAPOpenApi.air(activity, keyword, page, perPage, result -> {
// TODO
}, e -> {
// TODO
});
// 3.10.18 이하
DAPOpenApi.air(keyword, page, perPage, (result, value) -> {
switch (result) {
case OnResultListener.TRUE:
// TODO
break;
default:
// TODO
break;
}
});
Result
<header>
<resultCode>00</resultCode>
<resultMsg>NORMAL SERVICE.</resultMsg>
</header>
<body>
<items>
<item>
<dataTime>2018-09-21 14:00</dataTime>
<mangName>도시대기</mangName> <so2Value>0.002</so2Value>
<coValue>0.2</coValue>
<o3Value>0.025</o3Value>
<no2Value>0.021</no2Value>
<pm10Value>16</pm10Value>
<pm10Value24>11</pm10Value24>
<pm25Value>9</pm25Value>
<pm25Value24>7</pm25Value24>
<khaiValue>42</khaiValue>
<khaiGrade>1</khaiGrade>
<so2Grade>1</so2Grade>
<coGrade>1</coGrade>
<o3Grade>1</o3Grade>
<no2Grade>1</no2Grade>
<pm10Grade>1</pm10Grade>
<pm25Grade>1</pm25Grade>
<pm10Grade1h>1</pm10Grade1h>
<pm25Grade1h>1</pm25Grade1h>
</item>
<!-- 중략 -->
</items>
</body>
</response>
Table. Air 결과 정보
Code | Message | Descriptions |
---|---|---|
00 | 성공 | |
01 | Application Error | 제공기관 서비스 제공 상태가 원활하지 않습니다. |
02 | DB Error | 제공기관 서비스 제공 상태가 원활하지 않습니다. |
03 | No Data | 데이터 없음 오류 |
04 | HTTP Error | 제공기관 서비스 제공 상태가 원활하지 않습니다. |
05 | Service Timeout | 제공기관 서비스 제공 상태가 원활하지 않습니다. |
10 | Invalid Parameter Error | Open API 요청 시 Service Key 파라 미터가 누락되었습니다. |
11 | 필수 요청 파라 미터가 없음 | 요청 하신 Open API 의 필수 파라 미터가 누락되었습니다. |
12 | 해당 오픈 API 서비스가 없거나 폐기됨 | Open API 호출 시 URL 이 잘못 됨 |
20 | 서비스 접근 오류 | 활용승인이 나지 않은 Open API 호출 |
22 | 서비스 요청 제한 횟수 초과 에러 | 일일 활용 건수가 초과 함 (활용건수 증가 필요) |
30 | 등록되지 않은 서비스 키 | 잘못된 서비스 키를 사용하였거나 서비스 키를 URL 인 코딩 하지 않음 |
31 | 기한 만료된 서비스 키 | Open API 사용 기간이 만료됨 |
32 | 등록되지 않은 도메인 명 또는 IP 주소 | 활용 신청한 서버의 IP 와 실제 Open API 호출한 서버가 다름 |
Table. 아이템 항목 설명
항목(영문) | 항목(국문) | 크기 | 구분 | 샘플 | 설명 |
---|---|---|---|---|---|
dataTime | 측정일 | 20 | 1 | 2018-04- 20 15:00 | 오염도 측정일 |
mangName | 측정망 정보 | 10 | 1 | 도시대기 | 측정망 정보 (국가배경, 교외대기, 도시대기, 도로변 대기) |
so2Value | 아황산가스 농도 | 10 | 1 | 0.007 | 아황산가스 농도 (단위 : ppm) |
coValue | 일산화탄소 농도 | 10 | 1 | 0.4 | 일산화탄소 농도 (단위 : ppm) |
o3Value | 오존 농도 | 10 | 1 | 0.043 | 오존 농도 (단위 : ppm) |
no2Value | 이산화질소 농도 | 10 | 1 | 0.024 | 이산화질소 농도 (단위 : ppm) |
pm10Value | 미세먼지 (PM10) 농도 | 10 | 1 | 73 | 미세먼지 (PM10) 농도 (단위 : μg/m³ |
pm10Value24 | 미세먼지 (PM10) 24 시간 예측 이동 농도 | 10 | 1 | 55 | 미세먼지 (PM10) 24 시간 예측 이동 농도 (단위 : μg/m³ |
pm25Value | 미세먼지 (PM2.5) 농도 | 10 | 1 | 73 | 미세먼지 (PM2.5) 농도 (단위 : μg/m³ |
pm25Value24 | 미세먼지 (PM2.5) 24 시간 예측 이동 농도 | 10 | 1 | 31 | 미세먼지 (PM2.5) 24 시간 예측 이동 농도 (단위 : μg/m³ |
khaiValue | 통합 대기 환경 수치 | 10 | 1 | 75 | 통합 대기 환경수치 |
khaiGrade | 통합 대기 환경 지수 | 10 | 1 | 2 | 통합 대기 환경 지수 |
so2Grade | 아황산가스 지수 | 10 | 1 | 1 | 아황산가스 지수 |
coGrade | 일산화탄소 지수 | 10 | 1 | 1 | 일산화탄소 지수 |
o3Grade | 오존 지수 | 10 | 1 | 2 | 오존 지수 |
no2Grade | 이산화질소 지수 | 10 | 1 | 1 | 이산화질소 지수 |
pm10Grade | 미세먼지 (PM10) 24 시간 등급 | 10 | 1 | 2 | 미세먼지 (PM10) 24 시간 등급자료 |
pm25Grade | 미세먼지 (PM2.5) 24 시간 등급 | 10 | 1 | 2 | 미세먼지 (PM2.5) 24 시간 등급자료 |
pm10Grade1h | 미세먼지 (PM10) 1 시간 등급 | 10 | 1 | 2 | 미세먼지 (PM10) 1 시간 등급자료 |
pm25Grade1h | 미세먼지 (PM2.5) 1 시간 등급 | 10 | 1 | 2 | 미세먼지 (PM2.5) 1 시간 등급자료 |
Table. 항목별 Grade 값의 의미
등급 | 좋음 | 보통 | 나쁨 | 매우 나쁨 |
---|---|---|---|---|
Grade | 1 | 2 | 3 | 4 |
getSearch
Search 는 지정된 검색 어를 통해 네이버 / 다음 / 구글의 검색엔진을 통해 검색 결과를 화면에 보여주는 API 이며 search 에 필요한 인자는 아래와 같다.
No | Name | Descriptions |
---|---|---|
1 | keyword | 검색어 |
2 | from | 검색 엔진 (google, naver, daum) |
3 | windowName | 검색 결과를 출력할 Web 형태의 윈도우 또는 팝업 윈도우 명 |
인자가 전달되면 대상이 되는 웹 윈도우에 검색엔진의 결과를 화면에 출력하여 화면에 표현된다.
Example
DAPOpenApi.search(activity, "안드로이드", "google", "defaultWebPopupWindow", {
// TODO
}) {
// TODO
}
// 3.10.18 이하
DAPOpenApi.search("안드로이드", "google", "defaultWebPopupWindow")
DAPOpenApi.search(activity, "안드로이드", "google", "defaultWebPopupWindow", result -> {
// TODO
}, e -> {
// TODO
});
// 3.10.18 이하
DAPOpenApi.search("안드로이드", "google", "defaultWebPopupWindow");