コメントで、データをmysqlにアップロードして保存する方法を尋ねます。だからここにあります:
ファイルを取得するには、html に次のようなスクリプトを含める必要があります。
<html>
<body>
<form action="upload_file.php" method="post" enctype="multipart/form-data">
<label for="file">Filename:</label>
<input type="file" name="file" id="file"><br>
<input type="submit" name="submit" value="Submit">
</form>
</body>
</html>
POST では、PHP ファイルは次のようになりますが、ファイルが POST に存在するかどうかを確認する必要があることに注意してください。
if ($_FILES["file"]["error"] > 0)
{
echo "Error: " . $_FILES["file"]["error"] . "<br>";
}
else
{
echo "Upload: " . $_FILES["file"]["name"] . "<br>";
echo "Type: " . $_FILES["file"]["type"] . "<br>";
echo "Size: " . ($_FILES["file"]["size"] / 1024) . " kB<br>";
echo "Stored in: " . $_FILES["file"]["tmp_name"];
}
"Stored in:" の部分は単なる一時パスであるため、 move_uploaded_file()を使用して「実際の」画像パスに移動する必要があります。画像の実際の/デフォルトのパスが次の場所にあるとしましょう:
$image_dir= '/images/';
これを使用してファイルを移動するだけです:
move_uploaded_file($_FILES['uploaded_file']['tmp_name'], $image_dir. $_FILES['uploaded_file']['name']);
そして、画像へのフルパスは次のようになります
$image = $final_save_dir . $_FILES['uploaded_file']['name'];
データベースへのパスを保存するには、いくつかの方法があります。
1番目:ファイル名だけを保存し、PHPで画像の$_SERVER['DOCUMENT_ROOT']
パスとデフォルトの画像パスを次のように連結します。
$sql="insert into employee_detail( emp_image, employee_name, employee_address,
employee_contact, employee_designation, employee_salary)
values( '$image', '$_POST[employee_name]', '$_POST[employee_address]', '$_POST[employee_contact]',
'$_POST[employee_designation]','$_POST[employee_salary]')";
2番目:次のようなフルパスを保存することです:
$sql="insert into employee_detail( emp_image, employee_name, employee_address,
employee_contact, employee_designation, employee_salary)
values( '".$_SERVER['DOCUMENT_ROOT']."\\images\\".$image."', '$_POST[employee_name]', '$_POST[employee_address]', '$_POST[employee_contact]',
'$_POST[employee_designation]','$_POST[employee_salary]')";
私がお勧めするのは、後で展開する際に問題が発生しないように、部分パス(ルートディレクトリなし) を入力するこのアプローチです。
$sql="insert into employee_detail( emp_image, employee_name, employee_address,
employee_contact, employee_designation, employee_salary)
values( 'images\\".$image."', '$_POST[employee_name]', '$_POST[employee_address]', '$_POST[employee_contact]',
'$_POST[employee_designation]','$_POST[employee_salary]')";
そして、画像がそのデフォルトの画像 dir/pathに正常にアップロードされていることを確認してください。
アップデート
また、SQL インジェクションを防ぐために、mysqli_*
またはメソッド /function をPDO
使用することをお勧めします。prepare()