我已经实施了Google服务帐户,并将其作为授权用户添加到工作表中。
接下来,我使用以下代码访问工作表Feed:
const string gUser = "SVC-ACCOUNT@developer.gserviceaccount.com";
const string certFile = "CERTFILE.p12";
static void Main(string[] args) {
var certificate = new X509Certificate2(certFile, "notasecret", X509KeyStorageFlags.Exportable);
var serviceAccountCredentialInitializer = new ServiceAccountCredential.Initializer(gUser) {
Scopes = new[] { "https://spreadsheets.google.com/feeds/" }
}.FromCertificate(certificate);
var credential = new ServiceAccountCredential(serviceAccountCredentialInitializer);
if (!credential.RequestAccessTokenAsync(System.Threading.CancellationToken.None).Result)
return;
var requestFactory = new GDataRequestFactory(null);
requestFactory.CustomHeaders.Add("Authorization: Bearer " + credential.Token.AccessToken);
var service = new SpreadsheetsService("MY-SHEETS-SVC") { RequestFactory = requestFactory };
SpreadsheetQuery query = new SpreadsheetQuery();
var sheetFeed = service.Query(query);
Console.WriteLine("Spreadsheet list:");
foreach (var sheet in sheetFeed.Entries) {
Console.WriteLine("\t--" + sheet.Title.Text);
}
Console.ReadLine();
}
但是,尽管授予了服务帐户编辑权限,但它不会返回任何工作表。我已经将服务帐户添加到Google Apps安全组,但结果没有变化。在过去创建帐户(相同的应用程序域等)并在共享设置中授予它编辑权限是所有需要的。 API是否已更改为仅需要OAUTH,或者某个地方是否存在我丢失的设置?
答案 0 :(得分:0)
我的应用领域正在发生变化,目前正在迁移中。在新帐户下添加了一个表单,它立即出现。