En mi cruzada de crear un formulario dinámico para subir el contenido a la base de datos con php que recogiera varios campos incluyendo uno para subir archivos...ya está conseguido!
Ahora me surge la siguiente duda, como puedo hacer para que cuando algún visitante de mi web suba una foto, esta la redimensione al peso correcto, es decir si alguien sube una foto de 300 kb y yo en la base de datos tengo el registro blog que como máximo sirve para 67 kb, como hago para que antes de guardarmela me la rediemnsione a este peso?
Este es mi código actual para insertarla en la base de datos y esta limitado a 67 kb:
Código PHP:
<?php
//Primero, arranca el bloque PHP y checkea si el archivo tiene nombre. Si no fue asi, te remite de nuevo al formulario de inserción:
// No se comprueba aqui si se ha subido correctamente.
if (empty($_FILES['archivo']['name'])){
header("location: formulario.php?proceso=falta_indicar_fichero"); //o como se llame el formulario ..
exit;
}
$filesize = $_FILES['archivo']['size'];
$filetype = $_FILES['archivo']['type'];
//verificamos el tipo de archivo y definimos los que se pueden subir
$type = substr($filetype, (strpos($filetype,"/"))+1);
$types=array("jpeg","gif");
//marcamos el maximo tamaño del archivo a subir
if ( $filesize > 0 && $filesize <= 67000 && in_array($type, $types) ) {
//establece una conexión con la base de datos.
$conexion = mysql_connect("localhost","","") or die("No se pudo realizar la conexion con el servidor.");
mysql_select_db("",$conexion) or die("No se puede seleccionar BD"); // tu_bd es el nombre de la Base de datos .. por siaca.
// archivo temporal (ruta y nombre).
$binario_nombre_temporal=$_FILES['archivo']['tmp_name'] ;
// leer del archvio temporal .. el binario subido.
// "rb" para Windows .. Linux parece q con "r" sobra ...
$binario_contenido = addslashes(fread(fopen($binario_nombre_temporal, "r"), filesize($binario_nombre_temporal)));
// Obtener del array FILES (superglobal) los datos del binario .. nombre, tabamo y tipo.
$binario_nombre=$_FILES['archivo']['name'];
$binario_peso=$_FILES['archivo']['size'];
$binario_tipo=$_FILES['archivo']['type'];
$tipovivienda=$_POST['tipovivienda'];
$ciudad=$_POST['ciudad'];
$poblacion=$_POST['poblacion'];
$email=$_POST['email'];
$telefono=$_POST['telefono'];
$precio=$_POST['precio'];
$habitaciones=$_POST['habitaciones'];
$banos=$_POST['banos'];
$m2=$_POST['m2'];
$cliente=$_POST['cliente'];
$estado=$_POST['estado'];
$opcion=$_POST['opcion'];
$descripcion=$_POST['descripcion'];
//insertamos los datos en la BD.
$consulta_insertar = "INSERT INTO propiedades (referencia, archivo_binario, archivo_nombre, archivo_peso, archivo_tipo, idvivienda, idciudad, poblacion, email, telefono, precio, habitaciones, banos, m2, cliente, estado, opcion, descripcion) VALUES ('', '$binario_contenido', '$binario_nombre', '$binario_peso', '$binario_tipo', '$tipovivienda', '$ciudad', '$poblacion', '$email', '$telefono', '$precio', '$habitaciones', '$banos', '$m2', '$cliente', '$estado', '$opcion', '$descripcion')";
mysql_query($consulta_insertar,$conexion) or die("No se pudo insertar los datos en la base de datos.");
header("location: listar_imagenes.php"); }else{ header("location: formulario.php?proceso=el archivo no puede ser mayor de 67 kb o es un formato no compatible"); }//o como se llame el formulario ..
exit;
?>