&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で認証されたアカウントのタイムラインがテスト用に表示される(出力ウィンドウに)。