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

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

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

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

Q&A

2回答

1385閲覧

PHPでログイン機能

Roo

総合スコア55

PHP

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

0グッド

1クリップ

投稿2018/08/31 11:21

編集2018/08/31 14:29

前提・実現したいこと

拙い内容ご容赦下さい。

phpでのログイン機能を作成中
セッションは一旦放置し、
DBの内容と入力値の内容を比較したいです。

DBテーブル定義
id AUTO_INCREMENT
userid ・・・hoge
password・・・hoge

定義済みのテーブルの”userid”"password"
入力値が合っていれば→マイページ
間違っていれば→エラーページ
としたいです。

入力値とDBをどう比較していいかわかりません。
やり方を教えていただけると幸いです。
ここに質問の内容を詳しく書いてください。

phpここに言語名を入力
ソースコード

<?php $ui = 'userid'; $_Pw = 'password'; $db['host'] = "localhost"; $db['userid'] = "hoge"; $db['pass'] = "hoge"; $db['dbname'] = "hoge"; echo "start"; $db = new PDO ('mysql:host=localhost;dbname=hoge;charset=utf8','hoge','hoge'); ?> <!DOCTYPE html> <html lang = "jpa"> <head> <meta charset = "utf-8"> <title>login</title> <link rel="stylesheet" href="test1.css"> </head> <body>
<form action="login4.php" method="POST"> <div class="parent"> <h1>login</h1> <p>UserIDとPasswordを入力してください。</p> <table> <tr> <td>User ID</td> <td><input type="text" name="$ui" value="<?php echo htmlspecialchars($ui); ?>"></td> </tr>
<p> <?php if (isset($_GET["click_sum"])){ } ?> </p>
<p><input type="submit" name="click_sum" onclick="submit" value="マイページへ"></p> </div> </form>
</body> </html>

試したこと

//$sql = 'select * FROM "データベース名" WHERE userid = ? password = ?';

//$array = array();
//$array[] = ("$ui" && "$_Pw");

//$new = $db->exec($sql,$array);

ここに問題に対して試したことを記載してください。

補足情報(FW/ツールのバージョンなど)

どうすれば入力値とDBの内容をひかくできますか?
ここにより詳細な情報を記載してください。

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

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

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

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

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

m.ts10806

2018/08/31 13:59

プログラムコード(およびエラーメッセージ)は質問内容としては最も重要な部分であるため、見やすくしていただけると助かります。<code>ボタン押下→「コード」部分にコードを貼り付け→「ここに言語を入力」に対象言語名記入(エラーメッセージの場合は不要)の手順で「コードハイライト化」してください。(質問編集画面ではリアルタイムでプレビューが表示されるので見ながら調整してください)
m.ts10806

2018/08/31 14:00

入力した情報をDBと比較というのは比較的ありふれた内容なので検索すれば簡単なコードは幾らでも出てきそうに思いますが、何か参考にしたこと、どう調べたかとかありますか?現在提示されているコードの問題点は何でしょう?
Roo

2018/08/31 14:25

そうなんですが、、、実力不足かな実装できずです。。。参考は全てネットの文献だったため、理解及ばず。現在提示されているコードの問題点というよりも、比較する関数の使い方がわからなく、【試したこと】に記載した、変数に入力値を入れ、その変数が一致するかを調べたかったのですが、反映されませんでした。
m.ts10806

2018/08/31 14:40

1つ目のコメントで指摘したコードハイライト対応お願いしますね。
m.ts10806

2018/08/31 14:46

質問は質問者さんのみ編集できるので。
Roo

2018/09/01 03:53

失礼いたしました、もう少し勉強し直してから、ご質問させていただきます。
m.ts10806

2018/09/01 04:07

コードブロックの対応だけでもやっておきませんか?なぜそうするか分かると思います
guest

回答2

0

全て一気にやるからではないでしょうか?
コピペのつなぎ合わせではおそらくいつまでたっても完成しません。
phpに限らずですが、Hello Worldからが原則です。
そのあとは変数・簡単な関数、文字列の操作、ループ処理。

入力値を取得して云々はそれらが出来てからです。
POST,GETなど「クライアントからのリクエストを送信」(リクエスト)についても知らなければなりません。
DBとの比較は更に1つ先です。

ちなみにそれぞれについてはPHPマニュアルに説明と簡単なコードは載っています。
ネットの記事をつなぎ合わせたツギハギなコードよりは基本から学んでください。

ここでミニマムでもサンプルコードを提示するのは非常に簡単です。
でもそれでは「できた気」になってしまって質問者さんは何一つ成長できません。
なぜなら「できた」コードはあくまで人が書いたものであり自身で考えて作ったものではないからです。
書いたコードを質問者さんが理解できなければ(または理解しようという姿勢がなければ)そのコードは無駄になってしまいます。

今自身のコードに起きている問題は何なのか。
エラーは起きていないか。画面に何も表示されてないならエラー表示設定がOnになってないから。
ではエラーが起きていればそれはどういう意味なのか、
コードの流れ上どこまで正しく通っているか。
「デバッグ」は必ずできるようにならないといけません。
基本のキです。デバッグ覚えないとプログラミングは進められません。

「プログラムは指示したとおりにしか動かない」ということを理解できているか?というところもどこまで理解しているかというところも気にはなりますが、
やらなければならないのはネット上のコードを参考にコピペで作りたいものを作るのではなく、基本から覚えていくことです。
時間はかかって当然でしょう。ただし急がば回れです。理解が浅いままなんとなく進めていては、近いうちに壁にぶちあたって跳ね返されて挫折するのが落ちです。

基礎体力も何もないままフルマラソンを走りきることはできません。
じゃあ練習だといきなり走り始めますか?ストレッチから始めません?
質問者さんは今どの段階でしょうか。よく考えて、先を見据えたうえで今やるべきことをやってください。

投稿2018/08/31 14:50

m.ts10806

総合スコア80850

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

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

Roo

2018/09/01 03:52

失礼いたしました。 もう少し勉強し直してから、再度質問させていただきます。
m.ts10806

2018/09/01 04:06

質問するのは悪いことではないのですが、本来必要なことをやらずにコードだけもらっても根本的な解決にならないことご理解ください。
guest

0

セッションは一旦放置し、

DBの内容と入力値の内容を比較したいです。

セッションのないログインはほぼ成り立たないですが大丈夫ですか?
ログアウトのないBasic認証を利用してみてはどうでしょうか?

投稿2018/08/31 11:39

yambejp

総合スコア114829

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問