알짜게시판

[PHP] 네이버 검색광고 키워드 도구 API 검색

이 코드는 네이버 검색광고에서 제공하는 키워드 도구 API를 호출하여
특정 키워드와 연관된 검색 키워드 데이터를 조회하는 역할을 한다.

API 인증 절차부터 요청 생성, 응답 처리까지의 전 과정을 하나의 함수로 캡슐화하여
외부에서는 키워드 문자열만 전달하면 결과를 받을 수 있도록 구성되어 있다.


API 인증 정보 설정

상단에는 네이버 검색광고 API 호출에 필요한 인증 정보가 상수로 정의되어 있다.

  • ACCESS_LICENSE
  • SECRET_KEY
  • CUSTOMER_ID

이 값들은 네이버 검색광고 관리자 센터에서 발급받는 정보이며,
요청 시 HTTP 헤더에 포함되어 API 사용 권한을 검증하는 데 사용된다.

코드 내에서 상수로 분리함으로써
인증 정보 변경 시 유지보수가 용이하도록 설계되어 있다.


키워드 조회 함수 구조

fetchKeyword 함수는 키워드 도구 API 호출을 담당하는 핵심 로직이다.

입력값으로 하나 이상의 키워드를 문자열 형태로 전달받아
해당 키워드를 기반으로 한 연관 키워드 목록을 반환한다.

함수의 반환값은 배열 형태이며,
API 응답이 정상적이지 않은 경우 빈 배열을 반환하도록 처리되어 있다.


타임스탬프 및 서명 생성

API 요청 시 보안을 위해 타임스탬프와 서명이 필요하다.

타임스탬프는 밀리초 단위의 현재 시간으로 생성되며,
요청 시점의 유효성을 검증하는 용도로 사용된다.

서명은 다음 요소를 결합하여 생성된다.

  • 타임스탬프
  • HTTP 메서드
  • 요청 경로

이 값을 SECRET_KEY를 이용해 HMAC-SHA256 방식으로 해시한 뒤
Base64로 인코딩하여 최종 서명을 만든다.

이 서명은 요청이 위변조되지 않았음을 증명하는 역할을 한다.


API 요청 구성

cURL을 사용하여 HTTP GET 요청을 생성한다.

요청 URL에는 다음 정보가 포함된다.

  • hintKeywords
  • showDetail 옵션

hintKeywords는 조회 대상 키워드이며
URL 인코딩을 통해 안전하게 전달된다.

HTTP 헤더에는 앞서 생성한 인증 정보가 포함된다.

  • X-Timestamp
  • X-API-KEY
  • X-CUSTOMER
  • X-Signature

이를 통해 네이버 서버는 요청자의 신원을 확인하고
요청의 유효성을 검증한다.


응답 처리 방식

API 호출 결과는 JSON 문자열 형태로 반환된다.

이를 배열로 디코딩한 뒤
keywordList 항목만 추출하여 반환한다.

만약 응답에 해당 항목이 존재하지 않을 경우
null 병합 연산자를 통해 빈 배열을 반환하도록 처리되어 있다.

// 네이버 키워드 도구 API 설정
define('ACCESS_LICENSE', '');
define('SECRET_KEY', '');
define('CUSTOMER_ID', '');

// 키워드 검색 함수
function fetchKeyword($keywords) {
    $timestamp = (string) round(microtime(true) * 1000);
    $signature = base64_encode(hash_hmac('sha256', $timestamp.'.GET./keywordstool', SECRET_KEY, true));

    $ch = curl_init();
    curl_setopt($ch, CURLOPT_URL, 'https://api.searchad.naver.com/keywordstool?hintKeywords='.urlencode($keywords).'&showDetail=1');
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
    curl_setopt($ch, CURLOPT_HTTPHEADER, [
        'X-Timestamp: '.$timestamp,
        'X-API-KEY: '.ACCESS_LICENSE,
        'X-CUSTOMER: '.CUSTOMER_ID,
        'X-Signature: '.$signature
    ]);
    $data = json_decode(curl_exec($ch), true);
    curl_close($ch);

    return $data['keywordList'] ?? [];
}

로그인 후 댓글내용을 입력해주세요

제목 글쓴이 조회 날짜
[PHP] 네이버 검색 Open API 9 1시간 전
[PHP] 네이버 검색광고 키워드 도구 API 검색 11 2시간 전
[MYSQL] MariaDB column_stats 테이블 오류 해결 방법 409 25-12-06
[PHP] PHP-FPM 에러 로그 실시간 모니터링 406 25-12-03
[윈도우] 윈도우11 업데이트 후 네트워크 드라이브 접근 불가 문제 해결 방법 788 25-11-24
[PHP] 다국어 번역 함수 구현 방법 2,841 25-11-08
[워드프레스] "치명적인 오류가 발생했습니다" 디버깅 가이드 13,684 25-10-31
[리눅스] Apache 웹 로그 분석하기 – awk와 GoAccess 활용 18,217 25-10-28
[칼무리] 외부 명령으로 캡처 자동화하기 1 39,730 25-10-14
[윈도우] 윈도11 강제업데이트 피하고 윈도10 계속 쓰기 41,409 25-10-12
[리눅스] PHP 파일 업로드 용량 늘리기 56,312 25-10-03
[HTML] 애드센스 충돌 문제 해결하기 74,317 25-09-20
[파이썬] Python Playwright로 Edge 브라우저 제어하기 76,310 25-09-12
[델파이] TDirectory.Delete 대신 CMD 으로 폴더 삭제 74,719 25-09-10
[윈도우] Chrome 및 Edge를 TLS 1.2 모드로 실행 73,989 25-08-30
[HTML] 애드센스 자동 광고 사용 시 빈 화면이 출력된다면? 158,924 25-06-20
[윈도우] 브라우저 환경설정 추출 145,477 25-06-18
[워드프레스] xmlrpc.php 차단으로 보안 강화하기 136,714 25-06-05
[델파이] 폼이 모니터 한 가운데 있는 경우 자연스럽게 왼쪽으로 이동시키기 134,260 25-05-26
[윈도우] WSH script registration is not valid. 134,437 25-05-23
[워드프레스] 제목 블록 기본값을 H5로 변경하는 방법 115,782 25-05-22
[파이썬] 동영상 특정 영역 모자이크(흐리게) 하기 47,490 25-04-30
[리눅스] 구글 크롬 콘솔 'Attestation check for Topics on' 에러 원인 & 해결방… 60,646 25-04-11
[크롬] 개발자 도구(DevTools)에서 붙여넣기 안될때 73,093 25-03-10
[그누보드] SmartEditor2Skin.html 다운로드 되는 현상 110,719 25-01-08
[윈도우] 네트워크 탐지 115,242 24-12-31
[델파이] TrayIcon 이 흐릿하게 보이는 버그? 수정 128,688 24-12-12
[델파이] 실행 중인 프로세스가 활성 창인지 확인하는 함수 146,004 24-11-02
[델파이] 메세지 다이어그램(Message Dialog) 에 체크박스(CheckBox) 추가 132,946 24-10-30
[그누보드] 부트스트랩 테마 예제로 사용중인 main.php 116,644 24-10-21
[그누보드] 유튜브 스킨 76,017 24-10-14
건강정보결혼의정석망치와삽강남언니야회생의길