1、獲取token,或者session(如不需要可忽略)
login_url = "http://xxxx/api/auth/login" login_data = {"username":"test3","password":"123456"} login_res = requests.post(url=login_url,data = login_data) token = login_res.json()["data"]["token"]
2、獲取下載路徑(如果請求后直接返回文件內容,可直接進行第三步)
batch_url = "http://xxxx/api/models/batch" batch_data = {"ids":"[4]","version_number":"[309]"} headers = {"Authorization":"bearer %s" % token} batch_res = requests.get(url=batch_url,params=batch_data,headers=headers)
3、根據下載路徑拼接下載url,完成文件下載以及寫入
file_path = batch_res.json()['data']['file_path'] file_name = batch_res.json()['data']['file_name'] down_url = "http://xxxx/api/report/down" down_data = {"type":2, "file_path":file_path, "file_name":file_name, "token":token } down_res = requests.get(url=down_url,params=down_data) with open(file_name,"wb") as code: code.write(down_res.content)
備注:
第二步返回json數據,包含路徑、文件名,實際是文件生成過程,第三步下載在服務端生成的文件,有時第三步無法在頁面F12查看到,需要使用抓包工具獲取