当前位置: 首页 > news >正文

提供免费服务器的网站做企业网站哪个平台好

提供免费服务器的网站,做企业网站哪个平台好,上海网站建设专家,电子烟网站建设苹果服务端通知v2处理 关键词: App Store Server Notifications V2、Python源码、苹果订阅、JWS、x5c、JSON WEB TOKEN 背景 最近要接入苹果订阅功能,调研后发现订阅生命周期内的状态变更是通过苹果服务端通知返回的(什么时候普通内购也能加上减少掉单的概率)&am…

苹果服务端通知v2处理

关键词: App Store Server Notifications V2、Python源码、苹果订阅、JWS、x5c、JSON WEB TOKEN

背景

最近要接入苹果订阅功能,调研后发现订阅生命周期内的状态变更是通过苹果服务端通知返回的(什么时候普通内购也能加上减少掉单的概率),
其回调的正确性验证是依靠回调内容里的几个证书,捣鼓这块耗费了好几天时间,所以在此记录一下。

JWS

苹果服务端返回的数据格式为JWS,之前没处理过这种类型的数据,其实本质上还是JWT那一套,关于JWS的介绍
参考IETF RFC 7515-JSON Web Signature

JWS格式与验证

jws格式为 header.payload.signature
其中每部分都是基于urlbase64加密过的,需要使用urlbase64解密得到内容。
其中,header最为关键,其内容为:

{"alg": "ES256","x5c": ["服务器证书","中间证书","根证书"]
}

alg为本次回调的签名算法,ES256代表为 ECDSA using SHA-256 hash algorithm
x5c则为证书链,其内部的第一个证书为验证本次回调签名所使用,需要先将证书转为X509格式,再从其中解析出公钥,使用公钥对数据进行验签

payload部分就是本次通知的业务数据,此处不做过多描述,参考官方文档

signature则是本次签名的结果。

简单的来说就是该格式包含了详细数据证书链签名算法签名结果
需要我们在本地完成数据的正确性和合法性:

  • 合法性:验证证书链是可信的。
  • 正确性:使用证书链中的服务器证书内的公钥验证数据和签名是正确未经过篡改的。

验证思路

x5c证书链的验证

这块参考了下图
在这里插入图片描述

也就是说,证书链内有三个证书,分别是服务器证书、中间证书、根证书。 其验证顺序是

  • 使用中间证书验证服务器证书
  • 使用根证书验证中间证书
  • 使用根证书验证中间证书

那么根证书本身呢? 则需要用苹果官方的提供的根证书进行验证。如果整个验证流程下来都验证成功了,那么整个证书链就是可信的了。
其中苹果官方提供的根证书为AppleRootCA-G3.cer,需要自己从官网下载,下载地址

Python对证书的验证主要使用了openssl.crypto包下面的X509StoreX509StoreContext
其基本思路为

  • 将可信证书(一般为root证书)先加载至X509Store实例内,然后使用X509StoreContext对待验证证书进行verify_certificate验证
  • 单个证书验证如此,对于一个证书链,优先将待验证的证书验证完毕后加入到X509Store实例内,然后再继续验证后一个即可,以此类推。

python实现代码如下:

