我似乎无法让 Google Picker 工作。我已经使用PHP League Oauth Provider对我的用户进行了身份验证
身份验证后,我的用户的 accessToken 看起来像这样;
ya67.Fi_dfioriogneegroig7Czdy54z0sdfdvnfr9fn38n3n93
这是我用于呈现选择器的 Javascript 和 HTML 代码;
<a href="{{ appContextInstallId }}/authenticate" class="btn info">
<i class="icon-bolt"></i> Authenticate
</a>
<button onClick="createPicker()">Add a new document</button>
<script type="text/javascript">
var developerKey = 'erteetr43gg-V34y4httytjyjytjyttyjyjyjjy';
var clientId = "373498750987-5dsfwerrwewerweewrl.apps.googleusercontent.com"
var appId = "373498750987"
var scope = ['https://www.googleapis.com/auth/drive'];
var pickerApiLoaded = false;
// Use the Google API Loader script to load the google.picker script.
// Create and render a Picker object for searching images.
function createPicker() {
var view = new google.picker.View(google.picker.ViewId.DOCS);
var picker = new google.picker.PickerBuilder()
.enableFeature(google.picker.Feature.NAV_HIDDEN)
.enableFeature(google.picker.Feature.MULTISELECT_ENABLED)
.setAppId(appId)
.setOAuthToken("{{ token|escape }}")
.addView(view)
.addView(new google.picker.DocsUploadView())
.setDeveloperKey(developerKey)
.setCallback(pickerCallback)
.build();
picker.setVisible(true);
}
// A simple callback implementation.
function pickerCallback(data) {
// makes an ajax call....
}
</script>
<!-- The Google API Loader script. -->
<script type="text/javascript" src="https://apis.google.com/js/api.js"></script>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.1.1/jquery.min.js"></script>
我的 accessToken 可在{{ token|escape }}
.
当我尝试单击“添加新文档”按钮时,出现以下错误。
未捕获的 ReferenceError:google 未在 createPicker 中定义
我不知道这是为什么。我没有正确使用访问令牌吗?
顺便说一句,我需要使用服务器端技术来处理 accessToken 业务,因为我有多个子域,你不能在 Google Dev Console 中使用通配符。因此,我不能只使用像这样的标准示例来通过客户端进行身份验证。
PS - 显然,在上面的代码块中,这些不是我真正的令牌/秘密。他们已经改变了。