大きなファイルのビデオファイルをFacebookにアップロードしようとしていますが、どのアプローチを採用しても、結果は常に同じです。このプロセスでは、5〜35 MB相当のデータがアップロードされ、タイムアウトになります。これはWiFiで発生します。
Facebook SDK 3.1.1、iOSソーシャルライブラリ(つまりSLRequest)、AFNetworkingを試してみました。
ソーシャルライブラリとafnetworkingはタイムアウトエラーを出しますが、Facebook SDKはコード5、操作を完了できませんでした、HTMLエラー200を返しますが、機器を介してネットワークアクティビティを監視すると、同じ署名があります。ストールする前にアップロードされているメガバイト。
3つの方法のいずれかを使用して、問題なく小さいビデオをアップロードできることに注意してください。
誰かがこの問題に遭遇し、その解決策や理由を見つけましたか?
ps Facebookのバグだと思います。他の誰かがそれを購読して調査を促す場合は、そこに問題を記録しました(https://developers.facebook.com/bugs/265409976924087)。
FacebookSDKコード
NSData *videoData = [NSData dataWithContentsOfFile:videoUrlStr options:NSDataReadingMappedAlways error:&lError];
NSString *description = self.streamToShare.videoDescription;
if (description == nil){
description = @"";
}
NSMutableDictionary *params = [NSMutableDictionary dictionaryWithObjectsAndKeys:videoData, self.streamToShare.publishedStoryFileName,
@"video/quicktime", @"contentType",
self.streamToShare.name, @"title",
description,@"description",
nil];
[FBRequestConnection startWithGraphPath:@"me/videos" parameters:params HTTPMethod:@"POST" completionHandler:^(FBRequestConnection *connection, id result, NSError *error) {
if (error) {
self.errorMessage = [NSString stringWithFormat:@"error: domain = %@, code = %d, description = %@", error.domain, error.code, error.localizedDescription];
}
}
iOSネイティブライブラリとAFNetworkingコード
[accountStore requestAccessToAccountsWithType:facebookTypeAccount
options:@{ACFacebookAppIdKey: appID,ACFacebookPermissionsKey: @[@"publish_stream"],ACFacebookAudienceKey:ACFacebookAudienceFriends} completion:^(BOOL granted, NSError *error) {
if(granted){
NSArray *accounts = [accountStore accountsWithAccountType:facebookTypeAccount];
facebookAccount = [accounts lastObject];
NSLog(@"Facebook Login Success");
NSURL *videourl = [NSURL URLWithString:@"https://graph.facebook.com/me/videos"];
NSURL *pathURL = [[NSURL alloc]initFileURLWithPath:self.streamToShare.publishedStoryURL isDirectory:NO];
NSDictionary *params = @{
@"title": self.streamToShare.name,
@"description": description
};
SLRequest *uploadRequest = [SLRequest requestForServiceType:SLServiceTypeFacebook requestMethod:SLRequestMethodPOST URL:videourl parameters:params];
[uploadRequest addMultipartData:videoData withName:@"source" type:@"video/quicktime" filename:[pathURL absoluteString]];
uploadRequest.account = facebookAccount;
NSURLRequest *urlRequest = [uploadRequest preparedURLRequest];
NSMutableURLRequest *mutableUrlRequest = [urlRequest mutableCopy];
[mutableUrlRequest setCachePolicy:NSURLRequestReloadIgnoringLocalAndRemoteCacheData];
[mutableUrlRequest setTimeoutInterval:60]; // adjusting this does not fix the issue
// AF Networking Code
NSInputStream *stream = [[NSInputStream alloc] initWithData:videoData];
[mutableUrlRequest setHTTPBodyStream:stream];
AFHTTPRequestOperation *operation = [[AFHTTPRequestOperation alloc]initWithRequest:mutableUrlRequest];
[operation setUploadProgressBlock:^(NSUInteger bytesWritten, long long totalBytesWritten, long long totalBytesExpectedToWrite) {
NSLog(@"%lld bytes out of %lld sent", totalBytesWritten, totalBytesExpectedToWrite, progress);
}];
[operation setCompletionBlockWithSuccess:^(AFHTTPRequestOperation *operation, id responseObject) {
NSLog(@"Facebook upload success");
} failure:^(AFHTTPRequestOperation *operation, NSError *error) {
NSLog(@"Facebook upload error %@",error.localizedDescription);
}
}];
[operation start];
// iOS Native Library Upload - Commented out so AFNetworking could be tested
//NSURLResponse *urlResponse = nil;
//NSError *urlRequestError = nil;
/*[NSURLConnection sendSynchronousRequest:mutableUrlRequest returningResponse:&urlResponse error:&urlRequestError];
if (urlResponse == nil) {
// Check for problems
if (urlRequestError != nil) {
NSLog(@"Error %@", urlRequestError.localizedDescription);
}
}
else {
// Data was received.. continue processing
NSLog(@"Worked!");
}*/
}else{
// ouch
NSLog(@"Permission not granted. Error: %@", error);
}
}];