Twitter は API 1.0 を廃止し、新しい API 1.1 を実装しました。新しい API に従って、公開タイムラインを取得する前に認証が必要です。
ここで新しい API ドキュメントを読みました: https://dev.twitter.com/docs/api/1.1 しかし、iOS に実装する方法が明確ではありません。
API 1.1 を使用して Twitter から公開タイムラインを取得する最良の方法を教えてください。
前もって感謝します。
Twitter は API 1.0 を廃止し、新しい API 1.1 を実装しました。新しい API に従って、公開タイムラインを取得する前に認証が必要です。
ここで新しい API ドキュメントを読みました: https://dev.twitter.com/docs/api/1.1 しかし、iOS に実装する方法が明確ではありません。
API 1.1 を使用して Twitter から公開タイムラインを取得する最良の方法を教えてください。
前もって感謝します。
まず、リクエストが必要ですAuthenticate
(許可を得る)。
次に、次の手順を参照してください。
1.TwitterFHSTwitterEngine
ライブラリをダウンロードします。
2. フォルダFHSTwitterEngine
" をプロジェクトに追加し、#import "FHSTwitterEngine.h".
3.SystemConfiguration.framework
プロジェクトに追加します。
使用法: 1.in に
[ViewDidLoad]
次のコードを追加します。
UIButton *logIn = [UIButton buttonWithType:UIButtonTypeRoundedRect];
logIn.frame = CGRectMake(100, 100, 100, 100);
[logIn setTitle:@"Login" forState:UIControlStateNormal];
[logIn addTarget:self action:@selector(showLoginWindow:) forControlEvents:UIControlEventTouchUpInside];
[self.view addSubview:logIn];
[[FHSTwitterEngine sharedEngine]permanentlySetConsumerKey:@"<consumer_key>" andSecret:@"<consumer_secret>"];
[[FHSTwitterEngine sharedEngine]setDelegate:self];
and don't forget to import the delegate FHSTwitterEngineAccessTokenDelegate.
you need to get the permission for your request, with the following method which will present Login window:
- (void)showLoginWindow:(id)sender {
[[FHSTwitterEngine sharedEngine]showOAuthLoginControllerFromViewController:self withCompletion:^(BOOL success) {
NSLog(success?@"L0L success":@"O noes!!! Loggen faylur!!!");
}];
}
ログイン ウィンドウが表示されたら、Twitter
ユーザー名とパスワードを入力してリクエストを認証します。
次のメソッドをコードに追加します。
-(void)viewWillAppear:(BOOL)animated
{
[super viewWillAppear:animated];
[[FHSTwitterEngine sharedEngine]loadAccessToken];
NSString *username = [[FHSTwitterEngine sharedEngine]loggedInUsername];// self.engine.loggedInUsername;
if (username.length > 0) {
lbl.text = [NSString stringWithFormat:@"Logged in as %@",username];
[self listResults];
} else {
lbl.text = @"You are not logged in.";
}
}
- (void)storeAccessToken:(NSString *)accessToken {
[[NSUserDefaults standardUserDefaults]setObject:accessToken forKey:@"SavedAccessHTTPBody"];
}
- (NSString *)loadAccessToken {
return [[NSUserDefaults standardUserDefaults]objectForKey:@"SavedAccessHTTPBody"];
}
4.Now you are ready to get your request, with the following method(in this method I created a `Twitter` search for some `Hashtag`, to get the screen_name for example):
- (void)listResults {
dispatch_async(GCDBackgroundThread, ^{
@autoreleasepool {
[UIApplication sharedApplication].networkActivityIndicatorVisible = YES;
// the following line contains a FHSTwitterEngine method wich do the search.
dict = [[FHSTwitterEngine sharedEngine]searchTweetsWithQuery:@"#iOS" count:100 resultType:FHSTwitterEngineResultTypeRecent unil:nil sinceID:nil maxID:nil];
// NSLog(@"%@",dict);
NSArray *results = [dict objectForKey:@"statuses"];
// NSLog(@"array text = %@",results);
for (NSDictionary *item in results) {
NSLog(@"text == %@",[item objectForKey:@"text"]);
NSLog(@"name == %@",[[item objectForKey:@"user"]objectForKey:@"name"]);
NSLog(@"screen name == %@",[[item objectForKey:@"user"]objectForKey:@"screen_name"]);
NSLog(@"pic == %@",[[item objectForKey:@"user"]objectForKey:@"profile_image_url_https"]);
}
dispatch_sync(GCDMainThread, ^{
@autoreleasepool {
UIAlertView *av = [[UIAlertView alloc]initWithTitle:@"Complete!" message:@"Your list of followers has been fetched" delegate:nil cancelButtonTitle:@"OK" otherButtonTitles:nil];
[av show];
[UIApplication sharedApplication].networkActivityIndicatorVisible = NO;
}
});
}
});
}
それで全部です。screen_name
からを取得search Query
しました。次の方法を使用して、ユーザーのタイムラインを取得できます。
// statuses/user_timeline
- (id)getTimelineForUser:(NSString *)user isID:(BOOL)isID count:(int)count;
- (id)getTimelineForUser:(NSString *)user isID:(BOOL)isID count:(int)count sinceID:(NSString *)sinceID maxID:(NSString *)maxID;
上記の検索方法の代わりに。
注:
FHSTwitterEngine.h
どの方法を使用する必要があるかについては、 を参照してください。注: と を取得するには<consumer_key>
、 のアプリへの<consumer_secret>
このリンクにアクセスする必要があります。register
次のライブラリに興味があるかもしれません。
https://github.com/nst/STツイッター
これは、Twitter REST API 1.1 用の軽量の Objective-C ラッパーです。
例については、ReadMe と Demo プロジェクトを参照してください。
これは、ライブラリにある多くのメソッドの 1 つにすぎません。
- (void)getUserTimelineWithScreenName:(NSString *)screenName
successBlock:(void(^)(NSArray *statuses))successBlock
errorBlock:(void(^)(NSError *error))errorBlock;