키움증권 REST API 접근토큰 발급 > PHP
PHP

키움증권 REST API 접근토큰 발급

조회 4,034회 댓글 0건
  • 현재 페이지 주소 복사
  • 페이스북으로 공유
  • X 로  공유
  • 트위터로  공유
  • 네이버 블로그로 공유
  • 네이버 카페 공유하기
  • 네이버 라인 공유하기
  • 네이버 밴드 공유하기
  • 링크드인으로 공유하기
  • 핀터레스트에 공유하기

아래 프로그램 실행전에 앱키와 시크릿키는 API키 발급 받는곳에서 먼저 받아 놓아야 합니다.


키움증권 REST API 사용신청 하는곳

API 사용신청 | 키움 REST API



 

REST는 특성성 프로그램 언어와 관계 없습니다. 예제에서 파이선 자바스크립트 이렇게 있고 PHP 없다고 하여 안되는것이 아닙니다.

물론 인터넷(네트워크) 지원 안되는 언어는 안됩니다.


그렇기 때문에 리눅스 쉘에서 쉽게 테스트 할 수 있는 아래도 당연히 됩니다.

curl -X POST -H "Content-Type: application/json;charset=UTF-8" -d '{"grant_type":"client_credentials","appkey":"AxserEsdcredca.....","secretkey":"SEefdcwcforehDre2fdvc...."}' -v -w "\nHTTP Code: %{http_code}\n" https://api.kiwoom.com/oauth2/token



<?php

// 접근토큰 발급
function fn_au10001($data) {

    // $host = 'https://mockapi.kiwoom.com'; // 모의투자
    $host     = 'https://api.kiwoom.com'; // 실전투자
    $endpoint = '/oauth2/token';
    $url      = $host . $endpoint;

    $headers = [
        'Content-Type: application/json;charset=UTF-8' // 컨텐츠타입
    ];

    $ch = curl_init();
    curl_setopt($ch, CURLOPT_URL, $url);
    curl_setopt($ch, CURLOPT_POST, true);
    curl_setopt($ch, CURLOPT_POSTFIELDS, json_encode($data));
    curl_setopt($ch, CURLOPT_HTTPHEADER, $headers);
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
    curl_setopt($ch, CURLOPT_HEADER, true);
    curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);

    $response        = curl_exec($ch);
    $httpCode        = curl_getinfo($ch, CURLINFO_HTTP_CODE);
    $headerSize      = curl_getinfo($ch, CURLINFO_HEADER_SIZE);

    $responseHeaders = substr($response, 0, $headerSize);
    $responseBody    = substr($response, $headerSize);
    curl_close($ch);

    $headerArray = [];
    $headerLines = explode("\r\n", $responseHeaders);
    foreach ($headerLines as $line) {
        if (strpos($line, 'next-key:') === 0) {
            $headerArray['next-key'] = trim(substr($line, 9));
        } elseif (strpos($line, 'cont-yn:') === 0) {
            $headerArray['cont-yn'] = trim(substr($line, 8));
        } elseif (strpos($line, 'api-id:') === 0) {
            $headerArray['api-id'] = trim(substr($line, 7));
        }
    }

$aAuth2Token = json_decode($responseBody, true);

    echo 'Code: ' . $httpCode . "\n";
    echo 'Header: ' . json_encode($headerArray, JSON_PRETTY_PRINT | JSON_UNESCAPED_UNICODE) . "\n";
    echo 'Body: ' . json_encode(json_decode($responseBody), JSON_PRETTY_PRINT | JSON_UNESCAPED_UNICODE) . "\n";
    // echo $response . PHP_EOL;
    // echo "--------------------------------" . PHP_EOL;
    // echo "httpCode: $httpCode            headerSize: $headerSize " . PHP_EOL;
    // print_r($data);
    // echo "--------------------------------" . PHP_EOL;
return $aAuth2Token;
}



$aParams = [
    'grant_type' => 'client_credentials',  // grant_type
    'appkey'     => '앱키',
    'secretkey'  => '시크릿키',
];

fn_au10001($aParams);
 


위와 같이 변경해서 사용하면 되며 위는 테스트 하기 위해서 만들어진 것으로 실제 사용은 공통되는 부분은 함수로 만들어 사용하면 됩니다.


처음에 curl 실행시 아무것도 나오지 않았는데 아래 부분을 넣어주지 않아서 그랬습니다.

curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); 


● 종목의 시세를 조회하는 것은 아래를 참고하세요.

   - 키움증권 REST API 시세조회 > 시분요청 > PHP

   - 키움증권 REST API 실시간시세조회 및 조건검색 

   - 키움증권 REST API 주식주문하기
 

  • 현재 페이지 주소 복사
  • 페이스북으로 공유
  • X 로  공유
  • 트위터로  공유
  • 네이버 블로그로 공유
  • 네이버 카페 공유하기
  • 네이버 라인 공유하기
  • 네이버 밴드 공유하기
  • 링크드인으로 공유하기
  • 핀터레스트에 공유하기
