평범한 이야기들

[PHP] PHP를 이용해 업비트(upbit) API 통신하기 #1 계좌정보 가져오기 본문

평범한 개발 이야기/PHP

[PHP] PHP를 이용해 업비트(upbit) API 통신하기 #1 계좌정보 가져오기

songsariya 2021. 3. 18. 17:40
728x90

업비트 API

국내 비트코인 거래소인 Upbit(이하 업비트)에서는 거래소에서 사용되는 기능들을 API로 제공해주고 있습니다. 그래서 해당 API를 이용해서 업비트의 거래소, 차트, 계좌정보, 거래 등을 할 수 있는 기본적인 프로그램을 만들어서 소소하게 놀아보자 라는 생각으로 해당 프로그램을 만들어 보려고 합니다. PHP로 재미 삼아 만드는 것이기 때문에 크게 신경 쓰지 않고 만들어 볼 생각입니다.

 

업비트 API 신청하기

업비트 API를 신청하려면 당연히 업비트에 아이디가 필요로 하고 계좌정보도 등록되어있어야 합니다. 그 후 마이페이지에 들어가셔서 Open Api 관리 메뉴로 들어가 Open Api Key를 발급받으시면 됩니다.

 

 

Open Api에서 특정 기능만을 설정할 수 있기 때문에 사용하실 기능만 체크한 후에 Open API Key 발급받기 버튼을 클릭하시면 됩니다. 저는 특정 IP에서만 실행도 넣었습니다. 아무래도 돈과 관련된 내용이다 보니 아이피까지 설정할 수 있는 부분이 있어서 다행이다 생각했습니다.

 

업비트 기본 계좌정보 가져오기

업비트는 REST API 요청 시, 발급받은 access key와 secret key로 토큰을 생성하여 Authorization 헤더를 통해 전송합니다. 토큰은 JWT(https://jwt.io) 형식을 따릅니다. JWT 사이트에 가시면 다양한 언어와 버전, 그리고 설치하는 방법 등 들이 나와있습니다. 가셔서 참고하셔도 됩니다.

저는 firebase/php-jwt 버전으로 설치했습니다. 설치는 컴포저로 했고 아래와 같이 명령어를 통해서 설치를 했습니다.

composer require firebase/php-jwt

 

제 기본 계좌를 가져오는 소스코드입니다.

<?php

namespace classes\upbitapi;

use Firebase\JWT\JWT;

/**
 * Upbit Api
 * Upbit 서버와 통신을 하는 메소드로 구성
 */
class UpbitApi
{
    private $accessKey;
    private $secretKey;

    public function __construct()
    {
        $this->accessKey = "";
        $this->secretKey = "";
    }

    /**
     * 계좌정보 가져오는 메서드
     *
     * @return void
     */
    public function getAccountInfo()
    {
        $url = "https://api.upbit.com/v1/accounts";

        $payload = [
            "access_key" => $this->accessKey,
            "nonce" => uniqid(),
        ];

        $token = JWT::encode($payload, $this->secretKey);

        $responseData = $this->call(array(
            "url"       => $url,
            "header"    => array(
                "Authorization: Bearer {$token}"
            )
        ));

        return $responseData;
    }

    /**
     * Upbit와 통신을 하는 메서드
     *
     * @param [type] $param
     * @return void
     */
    private function call($param)
    {

        $curl = curl_init();
        curl_setopt($curl, CURLOPT_URL,  $param["url"]);
        curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, FALSE);
        curl_setopt($curl, CURLOPT_HTTPHEADER, $param["header"]);
        curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
        $result = curl_exec($curl);
        $httpcode = curl_getinfo($curl, CURLINFO_HTTP_CODE);

        curl_close($curl);

        $returnData = json_decode($result, true);
        $httpCodeData = json_decode($httpcode, true);

        $returnData["httpCode"] = $httpCodeData;

        return $returnData;
    }
}

해당 프로그램을 실행하면 제 계좌정보가 다음과 같이 나옵니다.

내 실제 계좌정보

이렇게 간단하게 계좌정보를 조회해왔습니다. 

728x90
Comments