sql >> Base de Datos >  >> RDS >> Mysql

¿Cómo cargar una imagen PHP e insertar una ruta en MySQL?

En su comentario, pregunta cómo cargar y almacenar los datos en mysql. Así que aquí está:

Para obtener el archivo, debe tener un script en su html como este:

<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>

Ahora, en POST, su archivo PHP debería verse así, pero tenga en cuenta que debe verificar si el archivo existe en su 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"];

  }

Dado que la parte "Almacenado en:" es solo la ruta temporal, debe moverse a la ruta de su imagen 'real' usando mover_archivo_cargado() .Digamos que la ruta real/predeterminada para sus imágenes está en:

$image_dir= '/images/';

Solo tienes que mover el archivo usando esto:

move_uploaded_file($_FILES['uploaded_file']['tmp_name'], $image_dir. $_FILES['uploaded_file']['name']);

Y su ruta completa a la imagen sería

$image = $final_save_dir . $_FILES['uploaded_file']['name'];

Hay varias formas de almacenar la ruta a su base de datos:

Primero:es almacenar solo el nombre de archivo y concatene la ruta de la imagen en PHP usando $_SERVER['DOCUMENT_ROOT'] y su ruta de imagen predeterminada como:

$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º:Es almacenar la ruta completa como:

$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]')";

Lo que recomiendo es este enfoque en el que ingresará la ruta parcial (sin el directorio raíz) para que luego no tengas problema en desplegarlo:

$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]')";

Y asegúrese de que las imágenes se carguen correctamente en esa dirección/ruta de imagen predeterminada .

ACTUALIZAR

También te recomiendo que uses mysqli_* o PDO y usa prepare() método/función para evitar la inyección de sql.