다음 등의 포털 사에서는 자사 데이터 일부를 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 14399
공지 [UX Summit 요약] 오른쪽 클릭은 옳다 (Right Click is Right) 관리자 2020.11.16 13034
공지 [10.4 시드니] What's NEW! 신기능 자세히 보기 관리자 2020.05.27 15542
공지 RAD스튜디오(델파이,C++빌더) - 고객 사례 목록 관리자 2018.10.23 21075
공지 [데브기어 컨설팅] 모바일 앱 & 업그레이드 마이그레이션 [1] 관리자 2017.02.06 22305
공지 [전체 목록] 이 달의 기술자료 & 기술레터 관리자 2017.02.06 17950
공지 RAD스튜디오(델파이, C++빌더) - 시작하기 [1] 관리자 2015.06.30 38238
공지 RAD스튜디오(델파이,C++빌더) - 모바일 앱 개발 사례 (2020년 11월 업데이트 됨) 험프리 2014.01.16 173751
574 이 달의 기술자료 - 2020년 03월 file 험프리 2020.02.28 271
573 [업데이트][패치][10.3.3] Midas와 델파이 Open Array 패치 험프리 2020.02.28 254
572 내장된 암호화 해시 라이브러리를 사용할 수 있습니다. - System.Hash file 험프리 2020.02.27 477
571 새로운 FMX 멀티-디바이스 테마 - Material Patterns Blue 관리자 2020.02.25 390
570 새로운 VCL 윈도우 테마 - Material Patterns Blue 관리자 2020.02.25 393
569 안드로이드 앱의 난독화 - 파이어몽키로 작성한 네이티브 앱은 디컴파일할 수 없어 보안에 강력합니다. 험프리 2020.02.24 430
568 [고객사례-유틸리티, 델파이] IcoFX 관리자 2020.02.20 287
567 [고객사례-유틸리티, 델파이] ExBox 관리자 2020.02.19 372
566 새로운 FMX 테마 - 우분투(Ubuntu) Clear Fantasy 스타일 관리자 2020.02.19 407
565 새로운 VCL 윈도우 테마 - Lucky Point 관리자 2020.02.18 386
564 [고객사례-유틸리티, 델파이] TreeSize - 하드 디스크 공간 관리 프로그램 관리자 2020.02.18 543
563 [고객사례-모바일 앱, 델파이] CAW+ 키보드 - 중/일, 한자 입력 및 번역 앱 file 관리자 2020.02.17 407
562 새로운 VCL 윈도우 테마 - Zircon 관리자 2020.02.14 406
561 개발을 할 때 조심해야 하는 포인트 '도구의 법칙과 개발자의 저주' 관리자 2020.02.13 411
560 도커(Docker) 제대로 활용하기 험프리 2020.02.07 555
559 3회차 "커뮤니케이션 데이 - 마이그레이션" 회고 험프리 2020.02.05 190
558 [고객사례-유틸리티, 델파이] SyncBackPro - 데이터 백업/동기화 솔루션 관리자 2020.02.04 345
557 Delphi / C ++ Builder를 사용하여 Azure에서 MSSQL 데이터베이스 만들기 및 연결 험프리 2020.02.03 213
556 이 달의 기술자료 - 2020년 02월 험프리 2020.01.31 258
555 [고객사례-유틸리티, 델파이] ALLMediaServer - 미디어 컨텐츠 플레이 프로그램 관리자 2020.01.31 273