我应该使用哪一个来从Openid auth进程索引用户。 “openid identity”或“openid_claimed_id”?我使用Dope OpenId类,返回的数据是:
[openid_ns] => http://specs.openid.net/auth/2.0
[openid_mode] => id_res
[openid_return_to] => http://localhost/login/authenticate
[openid_claimed_id] => https://me.yahoo.com/a/wK7..MjM-#607
[openid_identity] => https://me.yahoo.com/a/wK7...MjM-
[openid_realm] => http://localhost/
[openid_assoc_handle] =>odm...j24yhwlT...2TOXQ9.sifIz3eLZoU.....jOoGM...9VPcMVavQkVgEQ--
[openid_response_nonce] => 2009-09-19T12:35:08Z95e...WtOYlQ--
[openid_signed] => assoc_handle,claimed_id,identity,mode,ns,op_endpoint,response_nonce,return_to,signed,ns.pape,pape.auth_level.ns.nist,pape.auth_level.nist,pape.auth_policies
[openid_op_endpoint] => https://open.login.yahooapis.com/openid/op/auth
[openid_ns_pape] => http://specs.openid.net/extensions/pape/1.0
[openid_pape_auth_level_ns_nist] => http://csrc.nist.gov/publications/nistpubs/800-63/SP800-63V1_0_2.pdf
[openid_pape_auth_level_nist] => 0
[openid_pape_auth_policies] => http://schemas.openid.net/pape/policies/2007/06/none
[openid_sig] => kO7......EitU=
由于
答案 0 :(得分:7)
使用openid.claimed_id
参数作为用户的逻辑主键。将其视为case sensitive,并使用整个值。 不修剪片段或方案(协议)。将“http://”和“https://”协议视为完全不同,即使URL的其余部分相同。简而言之,将openid.claimed_id
视为不透明值
必须完全为新用户存储并完全匹配返回用户。
OpenID 2.0 specification进一步解释,但简短的回答在上面。
答案 1 :(得分:-2)
由于OpenID委派,您应始终存储用户提供的OpenID的规范形式作为输入。
在您的情况下,看起来声称身份在末尾有一个片段标识符,与OpenID进程无关。