&tag(GTMOAuth);
*目次 [#qea7a900]
#contents
*参考情報 [#t3892a5a]
-[[gtm-oauth - Google Toolbox for Mac - OAuth Controllers - Google Project Hosting:http://code.google.com/p/gtm-oauth/]]…Google製のOAuthライブラリ。
-[[GTMOAuthでTwitterなどのOAuthを行う方法 - Awaresoft:http://www.awaresoft.jp/ios-dev/item/90-gtmoauth]]
-[[予定外 [iOS5/ARC対応] iOSでTwitterクライアント その1 (準備編):http://homepie.blog.shinobi.jp/Entry/32/]]
-[[予定外 [iOS5/ARC対応] iOSでTwitterクライアント その2 (サインイン):http://homepie.blog.shinobi.jp/Entry/33/]]
-[[予定外 [iOS5/ARC対応] iOSでTwitterクライアント その3 (タイムライン取得):http://homepie.blog.shinobi.jp/Entry/34/]]
-[[予定外 [iOS5/ARC対応] iOSでTwitterクライアント その4 (ツイート投稿):http://homepie.blog.shinobi.jp/Entry/35/]]
*基本 [#x97244e3]
-TwitterのWebページをUIWebViewで表示しOAuth認証するライブラリ。
-OAuthするだけなので、Twitterでつぶやくとかそういう機能はない。

*サンプル: OAuthSampleTouch [#a5991874]

**基本 [#yd2b2ddb]
-GTMOAuthをダウンロードしたフォルダの中にある、OAuthSampleTouchというのがiOS用のサンプル。2012/07/24(火)現在のものなので将来的に変わる可能性あり。
-ビルドしてもそのまま動かないので、OAuthSampleRootViewControllerTouch.mを修正する。
-以下TwitterのOAuth認証を利用する場合の修正方法を説明。
-Twitterアプリは予めdev.twitter.comで登録しておく。認証タイプはBrowserにしておかないとだめ(コールバックURLにURLが入っているかどうかで判定しているらしい。つまりURLが入っていればBrowser。入ってなければデスクトップ扱い。)。
** authForTwitterの修正 [#r81b0d6b]
-ConsumerKey, ConsumerSecretを自分のTwitterアプリのものに修正する(これはTwitterにアプリを登録すれば表示される)。
#pre{{
- (GTMOAuthAuthentication *)authForTwitter {

  //以下を修正
  NSString *myConsumerKey = @"YourConsumerKey";
  NSString *myConsumerSecret = @"YourConsumerSecret";

  if ([myConsumerKey length] == 0 || [myConsumerSecret length] == 0) {
    return nil;
  }

  GTMOAuthAuthentication *auth;
  auth = [[[GTMOAuthAuthentication alloc] initWithSignatureMethod:kGTMOAuthSignatureMethodHMAC_SHA1
                                                        consumerKey:myConsumerKey
                                                         privateKey:myConsumerSecret] autorelease];

  [auth setServiceProvider:kTwitterServiceName];

  return auth;
}
}}


**signInToTwitterの修正 [#jacafd5e]
-OAuthに必要なURLを修正する。変わる可能性があるのでTwitterアプリページに表示されるものをコピペしたほうがよい(httpじゃなくhttpsとか)。
-scopeはnilでいいらしい。
-setCallbackで設定するURLはダミーでいいらしい。
-setBrowserCookiesURLでセットするURLはブラウザのCookieを消去するURL。二回目表示したときにログイン状態にならないようにする。これもOAuthのURLに併せてhttpsバージョンにしたほうがいいっぽい。
#pre{{
- (void)signInToTwitter {

  [self signOut];

  NSURL *requestURL = [NSURL URLWithString:@"https://api.twitter.com/oauth/request_token"];
  NSURL *accessURL = [NSURL URLWithString:@"https://api.twitter.com/oauth/access_token"];
  NSURL *authorizeURL = [NSURL URLWithString:@"https://api.twitter.com/oauth/authorize"];

  GTMOAuthAuthentication *auth = [self authForTwitter];
  if (auth == nil) {
    // perhaps display something friendlier in the UI?
    NSAssert(NO, @"A valid consumer key and consumer secret are required for signing in to Twitter");
  }

  //これはダミーでいいらしい
  [auth setCallback:@"http://www.example.com/OAuthCallback"];

  NSString *keychainItemName = nil;
  if ([self shouldSaveInKeychain]) {
    keychainItemName = kTwitterKeychainItemName;
  }

  // Display the autentication view.
  GTMOAuthViewControllerTouch *viewController;
  viewController = [[[GTMOAuthViewControllerTouch alloc] initWithScope:nil //scopeはNULLに
                language:nil
         requestTokenURL:requestURL
       authorizeTokenURL:authorizeURL
          accessTokenURL:accessURL
          authentication:auth
          appServiceName:keychainItemName
                delegate:self
        finishedSelector:@selector(viewController:finishedWithAuth:error:)] autorelease];

  // Cookieを消去するURLこれもhttpsバージョンにしたほうがよいのかな?
  [viewController setBrowserCookiesURL:[NSURL URLWithString:@"https://api.twitter.com/"]];
  [[self navigationController] pushViewController:viewController animated:YES];
}
}}


**動作確認 [#b8579aa4]
-Twitterを選び、[Sign In]ボタンを押す。
#ref(start.png)
-Twitterアカウントを入力。
#ref(twitter.png)
-AccessTokenが表示される。デバッガ出力に動作確認として認証が必要なステータスが出力される。
#ref(finish.png)

**動作の流れ解説 [#s24e0a6d]
-[Sign in]ボタンを押すとsignInOutClicked→signInToTwitterと呼ばれる。
-signInToTwitterでは、GTMOAuthViewControllerTouchが呼ばれる。このビューコントローラーはフレームワーク側にある。TwitterのWeb認証が行われる。
-Web認証が終わるとviewController:finishedWithAuth:errorが呼ばれる。成功の場合doAnAuthenticatedAPIFetchが呼ばれ、そこでTwitterで認証されたアカウントのタイムラインがテスト用に表示される(出力ウィンドウに)。

*自前のプロジェクトに組み込む [#j88b6a5d]
-Security.frameworkとSystemConfiguration.frameworkの追加が必要。


トップ   新規 一覧 検索 最終更新   ヘルプ   最終更新のRSS