使用p12密钥进行身份验证时出现错误用户无法访问帐户

时间:2019-05-27 07:04:01

标签: c# google-api google-api-dotnet-client service-accounts google-content-api

我有一个MVC Web应用程序,可以更新电子商务网站上的产品。现在,我们注册了Google商人中心,我的目标是同时更新产品。我正在使用Google.Apis.ShoppingContent.v2_1 API。

这是我的API凭据 API Credentials

这是我的API服务帐户 API Credentials 2

我已经为用户使用了Google帐户的电子邮件地址以及服务帐户的电子邮件地址,但是结果相同。

我有以下

    static string[] Scopes = { ShoppingContentService.Scope.Content};
    static string P12Secret =  @"~\Content\XXXXXX-5cab03fb904a.p12";
    static string userName = "serviceaccount@gserviceaccount.com";
    static public async Task RunTest2()
        {
            var certificate = new X509Certificate2(P12Secret, "notasecret", X509KeyStorageFlags.MachineKeySet | X509KeyStorageFlags.Exportable);
            var credential = new ServiceAccountCredential(new ServiceAccountCredential.Initializer(userName)
            {
                Scopes = Scopes
            }.FromCertificate(certificate));

            var service = new ShoppingContentService(new BaseClientService.Initializer
            {
                ApplicationName = ApplicationName,
                HttpClientInitializer = credential
            });

            try
            {
                var result = await service.Products.List("My MerchantID").ExecuteAsync();
            }
            catch (Exception e)
            {
                Console.WriteLine(e.Message);
            }
        }

当我执行var result = await service.Products.List(“ My MerchantID”)。ExecuteAsync();时,我收到错误

  

e.Message =“ Google.Apis.Requests.RequestError \ n用户无法访问帐户123456789 [401] \ r \ nErrors [\ r \ n \ tMessage [用户无法访问帐户123456789]位置[-]原因[-/ account_access_denied]域[content.ContentErrorDomain] \ r \ n] \ r \ n“

1 个答案:

答案 0 :(得分:1)

Documentaiton

  

服务帐户是特殊的Google帐户,应用程序可以使用它们通过OAuth 2.0以编程方式访问Google API。服务帐户使用不需要人工授权的OAuth 2.0流。相反,它使用只有您的应用程序可以访问的密钥文件。本指南讨论了如何使用服务帐户访问Content API for Shopping。

服务帐户需要预先授权。如果不是,则它无权访问任何数据。

  

用户无法访问帐户123456789

意味着它没有访问权限,您已经忘记授予它访问权限。请检查Documentaiton的外观以确保以下部分遵循所有步骤。

enter image description here