Как закодировать вывод дайджеста с помощью base64 в python на GDAX

Я пытаюсь использовать API на бирже GDAX. На своем сайте они дают такой код:

# Requires python-requests. Install with pip:
#
#   pip install requests
#
# or, with easy-install:
#
#   easy_install requests

import json, hmac, hashlib, time, requests, base64
from requests.auth import AuthBase

# Create custom authentication for Exchange
class CoinbaseExchangeAuth(AuthBase):
def __init__(self, api_key, secret_key, passphrase):
    self.api_key = api_key
    self.secret_key = secret_key
    self.passphrase = passphrase

def __call__(self, request):
    timestamp = str(time.time())
    message = timestamp + request.method + request.path_url + (request.body or '')
    hmac_key = base64.b64decode(self.secret_key)
    signature = hmac.new(hmac_key, message, hashlib.sha256)
    signature_b64 = signature.digest().encode('base64').rstrip('\n')

    request.headers.update({
        'CB-ACCESS-SIGN': signature_b64,
        'CB-ACCESS-TIMESTAMP': timestamp,
        'CB-ACCESS-KEY': self.api_key,
        'CB-ACCESS-PASSPHRASE': self.passphrase,
        'Content-Type': 'application/json'
    })
    return request

api_url = 'https://api.gdax.com/'
auth = CoinbaseExchangeAuth(API_KEY, API_SECRET, API_PASS)

# Get accounts
r = requests.get(api_url + 'accounts', auth=auth)
print r.json()


# Place an order
order = {
'size': 1.0,
'price': 1.0,
'side': 'buy',
'product_id': 'BTC-USD',
}
r = requests.post(api_url + 'orders', json=order, auth=auth)
print r.json()

Они также говорят: «Не забудьте сначала декодировать с помощью base64 буквенно-цифровую секретную строку (в результате чего получается 64 байта), прежде чем использовать ее в качестве ключа для HMAC. Кроме того, кодируйте с помощью base64 выходные данные дайджеста перед отправкой заголовка».

Я считаю, что исправил первую часть с помощью:

API_SECRET = base64.b64decode(b'{secret}')

Однако я не понимаю, что означает вторая часть. Я получаю сообщение об ошибке:

TypeError: Unicode-objects must be encoded before hashing

person Chad Skiles    schedule 04.12.2017    source источник


Ответы (2)


у меня была такая же проблема, это поможет:

def __call__(self, request):
    timestamp = str(time.time())
    message = timestamp + request.method + request.path_url + (request.body or '')

    message = bytes(message, 'utf-8')
    secret = bytes(self.secret_key, 'utf-8')
    signature = base64.b64encode(hmac.new(secret, message, digestmod=hashlib.sha256).digest())

    request.headers.update({
        'CB-ACCESS-SIGN': signature,
        'CB-ACCESS-TIMESTAMP': timestamp,
        'CB-ACCESS-KEY': self.api_key,
        'CB-ACCESS-PASSPHRASE': self.passphrase,
        'Content-Type': 'application/json'
    })
    return request
person user11704909    schedule 26.06.2019

Я использовал тот же код, что и пользователь выше, у которого была такая же проблема, и он не совсем работал, но был близок к этому. Все, что мне оставалось, это после получения секрета = байты (...) мне все еще нужно было секрет = base64.b64decode (секрет)

добавление этой строки перед подписью исправило это для меня

person Andrew Fish    schedule 08.12.2020