전체 237건 1 페이지
  • profile_image PHP 설치 되어 있지 아니하여 윈도우PC에 최신버전으로 설치버전은 설치 할 때마다 다르기 때문에 본인이 사용하려는버전을 선택 하면 됩니다.     > 현대적인? 방법으로 설치함.       예전에 압축해 놓은것 풀고 path 설정하고 했던 그런 방법을 쓰지 않고 간단하게 설치가 되었다.      winget install PHP.PHP.8.5    > 아래 명령으로 설치된 위치를 찾음      where php    > php.ini-production…
  • profile_image OP캐쉬 사용하면 괜찮아 보다는 저 같은 경우는 사용하지 않아도 괜찮아를 더 좋아 합니다.▷ 솔리드 캐시(SOLID CACHE)란?솔리드 캐시는 간단히 말해 "비싼 RAM(REDIS) 대신 저렴하고 넉넉한 디스크(DB)에 캐시를 저장하는 전략"으로 원래 루비 온 레일즈(RUBY ON RAILS) 커뮤니티에서 제안된 방식이지만 본질은 어떤 언어에서든 적용 가능한 실용적인 캐싱 철학임.▷ 핵심 철학: "ssd는 생각보다 훨씬 빠르다"과거에는 디스크가 너무 느려서 무조건 데이터를 ram(REDIS MEMCACHED)에 올려야 했지만 지금은 nvme ssd 같은 초고속 저장 장치가 보편화되었습니다. 굳이 복잡하게 별도의 메모리…
  • profile_image MyISAM은 SELECT가 빠르고 InnoDB는 느리다그런 경우도 있고 아닌 경우도 있기 때문에 어떤 용도로 사용하느냐에 따라서 다를 수 있습니다.그리고 처음 데이터 넣은 다음 select만 90% 이상이고 테이블 사용이 업데이트나 인서트는 적은 경우인지 불특정 다수에게 서비스 하기 때문에 불특정한 row를 가져와서 보여줘야 하는것인지에 다를 수 있는 것입니다. 가장 큰 차이: 데이터와 인덱스 구조→ MyISAM  - 데이터 파일(.MYD) 과 인덱스 파일(.MYI) 이 분리됨  - 인덱스 → 데이터 파일을 다시 읽는 구조  - 동작흐름: PK 인덱스 탐색 (.MYI) -> 데이터 위치…
  • profile_image 데이터베이스를 사용하다 보면 이미 존재하는 데이터인지 확인한 후 INSERT 또는 UPDATE를 해야 하는 상황을 자주 만나게 됩니다.이때 매우 유용한 문법이 바로 INSERT ... ON DUPLICATE KEY UPDATE입니다.즉, 쿼리 한번으로 해결 된다는 의미 인데 아무곳에서나 사용 가능한것은 아니고 키 중복이 발생하는 부분에서만 사용 하는 것입니다.그렇기 때문에 unique의 특성을 모르시는 분은 사용 하면 안되겠지요.  장점- 쿼리 수 감소: SELECT → INSERT/UPDATE 두 번 쿼리 날릴 필요 없음- 동시성 문제 감소: SELECT 후 INSERT 방식보다 Race Condition 발…
  • profile_image 웹서버에 접근하는 X-Forwarded-For란?X-Forwarded-For(XFF)는 HTTP 헤더로 클라이언트가 프록시나 로드 밸런서를 거쳐 웹 서버에 접속할 때 원래 클라이언트의 IP 주소를 식별하기 위해 사용 됩니다.로그밸런스도 프록시서버의 변형된 형태가 있기 때문에 쉽게 프록시 서버라고 생각을 하면 쉽습니다.일반적으로 웹 서버는 직접 연결된 IP만 볼 수 있는데 프록시 뒤에 있으면 프록시 서버의 IP만 보이게 되는데 이런 경우 XFF 헤더가 실제 사용자 IP를 전달하는 역할을 합니다. ▷ 헤더 형식X-Forwarded-For: 클라이언트IP 프록시1 프록시2 ...여러 프록시를 거치면 쉼표로 구분되어 …
  • profile_image ifconfig는 초기 한번 정도만 사용하고 interface configuration의 약자로 리눅스/유닉스 시스템에서 네트워크 인터페이스를 설정하고 확인하는 명령어입니다.▷ ifconfig 주요 용도1. 네트워크 인터페이스 정보 조회  - 현재 활성화된 네트워크 인터페이스 목록 확인  - 각 인터페이스의 IP 주소, MAC 주소, 서브넷 마스크 확인  - 네트워크 통계 정보 (전송/수신 패킷 수, 에러 등) 확인2. 네트워크 인터페이스 설정  - IP 주소 할당 및 변경  - 서브넷 마스크 설정  - 브로드캐스트 주소 설정  - MTU(Maximum Tr…
  • profile_image 결론부터 말하면 느리게 다운로드 처리 하는 방식에 대한 것입니다.왜? 느리게 다운로드가 필요한가 하면 지연을 시키면 트래픽이 평탄화 되는 효과가 있는데 갑자기 순간적으로 팍 튀는 그런 현상을 없애기 위해서 필욯나 방법중 하나 입니다. 원리는 간단하며 읽은 만큼 내보내고 약간 지연 시키는 방식 입니다.    /**     * 청크 단위로 지연시키면서 파일 다운로드 (대용량 파일용)     *     * @param string $filePath 다운로드할 파일 경로     * @param …

상업적 이용 금지. 컨텐츠는 개인 용도로만 사용이 가능 합니다.