问题解决了,实际上我还不能选择我的答案作为解决方案。
我正在使用YouTube Data为移动应用程序开发视频上传功能,但在执行查询时始终存在401错误。
我正在使用Firebase为我提供来自的OAuth和API密钥。
我试着看看Firebase提供的PLIST文件是否有任何变化,甚至还有其他的变化。
我试图重置iOS模拟器,卸载应用程序,并通过GIDSignIn.sharedInstance().disconnect()终止应用程序帐户的权限。
我试图用其他StackOverFlow问题来查看,但它们都是关于其他语言的,甚至是“原始”HTTP请求。
在我的AppDelegate文件中,我有用于与Firebase和Google连接的行:
FirebaseApp.configure()
GIDSignIn.sharedInstance().clientID = FirebaseApp.app()?.options.clientID这个方法(还有一个非常类似的方法,我在这里不会展示):
func application( _ application: UIApplication, open url: URL, sourceApplication: String?, annotation: Any ) -> Bool {
return GIDSignIn.sharedInstance().handle( url,
sourceApplication: sourceApplication,
annotation: annotation )
}在我的控制器关联类中,我有以下方法来创建查询:
private func uploadVideo( withVideoObject video: GTLRYouTube_Video, resumeUploadLocationURL locationURL: URL? ) throws {
let query = try uploadQuery( _video: video, resumeUploadLocationURL: locationURL )!
// [ progress related feedback ]
YouTubeUploadController.uploadFileTicket = self.service.executeQuery( query,
delegate: self.controller!,
didFinish: #selector( self.controller!.displayResultWithTicket(ticket:finishedWithObject:error:) ) )
}
private func uploadQuery( _video: GTLRYouTube_Video, resumeUploadLocationURL locationURL: URL? ) throws -> GTLRYouTubeQuery_VideosInsert? {
let fileToUploadURL = URL( fileURLWithPath: "\(self.controller!.uploadPathField)" )
if !( try! fileToUploadURL.checkPromisedItemIsReachable() ) {
throw YouTubeCustomError.init( _kind: .fileNotFound )
}
// Get a file handle for the upload data.
let uploadParameters = prepareUploadParameters( fileToUploadURL: fileToUploadURL, locationURL: locationURL )
return GTLRYouTubeQuery_VideosInsert.query( withObject: _video, part: "snippet,status", uploadParameters: uploadParameters )
}它通过displayResultWithTicket(ticket:finishedWithObject:error:)发送一个错误
“此操作无法完成。(com.google.HTTPStatus错误401)。”
没有给定的failureReason,也没有recoverySuggestion。
提前谢谢。
响应体:
下面是logs的HTTP应答日志,用于上载尝试:
Response body: (178 bytes)
{
"error" : {
"message" : "Login Required",
"errors" : [
{
"message" : "Login Required",
"locationType" : "header",
"reason" : "required",
"domain" : "global",
"location" : "Authorization"
}
],
"code" : 401
}
}请求头
Request: POST https://www.googleapis.com/resumable/upload/youtube/v3/videos?part=snippet%2Cstatus&prettyPrint=false
Request headers:
Accept: application/json
Cache-Control: no-cache
Content-Type: application/json; charset=utf-8
User-Agent: org.cocoapods.GoogleAPIClientForREST/1.3.8 google-api-objc-client/3.0 iPhone/12.2 hw/sim (gzip) (GTMSUF/1)
X-Goog-Upload-Command: start
X-Goog-Upload-Content-Length: 2614231
X-Goog-Upload-Content-Type: video/mp4
X-Goog-Upload-Protocol: resumable发布于 2019-06-05 01:33:12
因此,在我的GIDSignInDelegate signIn方法中,我缺少了GIDSignInDelegate授权程序的矫揉造作:
service.authorizer = user.authentication.fetcherAuthorizer()
我认为在其他方法中也可以这样做,但是它是初始化它的核心点。
我是通过一个ObjC写访问器完成这个任务的,因为我没有找到一种create/obtain a GTRLService instance in Swift的方法,我使用了一个ObjC单例类来获得它,而且如果在ObjC中初始化了它,我也不确定是否可以在Swift中访问它。
+ (void)setSharedInstanceAuthorizer:(id <GTMFetcherAuthorizationProtocol>)_authorizer {
if (sharedInstance == nil) {
sharedInstance = [GTLRYouTubeService new];
}
sharedInstance.authorizer = _authorizer;
};如果这不能解决问题,那么@stvar在问题的注释中的回答可能会解决问题。
https://stackoverflow.com/questions/56434103
复制相似问题