我正在使用下面的代码来获取带有服务帐户的文件。
var certificate = new X509Certificate2("D:\\05-privatekey.p12", "notasecret", X509KeyStorageFlags.Exportable);
var privateKey = certificate.Export(X509ContentType.Cert);
var provider = new AssertionFlowClient(GoogleAuthenticationServer.Description, certificate)
{
ServiceAccountId = "877564787679-glrhdp0gclc9mbj77qe4998dkc6mfj62@developer.gserviceaccount.com",
Scope = DriveService.Scopes.Drive.GetStringValue(),
ServiceAccountUser = "user1@05.mygbiz.com"
};
var auth = new OAuth2Authenticator<AssertionFlowClient>(provider, AssertionFlowClient.GetState);
DriveService service = new DriveService(new BaseClientService.Initializer()
{
Authenticator = auth,
ApplicationName = "My APP",
});
FilesResource.ListRequest request = service.Files.List();
FileList files = request.Execute();
这里执行()api给出异常
发送直接消息或获取消息时出错 响应。
编辑:项目基于@ https://code.google.com/p/google-api-dotnet-client/wiki/Build
所述的设置编辑2:我在CPanel中根据服务帐户进行了适当的设置
答案 0 :(得分:0)
我遇到了同样的问题。我最终得到了它;我有一些错误。
provider
对象中添加的唯一属性是.ServiceAccountId
和.Scope
。Scope
而不使用枚举值(这只是一个问题,因为我使用的是VB)。我在Fusion Tables中工作,范围只是渲染为“Fusiontables”,因为VB.NET不使用GetStringValue()
枚举函数。现在我正在使用"https://www.googleapis.com/auth/fusiontables"
。转到here获取有效范围列表。ServiceAccountId
,我使用了服务帐户“电子邮件地址:”,其中包含“@”。 (12345@developer.gserviceaccount.com),而不是他们在控制台中标记为“客户ID:”的那个(12345.apps.googleusercontent.com)。希望这有助于其他人。