다음 등의 포털 사에서는 자사 데이터 일부를 Open API로 공개하고 있습니다.

특히 지도나 주소, 검색 등은 직접 데이터를 수집하는 것보다 포털의 데이터를 활용하는 것이 개발 및 유지보수에 유리할 수 있습니다.

 

오늘은 데브기어 테크게시판을 통해 다음 카카오의 주소검색 API 연동을 문의주셔서 해당 내용을 공유합니다.

 

아래 샘플을 REST API를 이용해 카카오 주소 검색 Open API와 연동하는 내용입니다.

(카카오 Open API의 대부분은 REST API를 제공합니다. )

 

해당 내용을 잘 익히면 다양한 Open API를 여러분의 앱에서 활용하실 수 있습니다.

 

카카오 개발자 > 로컬 : https://developers.kakao.com/docs/latest/ko/local/dev-guide#address-coord

 

카카오 Open API를 연동하기 위해서는 앱을 등록하고, 앱 키를 받아야 합니다.(해당 내용의 설명은 생략합니다.)

카카오 개발자 > 내 애플리케이션 : https://developers.kakao.com/apps

 

위 링크를 참고해 개발했으며, 제일 문제가 됐던 부분은 HTTP 해더에 Authorization 값을 추가하는 부분입니다.

 

연동한 결과는 아래와 같습니다.

 

 

주요 코드는 아래와 같습니다.

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
uses
  REST.TYpes;
 
const
  API_KEY = '';
{
  https://developers.kakao.com/ 등록 > 앱 생성 > 앱키(REST API 키)를 위(API_KEY)에 입력
}
 
procedure TForm2.Button1Click(Sender: TObject);
begin
  RESTRequest1.Params.ParameterByName('query').Value := Edit1.Text;
 
  RESTRequest1.Execute;
end;
 
procedure TForm2.FormCreate(Sender: TObject);
var
  Param: TRESTRequestParameter;
begin
  RESTClient1.BaseURL := 'https://dapi.kakao.com';
  RESTClient1.Accept := 'application/json, text/plain; q=0.9, text/html;q=0.8,';
  RESTClient1.AcceptCharset := 'UTF-8, *;q=0.8';
 
  RESTRequest1.Resource := 'v2/local/search/address.json?query={query}';
  Param := RESTRequest1.Params.AddHeader('Authorization', 'KakaoAK ' + API_KEY);
  Param.Options := [TRESTRequestParameterOption.poDoNotEncode];
 
  RESTResponseDataSetAdapter1.RootElement := 'documents';
end;

참고로, Authorization 해더 파라메터의 옵션에 TRESTRequestParameterOption.poDoNotEncode를 설정하지 않으면,

값이 인코딩 되어 인증 오류가 발생합니다.

 

샘플 프로젝트

 KakaoLocalLocation.zip

 

 

문단제목

 


원글 : http://blog.hjf.pe.kr/472

번호 제목 글쓴이 날짜 조회 수
공지 [DelphiCon 요약] 코드사이트 로깅 실전 활용 기법 (Real-world CodeSite Logging Techniques) 관리자 2021.01.19 37102
공지 [UX Summit 요약] 오른쪽 클릭은 옳다 (Right Click is Right) 관리자 2020.11.16 35469
공지 [10.4 시드니] What's NEW! 신기능 자세히 보기 관리자 2020.05.27 36498
공지 RAD스튜디오(델파이,C++빌더) - 고객 사례 목록 관리자 2018.10.23 42897
공지 [데브기어 컨설팅] 모바일 앱 & 업그레이드 마이그레이션 [1] 관리자 2017.02.06 44862
공지 [전체 목록] 이 달의 기술자료 & 기술레터 관리자 2017.02.06 38673
공지 RAD스튜디오(델파이, C++빌더) - 시작하기 [1] 관리자 2015.06.30 62845
공지 RAD스튜디오(델파이,C++빌더) - 모바일 앱 개발 사례 (2020년 11월 업데이트 됨) 험프리 2014.01.16 197945
803 이전 버전 C ++ 빌더 애플리케이션을 C ++ 빌더 10 시애틀로 마이그레이션 [1] file 김원경 2017.11.24 1859
802 이 달의 기술자료 - 2017년 12월 file 험프리 2017.11.24 759
801 수원과학대 학생이 델파이로 개발한 '축구 리그 앱' 관리자 2017.11.24 2966
800 [발표자료] 20171117 델파이/C++빌더 제조/제어 개발 세미나 관리자 2017.11.20 459
799 [발표자료] 20171116 델파이/C++빌더 의료 개발 세미나 관리자 2017.11.17 416
798 [발표자료] 20171109 RAD스튜디오 100% 활용하기: 최신 기술 적용과 확장 관리자 2017.11.10 525
797 RAD 스튜디오 - 사물인터넷 관련기술과 고객사례 험프리 2017.10.31 1880
796 [고객사례-설치도구, 델파이] RAD&Installer 관리자 2017.10.31 677
795 이 달의 기술자료 - 2017년 11월 file 험프리 2017.10.30 636
794 안면인식(Face Detection) 라이브러리(안드로이드, iOS) 험프리 2017.10.30 2625
793 TTS(Text-to-Speech) 라이브러리(윈도우, 맥OS, iOS, 안드로이드) [2] 험프리 2017.10.30 1662
792 델파이로 빅데이터 데이터베이스 연동하기(Cassandra, Couchbase, MongoDB) 험프리 2017.10.30 1295
791 [고객사례-생산성도구, 델파이] Change-Pro for Excel - 엑셀 변경항목 분석 프로그램 관리자 2017.10.27 805
790 RAD스튜디오 로드맵 - 2017년 9월 관리자 2017.10.23 682
789 [따라하기] 인공지능 오목게임(7) - 오목게임 승자(5돌) 결정 지능프로그램 file 대화마을 2017.10.17 1782
788 [따라하기] 인공지능 오목게임(6) - 흑백 바둑알 놓고 위치저장 file 대화마을 2017.10.01 1206
787 엔터프라이즈 커넥터로 '구글 드라이브 VCL 애플리케이션' 만들기 file 관리자 2017.09.29 1634
786 이 달의 기술자료 - 2017년 10월 file 험프리 2017.09.26 697
785 [따라하기] 인공지능 오목게임(5) - 바둑알 놓기 [2] file 대화마을 2017.09.22 1107
784 [FMX] TListView 더보기 버튼 구현하기 험프리 2017.09.20 1165