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

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

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

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

PHP

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

Q&A

3回答

1469閲覧

ログインページのエラー

kacz-

総合スコア16

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

PHP

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

0グッド

0クリップ

投稿2017/06/06 06:21

###前提・実現したいこと
phpとmysqlでログインページの作成をしており、メールを送信しようとしたところ下記のエラーが出ます。対処方があればよろしくお願いいたします。

###発生している問題・エラーメッセージ
23行目の $result = mysqli_query($query); の部分にエラーが発生しておりますがどのように解決したらよろしいでしょうか。

Warning: mysqli_query() expects at least 2 parameters, 1 given in /Applications/XAMPP/xamppfiles/htdocs/members/regist/email_regist.php on line 23

###該当のソースコード

<?php /******************************************************************************* * * [mail_regist.php] ユーザの仮登録と登録ページURLの送信 * ********************************************************************************/ /*フォームからメールアドレスを取得*/ $email = $_POST["email"]; /*エラーメッセージ配列*/ $error = array(); /*データベースに接続*/ require_once("db.php"); /*メールアドレス入力チェック*/ if($email == "") { //未入力の場合、エラーを返す //エラー配列に値を代入 array_push($error, "メールアドレスを入力してください。"); //エラー配列に値を代入 } else { //仮ユーザーIDの生成 $pre_user_id = uniqid(rand(100,999)); $query = "insert into members(pre_userid,email) values('$pre_user_id','$email')"; //SQL文を発行 $result = mysqli_query($query); /*データベース登録チェック*/ if($result == false) { array_push($error,"データベースに登録できませんでした。"); //エラー配列に値を代入 } else { /*取得したメールアドレス宛にメールを送信*/ mb_language("japanese"); //言語の設定 mb_internal_encoding("utf-8");//内部エンコーディングの設定 $to = $email; $subject = "会員登録URL送信メール"; $message = "以下のURLより会員登録してください。\n". "http://localhost:8888/members/regist/index.php?pre_userid=$pre_user_id"; $header = "From:test@test.com"; if(!mb_send_mail($to, $subject, $message, $header)) { //メール送信に失敗したら array_push($error,"メールが送信できませんでした。<br><a href='http://localhost:8888/members/regist/index.php?pre_userid=$pre_user_id'>遷移先</a>"); //エラー配列に値を代入 } } } /*エラーがあるかないかによって表示の振り分け($error配列の確認)*/ if(count($error) > 0) { //エラーがあった場合 /*エラー内容表示*/ foreach($error as $value) { ?> <table> <caption>メールアドレス登録エラー</caption> <tr> <td class="item">Error:</td> <td><?php print $value; ?></td> </tr> </table> <?php } //foreach文の終了 } else { //エラーがなかった場合 ?> <table> <caption>メール送信成功しました。</caption> <tr> <td class="item">送信先メールアドレス:</td> <td><?php print $email ?></td> </tr> </table> <?php } ?>

###試したこと
課題に対してアプローチしたことを記載してください

###補足情報(言語/FW/ツール等のバージョンなど)
より詳細な情報

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

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

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

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

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

guest

回答3

0

手続き型のmysqli_query関数は引数が2つ必要です。
http://php.net/manual/ja/mysqli.query.php
現状ですと、第一引数に指定すべきリンクIDがないですね。
そもそもmysqli_connectでデータベースに接続する処理がありません。
リンク先のサンプルを見れば作り方は書いてあると思いますが、おおよその作り方はこんな感じです。

PHP

1// データベース接続 2$link = mysqli_connect("~"); 3// クエリ実行 4$result = mysqli_query($link, "SQL文")

投稿2017/06/06 06:30

ttyp03

総合スコア16998

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

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

0

手続き型なら、mysqli_query関数の第一引数にはmysqli_connect関数が返すリンクIDを渡す必要がありますよ。そもそも、どこでデータベースに接続してるんですか?

$link = mysqli_connect('localhost', 'user', 'passwd', 'db'); $result = mysqli_query($link, $query);

投稿2017/06/06 06:27

編集2017/06/06 06:47
退会済みユーザー

退会済みユーザー

総合スコア0

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

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

kacz-

2017/06/06 06:46

すいません。php初心者です。 db.phpを作ってその中に下記のように入れました。 <?php $link = mysqli_connect("localhost", "123", "pa", "dbname"); ?> のような形でデータベースに接続してます。
退会済みユーザー

退会済みユーザー

2017/06/06 06:48 編集

返信ありがとうございます。 > db.phpを作ってその中に下記のように入れました。... なるほど。 では、その$linkをmysqli_query関数の第一引数に指定してあげてください。
guest

0

mysqli_query()へのパラメータの渡し方がおかしいです
マニュアルを確認して下さい

投稿2017/06/06 06:25

yambejp

総合スコア114779

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問