今天找数据的时候看到福建省的公共数据资源统一开放平台,支持API接口调用,简单写了一个Python脚本调用平台的数据,放出来供参考。
导入包,编写生成时间戳和随机数的工具函数:
import requests
import hashlib
import base64
import random
def get_time() -> str:
# 时间戳, 1970年1月1日起至今的时间转换为毫秒
url = 'http://api.m.taobao.com/rest/api3.do?api=mtop.common.getTimestamp'
headers = {
'User-Agent': 'Mozilla/5.0 (Linux; Android 6.0; Nexus 5 Build/MRA58N) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/88.0.4324.150 Mobile Safari/537.36'
}
response = requests.get(url, headers=headers)
time = response.json()['t']
return response
def get_nonce():
# 生成5位随机数
return ''.join([str(random.randint(1, 9)) for _ in range(5)])
在平台上获取API的URL、Client ID和秘钥后,填入下方变量中:
url = 'API URL HERE'
x_client_id = 'YOUR CLIENT ID HERE'
x_sign_key = 'YOUR SIGNATURE HERE'
x_timestamp = get_time()
x_nonce = get_nonce()
x_sign = x_client_id + x_timestamp + x_nonce
# 使用HmacSHA256算法计算并经Base64编码后的字符串,密钥为签名认证令牌密钥
x_sign = hmac.new(x_sign_key.encode('utf-8'), x_sign.encode('utf-8'), digestmod=hashlib.sha256).digest()
x_sign = str(base64.b64encode(x_sign), 'utf-8')
写好请求头和要请求的字段,然后发送POST请求:
headers = {
'X-Client-Id': x_client_id,
'X-Timestamp': x_timestamp, # 时间戳, 1970年1月1日起至今的时间转换为毫秒
'X-Nonce': x_nonce, # 随机数
'X-Signature': x_sign,
'User-Agent': 'Mozilla/5.0 (Linux; Android 6.0; Nexus 5 Build/MRA58N) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/88.0.4324.150 Mobile Safari/537.36',
}
# 所有参数都需进行URL编码,编码时请遵守 RFC 1738
data = {
'START': 1,
'SIZE': 10,
}
# 发送请求
response = requests.post(url, data=data)
print(response.json())