官方文档地址:ios notification
推送截图步骤:
推送接入方法苹果给出了两种:
- certificate 证书接入
- token 接入
token 接入方法
- 根据文档给出的签名规则获取签名token。
import jwt
import time
token_dict = {'iat': int(time.time()),'iss': '**********' #颁发者密钥,其值是您用于开发公司应用程序的10个字符的团队ID。从您的开发人员帐户获取此值
}
header = {'alg': "ES256", # 指定的加密方法'kid': "**********" # 您从开发者帐户获得的10个字符的密钥ID
}
signing_pem = open("AuthKey_WW37W62BVM.p8", 'r').read() # 身份验证令牌签名密钥,指定为文本文件(带有.p8文件扩展名)。jwt_token = jwt.encode(token_dict, # payload, 有效载体signing_pem, # 进行加密签名的密钥algorithm="ES256", # 指明签名算法方式, 默认也是HS256headers=header # json web token 数据结构包含两部分, payload(有效载体), headers(标头)).decode('ascii') # python3 编码后得到 bytes, 再进行解码(指明解码的格式), 得到一个strprint(jwt_token)
- 根据获取的token,发现请求到对应接口(苹果支支持HTTP2请求,普通的请求HTTP1会报错)。
import requests
import jsontest_url = "https://api.sandbox.push.apple.com"
product_url = "https://api.push.apple.com"def get_headers():headers = {"authorization": "bearer " + jwt_token,"apns-push-type": "alert","apns-topic": "com.sxzq.ficc.fawo"}return headersdef post_data():from hyper.contrib import HTTP20Adaptersessions = requests.session()path = "/3/device/6211b0b7a393c90cc770c7d8a6c54ef760c22a5df1d06eea4778b7d4d614494a"url_full = test_url + pathdata = {"aps": {"alert": "测试通知","sound": "default","badge":4}}print(url_full)sessions.mount('https://api.sandbox.push.apple.com', HTTP20Adapter())r = sessions.post(url_full, data=json.dumps(data), headers=get_headers())print(r.content)print(r.status_code)print(r.headers)if __name__ == "__main__":post_data()
其他参数说明:
apns-expiration:过期
apns-priority:优先权
apns-collapse-id:合并
content-available:静默提示
其他参数说明