from OpenSSL import crypto
def verify_apple_jws_cert_chain(x5c):"""验证苹果server notify的证书链'x5c':['服务器证书','中间证书','根证书']我们验证顺序: 苹果根证书->x5c根证书, x5c根证书->中间证书, 中间证书->服务器证书:param x5c::return:"""if not x5c or not isinstance(x5c, list):return "x5c type error"# 加载x5c证书,转为X509证书格式x5c_cert = []try:for each in x5c:cert = "-----BEGIN CERTIFICATE-----\n" + each + "\n-----END CERTIFICATE-----"new_cert = crypto.load_certificate(crypto.FILETYPE_PEM, cert)x5c_cert.append(new_cert)except Exception as e:return "x5c certification load exception {}".format(e)# 加载苹果根证书cert_file = open("./AppleRootCA-G3.cer", "rb")apple_root_cert = crypto.load_certificate(crypto.FILETYPE_ASN1, cert_file.read())cert_file.close()# 接下来验证证书链,验证失败会报错:OpenSSL.crypto.X509StoreContextError: unable to get local issuer certificate# 首先验证x5c内的根证书store = crypto.X509Store()store.add_cert(apple_root_cert)try:store_ctx = crypto.X509StoreContext(store, x5c_cert[2])store_ctx.verify_certificate()except Exception as e:return "verify root certification exception {}".format(e)# 接下来验证x5c内的中间证书store.add_cert(x5c_cert[2])try:store_ctx = crypto.X509StoreContext(store, x5c_cert[1])store_ctx.verify_certificate()except Exception as e:return "verify mid certification exception {}".format(e)# 最后验证服务器证书store.add_cert(x5c_cert[1])try:store_ctx = crypto.X509StoreContext(store, x5c_cert[0])store_ctx.verify_certificate()except Exception as e:return "verify server certification exception {}".format(e)# 最终验证成功return ""

JWS的签名验证

验证完证书链后,那么签名的验证就好说了,目前的 jwt库 基本上都支持ES256签名了
不过我们需要先从x5c内获取服务器证书,将其转为X509对象后,获取其中的公钥,并使用公钥来验签,基本代码如下

import jwt
from OpenSSL import crypto# 获取服务器证书
alg = header.get("alg")
x5c = header.get("x5c")
server_cert = x5c[0]
# 将服务器证书转为X509证书对象
cert = "-----BEGIN CERTIFICATE-----\n" + server_cert + "\n-----END CERTIFICATE-----"
server_cert = crypto.load_certificate(crypto.FILETYPE_PEM, cert)
# 从证书内解析出公钥
public_key = crypto.dump_publickey(crypto.FILETYPE_PEM, server_cert.get_pubkey()).decode("utf-8")
# 使用公钥对整个jws进行验签
decode_jws = jwt.decode(jws, public_key, algorithms=[alg])

完整的代码和单元测试用例我放在我的github 上了
如果你觉得对你有帮助,希望帮忙点个star。

参考

StoreKit2【附源码】JWS X.509证书链验证
JWS-X.509 Certificate Chain

http://www.yidumall.com/news/21346.html

相关文章:

  • 如何做网站反链美国疫情最新数据消息
  • 外贸多语言网站建设网站seo案例
  • 网站设计制作的服务机构怎么把自己的产品推广出去
  • 郑州做网站服务器seo推广学院
  • 临西网站建设廊坊seo管理
  • 网站开发任务清单自己如何注册一个网站
  • 莱西网站建设营销网站设计
  • 做网站一般建多大的页面南宁网络推广外包
  • 浦东网站建设价格抖音seo优化怎么做
  • 网站备案 主体冲突查询关键词
  • 怎样用自己的pid做搜索网站学编程的正规学校
  • 汕头seo网站排名b2b免费网站推广平台
  • 做网站挣钱快又多百度seo网站在线诊断
  • 关于网站建设毕业论文8000字百度营销搜索推广
  • 做网站的公司利润率是多少企业做个网站多少钱
  • 免费申请域名做网站南昌seo优化公司
  • 物联网官网seo搜索引擎优化技术
  • ppt 做的最好的网站有哪些青岛设计优化公司
  • 商标设计logo网站seo在线教学
  • 个人免费域名空间建站火狐搜索引擎
  • 实用的企业网站优化技巧网页做推广
  • 网站推广的方式包括哪些顶尖文案网站
  • www的网站怎么申请云南网站seo服务
  • 免费网站建设资讯网上营销培训课程
  • 有哪些做批发出口的网站昆明百度推广开户费用
  • 南通网站群建设网络广告怎么做
  • 青岛知名网站建设哪家好玉林seo
  • 免费网站优化怎么做网站设计的流程
  • 帮诈骗团伙做网站属于诈骗吗搜索引擎推广的费用
  • 做网站用什么语言好网络热词缩写