Googleサインイン を自分のWebアプリに統合しようとしています。
私のページにはGoogleボタンがあります:
ModalDialogue.cshtml:
<a class="google g-signin2" data-onsuccess="onSignIn">Sign up with Google+</a>
私は自分のjsでそのメソッドをトリガーしようとしています:
ModalDialogue.js:
function onSignIn(googleUser) {
var profile = googleUser.getBasicProfile();
console.log('ID: ' + profile.getId()); // Do not send to your backend! Use an ID token instead.
console.log('Name: ' + profile.getName());
console.log('Image URL: ' + profile.getImageUrl());
console.log('Email: ' + profile.getEmail());
}
そんなこと知ってる
a] JavaScriptはページの範囲内にあります。これは、ダイアログを開いたり閉じたりするための他の関数が機能するためです。
b]ボタンはGoogleと通信しています。クリックすると、[Googleでサインイン]ダイアログが開き、完了したら、ボタンが[サインイン]に変更されます。
OnSignInメソッドをトリガーするにはどうすればよいですか?または、少なくとも、成功がトリガーされているかどうかを判断するにはどうすればよいですか?
ああ。私の悪い。メソッドがクロージャにラップされていることに気づいていませんでした。グローバルである必要があります。
将来このページにアクセスする人のために、関数定義をボタンタグの上に移動する必要がありました。データの成功は単なる文字列であるため、問題ではないようです。残念ながら、エラーメッセージはスローされませんでした。
<html lang="en">
<head>
<meta name="google-signin-scope" content="profile email">
<meta name="google-signin-client_id" content="YOUR_CLIENT_ID.apps.googleusercontent.com">
<script src="https://apis.google.com/js/platform.js" async defer></script>
</head>
<body>
<div class="g-signin2" data-onsuccess="onSignIn" data-theme="dark"></div>
<script>
function onSignIn(googleUser) {
// Useful data for your client-side scripts:
var profile = googleUser.getBasicProfile();
console.log("ID: " + profile.getId()); // Don't send this directly to your server!
console.log('Full Name: ' + profile.getName());
console.log('Given Name: ' + profile.getGivenName());
console.log('Family Name: ' + profile.getFamilyName());
console.log("Image URL: " + profile.getImageUrl());
console.log("Email: " + profile.getEmail());
// The ID token you need to pass to your backend:
var id_token = googleUser.getAuthResponse().id_token;
console.log("ID Token: " + id_token);
}
</script>
</body>
</html>
for info for info