質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.47%
Google サイト

Google サイトは、Google社が提供する無料のホームページ作成ツールです。プログラミングやデザインなどの知識がなくても、ブラウザから容易にWebページを作成することが可能。新たなページの追加も簡単でページ数には制限がありません。

Google Apps Script

Google Apps ScriptはGoogleの製品と第三者のサービスでタスクを自動化するためのJavaScriptのクラウドのスクリプト言語です。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

Q&A

解決済

1回答

216閲覧

GoogleSitesでパラメータ付きでページ遷移させたい

dras

総合スコア2

Google サイト

Google サイトは、Google社が提供する無料のホームページ作成ツールです。プログラミングやデザインなどの知識がなくても、ブラウザから容易にWebページを作成することが可能。新たなページの追加も簡単でページ数には制限がありません。

Google Apps Script

Google Apps ScriptはGoogleの製品と第三者のサービスでタスクを自動化するためのJavaScriptのクラウドのスクリプト言語です。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

2グッド

2クリップ

投稿2024/01/18 07:00

編集2024/01/18 09:35

実現したいこと

GoogleSitesでログインページを作り、ログイン完了後にユーザーIDのパラメータを持ったマイページURLに遷移させたいです。

前提

GoogleSitesで会員ページとログイン機能を実装しようとしています。
現在は以下のところまで実装しています。

・スプレッドシートでユーザー情報(IDとパスワード)管理
・SitesのHTMLフォームで入力したデータをGASで取得
・GASで入力データとスプレッドシートを照らし合わせ、認証させる。
・Sitesにパラメータ付きのURLを渡す。

発生している問題・エラーメッセージ

このまま「location.href = "https://sites.google.com/mysite/mypage?number=00000001" 」でページ遷移をさせようとしたのですが、Googleのセキュリティ的な問題で使えませんでした。

どうしてもこのやり方じゃなきゃいけないわけではないです。(GoogleSitesは必須ですが)
GASでスプレッドシート照らし合わせが終わったのちにパラメータ付きで遷移させたいです。

error

1Refused to frame 'https://sites.google.com/' because an ancestor violates the following Content Security Policy directive: 2 "frame-ancestors https://google-admin.corp.google.com/".

該当のソースコード

Index.html

1<head> 2 <meta charset="UTF-8"> 3 <meta name="viewport" content="width=device-width, initial-scale=1.0"> 4 <title>Google Apps Script Example</title> 5 <script> 6 function updateHello() { 7 number = document.getElementById("number").value; 8 var password = document.getElementById("password").value; 9 google.script.run.withSuccessHandler(updateHelloText).sayHello(number, password); 10 } 11 12 function updateHelloText(text) { 13 if(text === "success"){ 14 console.log("success"); 15 document.getElementById("hello").innerText = "login success"; 16 location.href = "https://sites.google.com/mysite/mypage?number=" + number; 17 }else{ 18 console.log("failed"); 19 document.getElementById("hello").innerText = "login failed"; 20 } 21 } 22 </script> 23</head> 24<body> 25 26<!-- テキストボックス --> 27<div>社員番号</div> 28<input type="text" id="number" placeholder="00200000 8桁"> 29<div>パスワード</div> 30<input type="text" id="password"> 31<!-- ボタンをクリックすると GAS の関数が実行される --> 32<button onclick="updateHello()">ログイン</button> 33 34<!-- テキストを表示するための要素 --> 35<h1 id="hello"></h1> 36</body> 37</html>

login.gs

試したこと

「Googleサイト ページ遷移」「"GoogleSites" location href」などで検索しましたが、GoogleSites以外での遷移などしかヒットしませんでした。

TN8001😄を押しています
murohi👍を押しています

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

TN8001

2024/01/18 09:07

JavaとJavaScriptは全く別の言語です。 「Java」タグは何の関係もないので外してください。 (付けるのであれば)「JavaScript」タグです。
dras

2024/01/18 09:35

コメントありがとうございます。質問を修正したのでご確認よろしくお願いいたします。
guest

回答1

0

自己解決

ページ遷移は諦め、ログインページをそのままマイページとして利用することにしました。
で、ログイン機能は実装したいのでIDとパスワード入力後、ローカルストレージにIDを保存することにしました。

Index.html

1 2if(data === "success"){ 3 localStorage.setItem("id", number); 4} 5 6~~~ 7 8 9 document.addEventListener('DOMContentLoaded', function() { 10 var id = localStorage.getItem("id"); 11 if(id != null){ 12 document.getElementById("status").innerText = "already Login! id:" + id; 13 mypageShow(); 14 }else{ 15 document.getElementById("status").innerText = "login yet"; 16 } 17 });

本来のページ遷移という目的とはずれますが、これならGoogleSitesでログイン機能を実装できると思います。

投稿2024/01/19 06:40

dras

総合スコア2

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.47%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問