Android 在iOS设备上使用Apple Signin创建帐户后在其他平台上进行身份验证
假设一个用户在iOS设备上使用Apple Signin在我的应用程序上创建了一个帐户,并选择不共享他的电子邮件,导致他的帐户被一个电子邮件地址识别,如dpdcnf87nu@privaterelay.appleid.com而不是他的“真实”电子邮件地址,比如j。appleseed@icloud.com. 一段时间后,用户切换到Android设备,并希望使用他的帐户登录到我的应用程序,这是他之前在iOS设备上使用Apple signin创建的帐户Android 在iOS设备上使用Apple Signin创建帐户后在其他平台上进行身份验证,android,ios,apple-sign-in,Android,Ios,Apple Sign In,假设一个用户在iOS设备上使用Apple Signin在我的应用程序上创建了一个帐户,并选择不共享他的电子邮件,导致他的帐户被一个电子邮件地址识别,如dpdcnf87nu@privaterelay.appleid.com而不是他的“真实”电子邮件地址,比如j。appleseed@icloud.com. 一段时间后,用户切换到Android设备,并希望使用他的帐户登录到我的应用程序,这是他之前在iOS设备上使用Apple signin创建的帐户 你会如何简化用户在新安卓设备上登录帐户的过程,避免他
你会如何简化用户在新安卓设备上登录帐户的过程,避免他使用Facebook登录等其他方法创建新帐户(这不可避免地会导致创建新帐户-不同的电子邮件=不同的帐户) 您应该通过id识别用户,OAuth返回的id不是电子邮件地址。即使他们选择隐藏电子邮件,您也会在另一台设备上获得相同的id。您应该存储此字段以识别用户。 为了获取userId,您应该请求令牌rest API并获取userId:
https://appleid.apple.com/auth/token
。如果您使用Apple,您还将收到id_令牌
var id_token = responseJSON.GetValue("id_token").ToString();
var handler = new JwtSecurityTokenHandler();
var jwt = handler.ReadJwtToken(id_token);
var userId = jwt.Claims.FirstOrDefault((c) => c.Type == "sub").Value;