Crossbar.io : вызывающая сторона HTTP Bridge Services : правильная отправка подписанных запросов

Я использую вызывающую службу HTTP-моста crossbar для использования зарегистрированного RPC. Но когда я выдаю сообщение HTTP POST, я получаю в качестве ответа «неверную подпись запроса».

Согласно http://crossbar.io/docs/HTTP-Bridge-Services-Caller/,

Подпись, рассчитанная как кодировка Base64 следующего значения: HMAC[SHA256]_{secret} (key | timestamp | seq | nonce | body)

Как правильно сделать конкатенацию? Пробовал и с персонажем и без | и пространства.

раздел файла crossbar config.json для подписанных запросов:

        "call-signed": {
          "type": "caller",
          "realm": "realm1",
          "role": "anonymous",
          "options": {
            "key": "foobar",
            "secret": "secret",
            "post_body_limit": 0,
            "timestamp_delta_limit": 0,
            "require_ip": [
              "127.0.0.1"
            ],
            "require_tls": false,
            "debug": true
          }
        }

код python для отправки запросов:

import hmac
import hashlib
import base64
import requests
import json

key = "foobar"
timestamp = "2011-10-14T16:59:51.123Z"
seq = "0"
nonce = "22"

# construct body
args = [1, 3, 2]
kwargs = None
options = None

proc = 'com.myapp.func'
payload = {"procedure": proc}

if args:
    payload['args'] = list(args)

if kwargs:
    payload['kwargs'] = dict(kwargs)

body = payload
body = json.dumps(body)

# construct signature
# (key | timestamp | seq | nonce | body)
message = key + "" + timestamp + "" + seq + "" + nonce + "" + body

print message

secret = "secret"

signature = base64.b64encode(hmac.new(secret, msg=message, digestmod=hashlib.sha256).digest())

print signature

# HTTP POST

url = "http://127.0.0.1:8080/call-signed?" + \
      "seq=" + seq + \
      "&key=" + key + \
      "&nonce=" + nonce + \
      "&signature=" + signature + \
      "&timestamp=" + timestamp

headers = {'content-type': 'application/json'}

s = requests.Session()
r = s.post(url, data=body, headers=headers)

print r.text

person 911    schedule 29.10.2015    source источник
comment
будущие посетители этого вопроса о стеке должны посетить crossbar.io/docs/HTTP-Bridge вместо размещенный URL-адрес, который больше не действителен   -  person FirefighterBlu3    schedule 10.03.2017


Ответы (1)


я использую CrossbarHTTP https://github.com/thehq/python-crossbarhttp для обработки HTTP моста, но если вы настаиваете на использовании собственного кода, вы можете проверить метод _compute_signature() в этом https://github.com/thehq/python-crossbarhttp/blob/master/crossbarhttp/crossbarhttp.py., это может вам помочь.

person Klanjabrik    schedule 08.12.2015