我正在尝试使用 API 向 Zscaler 进行身份验证。通过阅读文档并遵循以下站点中的示例
我写了以下代码:
import time
import http.client
import json
def obfuscate_api_key():
seed = 'myActualKey'
time_now = int(time.time() * 1000)
n = str(time_now)[-6:]
r = str(int(n) >> 1).zfill(6)
obf_key = ""
for i in range(0, len(str(n)), 1):
obf_key += seed[int(str(n)[i])]
for j in range(0, len(str(r)), 1):
obf_key += seed[int(str(r)[j]) + 2]
return time_now, obf_key
now, key = obfuscate_api_key()
conn = http.client.HTTPSConnection('zsapi.zscalertwo.net')
payload = {"username": "my@username.com", "password":"mypassword", "apiKey": key,
"timestamp": now}
headers = {
'content-type': "application/json",
'cache-control': "no-cache"
}
conn.request("POST", "/api/v1/authenticatedSession", json.dumps(payload), headers)
res = conn.getresponse()
data = res.read()
print(data.decode("utf-8"))
但是,我不断收到以下消息:
{"code":"AUTHENTICATION_FAILED","message":"AUTHENTICATION_FAILED"}
我的凭据是正确的,因为我使用它们在 Web GUI 中进行身份验证。因为我有一个 api 密钥,所以我有必要的特权来使用 api。主机名也是正确的,这就是我用来从浏览器登录的。我也试过 admin.zscalertwo.net 但结果是一样的。任何可能导致此问题的想法都将受到欢迎。谢谢!