我需要模仿这个请求:
文字部分
POST /comeback_campaigns/entry HTTP/1.1
Host: ishin-global.aktsk.com
Accept: */*
X-Platform: android
X-Language: en
X-ClientVersion: 3.6.1
X-AssetVersion: 1510308536
X-DatabaseVersion: 1510542279
X-RequestVersion: 2
Content-Type: application/json
Authorization: MAC id="TVTYcxqDlO61l0yQYQnaKirWEVOPcVp2O4FCZOAb0pLrP++EEsKaqrlSho8VQRLFLV+4wvAV53DBwJyNuqUfqg==", nonce="1510773145:5a7b051af7f3e76e5b14f4e79753589f", ts="1510773145", mac="Eot1a1QPvyhecW3wNjWCW1JAENjuOjfjyxltmcguYqc="
Content-Length: 5
JSON部分
null
我在我的代码中使用请求函数
这样写了这个url='http://ishin-global.aktsk.com/comeback_campaigns/entry'
myhead={'Accept':'*/*',
'X-Platform':'android',
'X-Language':'en',
'X-ClientVersion':'3.6.1',
'X-AssetVersion':'1510308536',
'X-DatabaseVersion':'1510542279',
'X-RequestVersion':'2',
'Content-Type':'application/json',
'Authorization':'MAC id='+mac_key +', nonce='+TS+':'+nonce+', ts='+ TS + ', mac='+mac_gen,
'Content-Length':'5'
}
payload='null'
r=requests.post(url, headers=myhead, json=payload)
这是正确的方法吗?我是否必须像request.post(url, auth, header)
一样发送身份验证部分?在使用之前,我是否必须将图像中的访问令牌转换为OAuth2内容?
现在我得到一个错误说
oauth2_mac_rails / access_token_required
访问令牌是授权后的MAC ID。
答案 0 :(得分:0)
在"
键的各个部分周围添加引号(Authorization
):
'Authorization': 'MAC id="' + mac_key + '", nonce="' + TS + ':' + nonce + '", ts="' + TS + '", mac="' + mac_gen + '"'
您当前正在发送一个没有中间引号的长字符串:
'Authorization': 'MAC id=TVTxxx, nonce=151xxx:5a7xxx, ts=151xxx, mac=Eotxxx'
,而您的参考POST看起来像:
'Authorization': 'MAC id="TVTxxx", nonce="151xxx:5a7xxx", ts="151xxx", mac="Eot..."'