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

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

新規登録して質問してみよう
ただいま回答率
85.48%
Cookie

HTTPにおけるCookieとは、クライアントのウェブブラウザ上に保存された一時的なデータを指します。クライアント側のJavaScriptでも、サーバー側のHTTPヘッダーでもクッキーの読み書き・修正・削除が可能です。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

解決済

2回答

8473閲覧

ログイン情報をクッキー平文で保持させないようにするには

dog57

総合スコア131

Cookie

HTTPにおけるCookieとは、クライアントのウェブブラウザ上に保存された一時的なデータを指します。クライアント側のJavaScriptでも、サーバー側のHTTPヘッダーでもクッキーの読み書き・修正・削除が可能です。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

2クリップ

投稿2018/02/21 12:27

ログイン情報をクッキーで保持させるように実装しています。

現状では下記のようなコードなのですが、これだとクッキーに平文でE-mailとパスワードが見えてしまいます。
こういう場合はどうするのが良いでしょうか?

それと、「ログイン情報を保持する」にチェックボックスが入っていた場合に保持させたい場合は、
どのような感じで書けばよいででょうか?

login_form.php

php

1// クッキー情報確認 2if (isset($_COOKIE['email'])) { 3 4 $email = $_COOKIE['email']; 5 $password = $_COOKIE['password']; 6 7}

login_admin.php

php

1// クッキーの設定、同じユーザーが再度ログインする際のE-メール、パスワードを記入する手間を省く 2setcookie("email", $_SESSION["email"], time() + 30); 3setcookie("password", $_SESSION["password"], time() + 30);

イメージ説明

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

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

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

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

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

guest

回答2

0

ベストアンサー

ログイン認証を行うのであればセッションとして使用するCookieには基本的にログインに使用した値を格納してはいけません。

・Cookieにemailとpasswordが平文で格納して欲しくない
・「ログイン情報を保持する」にチェックボックスが入っていた場合に保持させたい

以上の要件を満たすのであれば

login_form.php

if (isset($_POST['email']) && isset($_POST['password'])) { $email = $_POST['email']; $password = $_POST['password']; //以降は認証を行う処理 }

まずlogin_form.phpでフォームからの入力を受け取り、認証に成功すればlogin_admin.phpに値を渡すようにします。

login_admin.php

$session = $password.$email; $sessionid = hash('sha256',$session); setcookie("sessionid", $_SESSION["sessionid"], time() + 3600);

認証に成功した場合にセッションとして使うCookieはサーバー側でハッシュ化した値をレスポンス時のSet-Cookieでユーザに渡すようにします。
DBにアカウント情報を保存している場合はハッシュ化された値を保存しておき、ユーザがPOSTしてきたemail+passwordをハッシュ化したものと比較して認証を行ってください。

また、ログイン時にアカウント情報の入力の手間を省く機能は、基本的にはブラウザ依存で実装します。
以下のようにするとフォーム要素にautocomplete属性を付与できるのでチェックボックスをクリックする度に保持するかどうかを決めることが可能です。

ログインを行う画面のhtml

<body> <form action="login_form.php" method="post"> <input type="text" id="email" name="email"> <input type="password" id="password" name="password"> <input type="checkbox" id="check"><a>Remember me</a> <input type="button" value="login"> </form> <script> var elem = document.getElementById('check'); var email = document.getElementById('email'); var passwd = document.getElementById('password'); elem.addEventListener('change',function(){ if(!email.getAttribute("autocomplete")){ email.setAttribute("autocomplete","on"); passwd.setAttribute("autocomplete","on"); }else{ email.removeAttribute("autocomplete"); passwd.removeAttribute("autocomplete"); } }); </script> </body>

投稿2018/02/21 13:59

編集2018/02/21 14:02
wp-h

総合スコア135

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

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

退会済みユーザー

退会済みユーザー

2018/02/21 14:10

多分 ReMember Me 機能(自動再ログイン) を実装しようとしてるんじゃね
wp-h

2018/02/21 14:43

なるほど、わざわざemailとpasswordを格納したい理由にも納得がいきますね。 単純にログイン認証を省くのであれば Cookieの生存時間を長くして、ログイン中は一定時間でセッションを更新するという実装を行うといった感じですかね
guest

0

投稿2018/02/21 15:09

umyu

総合スコア5846

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問