福建省公共数据资源统一开放平台API调用实例(Python)

本文介绍了如何使用Python编写脚本来调用福建省的公共数据资源统一开放平台的API接口,包括生成时间戳、随机数以及使用HMAC-SHA256进行签名认证的过程。
摘要由CSDN通过智能技术生成

今天找数据的时候看到福建省的公共数据资源统一开放平台,支持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())
  • 13
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值