以下のような、フォームから名前とコメントを入力して送信するWEBアプリケーションを作りました。
使用したデータベースは「online_bbs」と言う名前で、それぞれのパラメータは以下の画像のように設定されています。
そして以下のようなテーブルを作成しました。
直接MySQLからINSERT文でデータを入れる分には文字化けはしないのですが、
以下のように内容を送信すると、
送信された内容が文字化けしてしまいます。
また、ソースコードは、以下の通りです。
// 登録処理 $link = mysqli_connect('localhost', 'root', ''); if(!$link){ die('cannot connect database: '.mysqli_error()); } mysqli_select_db($link,'online_bbs'); $errors = array(); if($_SERVER['REQUEST_METHOD'] === 'POST'){ $name = null; if(!isset($_POST['name']) || !strlen($_POST['name'])){ $errors['name'] = 'Please write your name.'; } else if(strlen($_POST['name']) > 40){ $errors['name'] = 'Please write your name in 40.'; } else { $name = $_POST['name']; } echo $_POST['name']."<br>"; // 確認用 $comment = null; if(!isset($_POST['comment']) || !strlen($_POST['comment'])){ $errors['comment'] = 'Please write comment.'; } else if(strlen($_POST['comment']) > 200){ $errors['comment'] = 'Please write comment in 200.'; } else{ $comment = $_POST['comment']; } echo $_POST['comment']; // 確認用 if(count($errors) === 0){ $sql = "insert into `post` (`name`, `comment`, `created_at`)"; $sql .= "values('". mysqli_real_escape_string($link, $name)."',"; $sql .= "'". mysqli_real_escape_string($link, $comment)."',"; $sql .= "'". date('Y-m-d H:i:s')."')"; mysqli_query($link, $sql); } } ?> /* フォーム */ <html lang="ja"> <head> <meta http-equiv="content-type" content="test/html" charset="utf-8"> <title>BBS</title> </head> <body> <h1>BBS</h1> <form action="bbs.php" method="post"> name: <input type="text" name="name"/><br/> comment: <input type="text" name="comment" size="60"/><br/> <input type="submit" name="submit" value="submit"> </form> </body> </html>
phpmyadminでinsert処理をしたところ、以下の画像のようになりました。
php.iniの設定は、
- mbstring.language = Japanese
- mbstring.internal_encoding = UTF-8
- mbstring.http_input = auto
- mbstring.http_output = SJIS
- mbstring.encoding_translation = On
- mbstring.detect_order = auto
です。
何か忘れている設定などがあれば、ご教授いただきたいです。
回答2件
あなたの回答
tips
プレビュー