2011-12-10 25 views
0

私はOpenIDの概念が新しく、最近JanRain PHP 5システムを使用してCodeIgniterのOpenID Libraryを実装しようとしました。 GoogleやYahooのようなサイトからの単純なデータを取得中...しかし、いくつかの問題にCodeigniter OpenID認証

を走ったのOpenIDライブラリのための私の設定ファイルは次のようになります。しかし、

<?php if (! defined('BASEPATH')) exit('No direct script access allowed'); 
    $config['openid_storepath'] = 'tmp'; 
    $config['openid_policy'] = 'test/policy'; 
    $config['openid_required'] = array('email'); 
    $config['openid_optional'] = array('fullname'); 
    $config['openid_request_to'] = 'test/check'; 
?> 

、私はどちらか取得できませんよ'電子メール'または 'フルネーム'の値。私は他のフィールド( 'ニックネーム'など)を入力しようとしましたが、結果も得られませんでした。さらに、JanRain docs( 'verifiedEmail'や 'preferredUsername'など)に指定されている他の多くのオプションは、単にSREGエラーを引き起こしました。

認証が成功しました。成功メッセージが返されましたが、要求した情報にどのようにアクセスできますか?

編集:ここでは、戻りURLは次のとおりです。

http://www.{Site}.net/v2/test/check?janrain_nonce=2011-12-10T05:53:01ZFXVT02&openid.ns=http%3A%2F%2Fspecs.openid.net%2Fauth%2F2.0&openid.mode=id_res&openid.return_to=http%3A%2F%2Fwww.{Site}.net%2Fv2%2Ftest%2Fcheck%3Fjanrain_nonce%3D2011-12-10T05%3A53%3A01ZFXVT02&openid.claimed_id=https%3A%2F%2Fme.yahoo.com%2Fa%2F{Token}%23df6f7&openid.identity=https%3A%2F%2Fme.yahoo.com%2Fa%2F{Token}&openid.assoc_handle={Handle}&openid.realm=http%3A%2F%2Fwww.{Site}.net%2Fv2%2F&openid.ns.pape=http%3A%2F%2Fspecs.openid.net%2Fextensions%2Fpape%2F1.0&openid.response_nonce=2011-12-10T05%3A53%3{Nonce Token}&openid.signed=assoc_handle%2Cclaimed_id%2Cidentity%2Cmode%2Cns%2Cop_endpoint%2Cresponse_nonce%2Creturn_to%2Csigned%2Cpape.auth_level.nist&openid.op_endpoint=https%3A%2F%2Fopen.login.yahooapis.com%2Fopenid%2Fop%2Fauth&openid.pape.auth_level.nist=0&openid.sig=CUa39ZjhGE8nWc7TMvbS8UFlwjQ%3D 

ありがとう!

+0

これを参照してください。 http://thinkmoult.com/2009/02/22/use-codeigniter-openid-library-to-integrate-openid/ –

+0

@RohanPatil私はそのガイドに従っていて、いくつかのコメントを読んでいますが、まだソリューション... – drfranks3

+0

@DFranks私はあなたがyahoo/googleにリダイレクトしたと仮定し、ログインしてアプリケーションにリダイレクトされています。この場合、URLとそのパラメータを表示できますか? –

答えて

0

私はPHPであなたを助けることはできませんが、私はやっている私は、私はヤフーこのためAuthenticationUrl()を作成していながら、ヤフー

ための作業Javaで開発している、あなたのコードをされて表示することができます

StringBuilder sb = new StringBuilder(1024); 
     sb.append(endpoint.getUrl()) 
      .append(endpoint.getUrl().contains("?") ? '&' : '?') 
      .append(getAuthQuery(endpoint.getAlias())) 
      .append("&openid.return_to=") 
      .append(returnToUrlEncode) 
      .append("&openid.assoc_handle=") 

ここでは、この属性交換を使用するには、どのようなアイデアを与えるだろう

String getAuthQuery(String axa) { 
     if (authQuery!=null) 
      return authQuery; 
     List<String> list = new ArrayList<String>(); 
     list.add("openid.ns=http://specs.openid.net/auth/2.0"); 
     list.add("openid.claimed_id=http://specs.openid.net/auth/2.0/identifier_select"); 
     list.add("openid.identity=http://specs.openid.net/auth/2.0/identifier_select"); 
     list.add("openid.mode=checkid_setup"); 
     list.add("openid.ns." + axa + "=http://openid.net/srv/ax/1.0"); 
     list.add("openid." + axa + ".mode=fetch_request"); 
     list.add("openid." + axa + ".type.email=http://axschema.org/contact/email"); 
     list.add("openid." + axa + ".type.fullname=http://axschema.org/namePerson"); 
     list.add("openid." + axa + ".type.language=http://axschema.org/pref/language"); 
     list.add("openid." + axa + ".type.firstname=http://axschema.org/namePerson/first"); 
     list.add("openid." + axa + ".type.lastname=http://axschema.org/namePerson/last"); 
     list.add("openid." + axa + ".type.gender=http://axschema.org/person/gender"); 
     list.add("openid." + axa + ".required=email,fullname,language,firstname,lastname,gender"); 
     String query = Utils.buildQuery(list); 
     authQuery = query; 
     return query; 
    } 

希望は私のgetAuthQuery機能です。

+0

ありがとうございます!あなたのコードに加えて、この[置き換え](http://codeigniter.com/wiki/A3M_Account_Authentication_and_Authorization)は私の問題を解決するのに役立ちました。 :) – drfranks3

関連する問題