알짜게시판

[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 86 26-02-10
[PHP] 네이버 검색광고 키워드 도구 API 검색 91 26-02-10
[MYSQL] MariaDB column_stats 테이블 오류 해결 방법 429 25-12-06
[PHP] PHP-FPM 에러 로그 실시간 모니터링 431 25-12-03
[윈도우] 윈도우11 업데이트 후 네트워크 드라이브 접근 불가 문제 해결 방법 865 25-11-24
[PHP] 다국어 번역 함수 구현 방법 2,863 25-11-08
[워드프레스] "치명적인 오류가 발생했습니다" 디버깅 가이드 13,701 25-10-31
[리눅스] Apache 웹 로그 분석하기 – awk와 GoAccess 활용 18,236 25-10-28
[윈도우] 윈도11 강제업데이트 피하고 윈도10 계속 쓰기 41,426 25-10-12
[리눅스] PHP 파일 업로드 용량 늘리기 56,330 25-10-03
[HTML] 애드센스 충돌 문제 해결하기 74,329 25-09-20
[파이썬] Python Playwright로 Edge 브라우저 제어하기 76,336 25-09-12
[델파이] TDirectory.Delete 대신 CMD 으로 폴더 삭제 74,732 25-09-10
[HTML] 애드센스 자동 광고 사용 시 빈 화면이 출력된다면? 158,938 25-06-20
[워드프레스] xmlrpc.php 차단으로 보안 강화하기 136,727 25-06-05
[델파이] 폼이 모니터 한 가운데 있는 경우 자연스럽게 왼쪽으로 이동시키기 134,276 25-05-26
[윈도우] WSH script registration is not valid. 134,455 25-05-23
[워드프레스] 제목 블록 기본값을 H5로 변경하는 방법 115,801 25-05-22
[파이썬] 동영상 특정 영역 모자이크(흐리게) 하기 47,505 25-04-30
[리눅스] 구글 크롬 콘솔 'Attestation check for Topics on' 에러 원인 & 해결방… 60,661 25-04-11
[크롬] 개발자 도구(DevTools)에서 붙여넣기 안될때 73,121 25-03-10
[그누보드] SmartEditor2Skin.html 다운로드 되는 현상 110,737 25-01-08
[PHP] 검색 로봇 접속시 종료 56,996 24-10-07
[리눅스] PHP-FPM 튜닝을 위한 메모리 계산 42,022 24-08-29
[윈도우] 아이폰 벨소리 쉽게 추가하기 94,934 24-06-14
[윈도우] C:\Windows\Installer 폴더 다른 드라이브로 옮기기 105,831 24-05-29
[PHP] REQUEST 값 받기(application/json 포함) 99,846 24-04-20
[리눅스] 데몬(systemd service) 작성 및 실행하기 66,699 24-03-14
[MySQL] 업데이트 이후 에러 발생([ERROR] Incorrect definition of table … 92,298 23-12-08
구글 크롬 탭검색 비활성화 73,165 23-12-04
[MySQL] MySQL, MariaDB 업데이트 74,098 23-11-24
목록
심리톡톡회생의길보안IT지원금백과개봉닷컴