1. 验证苹果登录,官方提供两种验证方法,一种是token,另一个种是code。这里使用的是token

  2. 登录流程:

    1. 苹果客户端调用苹果API,获取到用户的信息,包括:

      1. user_id
      2. 昵称
      3. identity_token
    2. 苹果客户端发送identity_token到服务端
    3. 服务端验证identity_token是否合法,并解析数据,得到user_id。这个user_id和上面的user_id是一样的
    4. 服务端检查该user_id是否已注册,如果是,返回登录信息。如果否,注册。
  3. 验证的原理:

    1. 苹果会把用户的信息放在一个json里面,然后使用私钥对json签名。
    2. 服务端调用苹果API拿到公钥,然后验证签名是否正确。
    3. 所以总的来说就是使用RSA私钥签名的算法来保证数据不会被篡改。
  4. identity_token解析后包含几部分内容

    1. header。

      1. 例子:{u'alg': u'RS256', u'kid': u'86D88Kf'}
      2. alg是加密算法类型
      3. kid是使用的公钥的id
    2. payload或者claims 。也就是数据:
      1. 例子:

      {

      u'c_hash': u'HpjAKvLjivbJr9j9ZxfFxA',

      u'aud': u'com.kugou.moe',

      u'iss': u'https://appleid.apple.com',

      u'email_verified': u'true',

      u'nonce_supported': True,

      u'exp': 1583829815,

      u'auth_time': 1583829215,

      u'iat': 1583829215,

      u'email': u'huanghuixia5@163.com',

      u'sub': u'001712.90358ddaa2294989b3b7c88b30086b37.0724' # 用户唯一标志,相当于openid

      }

      ```

      1. aud 客户端的报名。
      2. exp。超时时间,时间戳。当前时间如果大于这个时间,会报超时错误
      3. email 用户的email
      4. sub 用户的user_id

demo

使用了python-jwt这个库。安装方法:pip install python-jwt

# encoding=utf8
import requests
import logging
import python_jwt as jwt, jwcrypto.jwk as jwk log = logging.getLogger('test') class AppleLoginManager(object):
"""
苹果登录
""" @classmethod
def get_key(cls, kid):
"""
访问apple 获取公钥。apple的接口会返回很多公钥的,根据jwt数据header的kid,找到对应的公钥
:param kid:
:return: {
"kty": "RSA",
"kid": "eXaunmL",
"use": "sig",
"alg": "RS256",
"n": "4dGQ7bQK8LgILOdLsYzfZjkEAoQeVC_aqyc8GC6RX7dq_KvRAQAWPvkam8VQv4GK5T4ogklEKEvj5ISBamdDNq1n52TpxQwI2EqxSk7I9fKPKhRt4F8-2yETlYvye-2s6NeWJim0KBtOVrk0gWvEDgd6WOqJl_yt5WBISvILNyVg1qAAM8JeX6dRPosahRVDjA52G2X-Tip84wqwyRpUlq2ybzcLh3zyhCitBOebiRWDQfG26EH9lTlJhll-p_Dg8vAXxJLIJ4SNLcqgFeZe4OfHLgdzMvxXZJnPp_VgmkcpUdRotazKZumj6dBPcXI_XID4Z4Z3OM1KrZPJNdUhxw",
"e": "AQAB"
}
"""
ret = requests.get('https://appleid.apple.com/auth/keys')
ret_json = ret.json()
for key in ret_json['keys']:
if key['kid'] == kid:
return key
log.error(u'[苹果登录]找不到对应的kid %s %s' % (kid, ret_json))
raise Exception('找不到对应的kid') @classmethod
def verify_jwt(cls, token):
"""
验证jwt数据,返回:
{
u'c_hash': u'HpjAKvivbJr9j9ZxfFxA',
u'aud': u'com.test.moe',
u'iss': u'https://appleid.apple.com',
u'email_verified': u'true',
u'nonce_supported': True,
u'exp': 1583829815,
u'auth_time': 1583829215,
u'iat': 1583829215,
u'email': u'hua@163.com',
u'sub': u'0017xx.9035989b3bxxxxx7c88b30086b37.xxx' # 用户唯一标志,相当于openid
} """
header, claims = jwt.process_jwt(token) # 获取信息,但是不验证
if claims['aud'] != 'com.test.test': # 检验是不是自己的安装包名
log.error(u'[苹果登录]aud异常 aud:%s token:%s' % (claims['aud'], token))
raise Exception(u'安装包名异常')
key_obj = AppleLoginManager.get_key(header['kid']) key = jwk.JWK(**key_obj) header, claims = jwt.verify_jwt(token, key, [key_obj['alg']], checks_optional=1) # 获取信息并验证
return claims @classmethod
def get_access_info(cls, token):
"""获取授权信息"""
try:
resp_json = AppleLoginManager.verify_jwt(token)
return {
"open_id": resp_json['sub'],
}
except:
log.exception(u'苹果登录异常,token:%s' % token)
raise Exception('苹果登录异常') token = '''xxxx''' #前端传过来的 identity_token
AppleLoginManager.get_access_info(token)

Python 解密JWT验证苹果登录的更多相关文章

  1. 苹果登录服务端JWT算法验证-PHP

    验证参数 可用的验证参数有 userID.authorizationCode.identityToken,需要iOS客户端传过来 验证方式 苹果登录验证可以选择两种验证方式 具体可参考这篇文章 htt ...

  2. python 加密 解密 签名 验证签名 公钥 私钥 非对称加密 RSA

    加密与解密,这很重要,我们已经可以用pypcap+npcap简单嗅探到网络中的数据包了.而这个工具其实可以嗅探到更多的数据.如果我们和别人之间传输的数据被别人嗅探到,那么信息泄漏,信息被篡改,将给我们 ...

  3. Jwt验证登录

    练习模板:https://gitee.com/zh1446802857/swagger-multi-version-api.git Jwt在我的 认知里,是一套门锁.别人(用户)需要用到你的接口 的时 ...

  4. golang学习笔记10 beego api 用jwt验证auth2 token 获取解码信息

    golang学习笔记10 beego api 用jwt验证auth2 token 获取解码信息 Json web token (JWT), 是为了在网络应用环境间传递声明而执行的一种基于JSON的开放 ...

  5. Python 生成 JWT(json web token) 及 解析方式

    一.关于 jwt 的原理及概念可以自行在网络上搜索了解一下,这里推荐一篇写的比较好的博客 深入了解Json Web Token之概念篇 另附 JWT 的官方文档: https://jwt.io/int ...

  6. JWT验证机制【刘新宇】【Django REST framework中使用JWT】

    JWT 在用户注册或登录后,我们想记录用户的登录状态,或者为用户创建身份认证的凭证.我们不再使用Session认证机制,而使用Json Web Token认证机制. 什么是JWT Json web t ...

  7. springBoot整合spring security+JWT实现单点登录与权限管理--筑基中期

    写在前面 在前一篇文章当中,我们介绍了springBoot整合spring security单体应用版,在这篇文章当中,我将介绍springBoot整合spring secury+JWT实现单点登录与 ...

  8. Python 实现 JWT 生成

    Python 实现 JWT 生成 JWT 简介:https://www.jianshu.com/p/576dbf44b2ae Json web token (JWT), 是为了在网络应用环境间传递声明 ...

  9. python paramiko模块SSH自动登录linux系统进行操作

    1). Linux系统首先要开启SSH服务:service ssh status 如果没安装的话,则要:apt-get install openssh-server service ssh resta ...

随机推荐

  1. python中安装surprise中出现error: Microsoft Visual C++ 14.0 is required. Get it with "Microsoft Visual C++ Build Tools":

    pip安装 安装之前要先进行numpy的安装 pip install numpy pip install surprise 安装出错: 安装surprise需要Microsoft visual c++ ...

  2. 第19届亚太零售商大会 | 奇点云CEO行在受邀出席发表演讲

    2019年9月5日—7日,第19届亚太零售商大会在重庆举行. 亚太零售商大会作为世界三大零售盛会之一,是亚太地区零售行业最具规模.最具影响力的零售行业盛会.本次大会以“新零售·新消费·新动力·合作与共 ...

  3. CDN是什么鬼

    CDN,内容分发网络,是大多数互联网业务里必不可少的部分,但大多数互联网从业人员不是特别清楚CDN究竟是什么,以及它可以为我们做哪些事情. 我们还是从之前介绍的<不同的人看到的直播为什么不一样? ...

  4. OpenCV Laplace 算子

    #include "opencv2/imgproc/imgproc.hpp" #include "opencv2/highgui/highgui.hpp" #i ...

  5. linux有些sh文件,为什么要用 ./ 来执行

    因为有环境变量PATH,里面包含了许多目录,这些目录下的可执行文件就无需输入完整路径来执行.你可以用 echo "$PATH"查看当前的环境变量包含的目录,自带的命令文件都是在PA ...

  6. php 正则获取html任意标签

    <?php $temp = ' <div class="num">1</div> <div class="num">2 ...

  7. input系统——android input系统

    AndroidInput系统--JNI NativeInputManager InputManger InputReader AndroidInput系统--InputReader AndroidIn ...

  8. unittest(13)- 从配置文件中读取测试数据

    case.config # 1. http_request.py import requests class HttpRequest: def http_request(self, url, meth ...

  9. Python 模块之间的引用

    项目结构: Dog.Cat模块引用Animal模块 Animal模块代码: # -*- coding:UTF-8 -*- # 定义一个动物类 class Animal(object): def run ...

  10. Mac 环境docker 安装jenkins

    网上很多的教程是讲的是Linux 上的Docker安装Jenkins,但是我用的是Mac,所以参考之前的前辈写的文章,记录一下自己的安装过程.非常感谢参考文章的前辈写的文章. 参考Docker安装Je ...