【发布时间】:2025-12-21 18:55:10
【问题描述】:
最近我将我的谷歌幻灯片脚本运行时从Rhino 切换到V8。我测试了我的插件,但出现错误:
We're sorry, a server error occurred while reading from storage. Error code PERMISSION_DENIED.
我的脚本使用PropertiesService.getUserProperties()。我发现我必须退出我的谷歌帐户并重新登录,它工作。
我可以想象,对于使用此插件的其他用户来说,这也可能是一件痛苦的事情。有没有其他方法可以解决这个错误?
appscript.json 配置
{
"timeZone": "Europe/Bratislava",
"runtimeVersion": "V8",
"dependencies": {
},
"exceptionLogging": "STACKDRIVER"
}
我还在我的 PC 上开发插件本地化,并使用 clasp 将代码推送到 App 脚本。
更新
我创建了最小的项目来重现此错误,我发现PropertiesService.getUserProperties() 不是问题所在。结果从Rhino切换到V8后,我无法调用任何appscript函数。
// Code.gs
function onInstall(event) {
onOpen(event);
}
function onOpen(event) {
SlidesApp.getUi().createAddonMenu()
.addItem('Open the sidebar', '_showSidebar')
.addToUi();
_showSidebar();
}
function _showSidebar() {
var ui = HtmlService
.createHtmlOutputFromFile('index')
.setTitle('Test add-on');
SlidesApp.getUi().showSidebar(ui);
}
function getCurrentSlideObjectId() {
var page = SlidesApp.getActivePresentation().getSelection().getCurrentPage();
if (page && page.getPageType() === SlidesApp.PageType.SLIDE) {
return page.getObjectId();
}
return null;
}
带模板:
<!DOCTYPE html>
<html>
<head>
<base target="_top">
<script>
const onButtonClick = () => {
google.script.run
.withSuccessHandler(success)
.withFailureHandler(error)
.getCurrentSlideObjectId()
}
const success = (currentSlideObjectId) => {
console.log("It works!", currentSlideObjectId);
}
const error = (error) => {
error = typeof error === 'string' ? new Error(error) : error;
console.error(typeof error === 'object' && error !== null ? error.message : error);
}
</script>
</head>
<body>
<button onclick="onButtonClick()">Click me</button>
</body>
</html>
目前我使用 2 个不同的账户登录到我的谷歌驱动器。在登录 Google chrome 以外的其他 acc 上测试插件时,会出现错误。
We're sorry, a server error occurred while reading from storage. Error code PERMISSION_DENIED.
【问题讨论】:
标签: google-apps-script v8 google-apps-script-addon google-slides google-apps-script-runtime