PDOを使ってXampp環境(ローカル環境)でPHPとHTMLでテキストが投稿できる掲示板を作成できたのですが、テキストしか投稿できません、画像や動画も投稿できるようにするためには、次のPHP+HTMLプログラムをどう修正すれば良いでしょうか?
<form action="" method="post" enctype="multipart/form-data">
<input type="hidden" name="MAX_FILE_SIZE" value="">
<input type="file" name="image">
<input type="submit" value="upload">
</form>
ただ単に上記のHTMLを挿入するだけではもちろん画像は投稿できません。
動画は難しいなら画像だけでもいいので投稿できるようにプログラムを修正したいです。
よろしくお願いします。
<?php
include_once("./app/database/connect.php");
if(isset($_POST["submitButton"])){
//スーパーグローバル変数 $_POSTを使う username=キー//
//$username=$_POST["username"];
//var_dump($username);
//$username=$_POST["bodycomment"];
//var_dump($username);
$post_date = date("Y-m-d H:i:s");
$sql = "INSERT INTO `comment` (`username`, `bodycomment`, `post_date`) VALUES (:username, :bodycomment, :post_date);";
$statement = $pdo->prepare($sql);
//値をセットする :username,:bodycomment,:post_dateの中に値をセットする
$statement->bindParam(":username", $_POST["username"], PDO::PARAM_STR);
$statement->bindParam(":bodycomment", $_POST["bodycomment"], PDO::PARAM_STR);
$statement->bindParam(":post_date", $post_date, PDO::PARAM_STR);
$statement->execute();
}
$comment_array = array();
//DBからデータを取ってくるSQL文//
//commentDBでのデータをテーブルから取得する
$sql = "SELECT * FROM comment";
$statement = $pdo->prepare($sql);
$statement->execute();
$comment_array = $statement;
//var_dump($comment_array->fetchAll());
?>
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<link rel="stylesheet" href="./assets/css/style.css">
</head>
<body>
<header>
<h1 class="title">mybbs<h1>
<hr>
</header>
<!-- thread -->
<div class="threadWrapper">
<div class="childWrapper">
<div class="threadTitle">
<span>【Title】</span>
<h1> I tried to create my bbs </h1>
</div>
<section>
<?php foreach($comment_array as $comment) :?>
<article>
<div class="wrapper">
<div class="nameArea">
<span>name:</span>
<p class="username"><?php echo $comment["username"]; ?></p>
<time>:<?php echo $comment["post_date"]; ?></time>
</div>
<p class="comment"><?php echo $comment["bodycomment"]; ?></p>
</div>
</article>
<?php endforeach ?>
</section>
<form class="formwrapper" method="POST">
<div>
<input type="submit" value="書き込む" name="submitButton">
<label>名前:</label>
<input type="text" name="username">
</div>
<textarea class="commenttextArea" name="bodycomment"></textarea>
</div>
</form>
</div>
</body>
</html>
A 回答 (3件)
- 最新から表示
- 回答順に表示
No.3
- 回答日時:
一般に画像や動画を扱うと保存容量や帯域使用量が増大するので、
運用時にかかる経費を考慮した上での設計としましょう。
案1.
投稿物をバイナリとして PDO で保存
バイナリ表示専用の PHP を用意し PDO から読み取り表示
表示例) <img src="/表示.php?id=12345">
案2.
容量面の経費削減を目指すなら
ストレージサービスを用意し投稿物を保存したリンク先のみ PDO で保存
バイナリ表示専用の PHP を用意しリンク先から転送して表示
表示例) <img src="/転送表示.php?id=12345">
案3.
帯域使用量削減を目指すなら
ストレージサービスのリンク先を直接表示させる
表示例) <img src="https://サービス.com/表示/12345.jpg">
案4.
一切の運用経費を掛けないなら
投稿物のバイナリを保存せず、画像や動画の URL だけを投稿させる
CSRF 対策として URL 先のチェックが必要
表示例) 動画は youtube の URL のみ許容し埋め込み表示
参考)
PHP でのファイルアップロードの処理
https://www.php.net/manual/ja/features.file-uplo …
PDO でバイナリを取り扱う
https://www.php.net/manual/ja/pdo.lobs.php
ストレージサービスを PHP で操作
https://cloud.google.com/php/docs/reference/clou …
youtube の埋め込み
https://developers.google.com/youtube/iframe_api …
CSRF の対策
https://www.ipa.go.jp/security/vuln/websecurity/ …
No.2
- 回答日時:
PHP側でinput系の関数か$File系のスーパーグローバル変数を使ってtmpフォルダなどに作成される画像データをムーブするかコピーするか何かしらしないと行けないです。
バイナリを直接DBに入れてもいいけど
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- PHP htmlのエラーについて(デバッグ) 1 2023/11/13 20:54
- HTML・CSS CSSが効かずどのように指定すれば良いか分からないのでアドバイスお願い致します 2 2023/06/07 12:25
- JavaScript ①入力フォーム→②確認表示画面→③送信完了画面のコードを書いているのです、 入力フォームから受け取っ 2 2022/05/10 16:45
- CGI perlで書いたcgiでsqliteの使い方を教えてください 2 2023/05/08 21:29
- PHP PHPでCookieを使った訪問回数について 1 2023/05/28 14:10
- JavaScript Q&A掲示板の入力フォームに文字数制限を設けて入力可能な文字数を表示したい 1 2024/04/08 02:46
- PHP PHP MySql 画像を取得 1 2022/06/04 14:05
- HTML・CSS ボタンをクリックした時に、入力フォームのすぐ下部に、「入力欄が空白です」というテキストメッセージが表 1 2022/04/27 16:25
- JavaScript 入力フォームの javascript で メールアドレスの正規チェックをを行い、ボタンをクリックして 2 2022/04/27 16:06
- JavaScript clear機能を失わずにファイルアップロード機能を作成したい 3 2023/06/10 16:12
このQ&Aを見た人はこんなQ&Aも見ています
-
性格の違いは生まれた順番で決まる?長男長女・中間子・末っ子・一人っ子の性格の傾向
同じ環境で生まれ育っても、生まれ順で性格は違うものなのだろうか。家庭教育研究家の田宮由美さんに教えてもらった。
-
プログラミング言語の制作方法について
C言語・C++・C#
-
なんでブラウザでPHPを動かすためだけにOSにPython2(Python3)を入れて、C(GCC)
PHP
-
システムエンジニアの適正について
C言語・C++・C#
-
-
4
Notepad++の関数リスト表示の変更方法をお教えください。
C言語・C++・C#
-
5
プログラミングを教えたいです。そういうSNSないですか?
その他(プログラミング・Web制作)
-
6
php配列のキーの二重定義 $a['zero'],$a['iti']と$a[0],$a[1]とが同等
PHP
-
7
mallocについて
C言語・C++・C#
-
8
プログラミング言語で、使えるクラス沢山ありますが、以下のようなクラスってなんて名前ですか? 例えば1
PHP
-
9
オブジェクト指向プログラミングにおいて Aというクラスと Bというプロパティ(ゲッターとセッターはこ
その他(プログラミング・Web制作)
-
10
[初心者]javascriptのfor文でなぜか繰り返し処理をしない。理由がわかりません。
JavaScript
-
11
index.phpって何ですか? 具体的に教えてください
PHP
-
12
プログラム言語について。
その他(プログラミング・Web制作)
-
13
javaScriptのコードの修正をお願いします。
JavaScript
-
14
PHPでこのコード自体に意味は無いんですけど、上のifと下のifの違いってなんですか?個人的には下の
PHP
-
15
C言語関数違いについて。
C言語・C++・C#
-
16
C言語について。
C言語・C++・C#
-
17
パイソンの
C言語・C++・C#
-
18
変数名をどのようにつけるのが良いかアドバイスお願い致します
JavaScript
-
19
Notepad++の関数リスト表示でC言語のプログラムが正しく表示できない。
C言語・C++・C#
-
20
スカラーのベクトル微分
その他(プログラミング・Web制作)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
PHP ボタンが押されたら処理を...
-
PHPで画像の渡しが上手く行きま...
-
PEAR auth で認証ができません
-
フォームボタンを押すたびに数...
-
HTMLで前の画面に戻る時、入力...
-
検索時の選択内容を保持する方法
-
POSTやGETの変数をフォーム無し...
-
Javascript→PHPに...
-
入力フォーム→確認画面→送信画...
-
チェックボックスのvalueを連結...
-
php mysql でチェックボックス...
-
formに複数ボタンを配置し、そ...
-
PHPでフォームから任意の画像削...
-
フォームへの前回入力値をクリ...
-
降順ソートができません。
-
PHPのmysqlに格納したデータの...
-
PHPの関数実行
-
HTMLのリンクをクリックするこ...
-
PHPで動的URLを静的URLに変換す...
-
データ検索のエラーについて
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
<input type="hidden" >で配列...
-
HTMLで前の画面に戻る時、入力...
-
PHPでユーザー情報を入力して簡...
-
PHP ボタンが押されたら処理を...
-
PHPとHTML+Xamppの掲示板で画像...
-
syntax error, unexpected '}' ...
-
検索時の選択内容を保持する方法
-
PHPでCookieを使った訪問回数に...
-
チェックボックスによる検索
-
PHPで画像の渡しが上手く行きま...
-
フォームでのリセットを使う方法
-
チェックボックスによる検索(...
-
フォームへの前回入力値をクリ...
-
フォームボタンを押すたびに数...
-
php mysql でチェックボックス...
-
PHPの関数実行
-
PHPで、ボタンを押すと同じペー...
-
phpで分からないエラーが出てし...
-
ラジオボタンをsessionで使いたい
-
入力フォーム→確認画面→送信画...
おすすめ情報