Foros del Web » Programando para Internet » PHP »

Formulario upload

Estas en el tema de Formulario upload en el foro de PHP en Foros del Web. Hola, ¿qué tal? Me preguntaba si podrían ayudarme. Tengo un formulario para subir archivos que, además, debe insertar registros en una base de datos. A ...
  #1 (permalink)  
Antiguo 22/04/2015, 06:19
Avatar de MariaLSS  
Fecha de Ingreso: abril-2015
Ubicación: Madrid
Mensajes: 53
Antigüedad: 9 años
Puntos: 2
Formulario upload

Hola, ¿qué tal?
Me preguntaba si podrían ayudarme. Tengo un formulario para subir archivos que, además, debe insertar registros en una base de datos. A continuación, copio el código del formulario:

Código HTML:
Ver original
  1. <form action="<?php echo $editFormAction; ?>" method="post" name="form4" id="form4" enctype="multipart/form-data">
  2.                 <table align="center">
  3.                     <tr valign="baseline">
  4.                         <td nowrap="nowrap" align="right">Alias:</td>
  5.                         <td><select name="us_alias">
  6.                             <?php
  7. do {  
  8. ?>
  9.                             <option value="<?php echo $row_rs_alias_usuario['us_alias']?>"><?php echo $row_rs_alias_usuario['us_alias']?></option>
  10.                             <?php
  11. } while ($row_rs_alias_usuario = mysql_fetch_assoc($rs_alias_usuario));
  12.  $rows = mysql_num_rows($rs_alias_usuario);
  13.  if($rows > 0) {
  14.       mysql_data_seek($rs_alias_usuario, 0);
  15.       $row_rs_alias_usuario = mysql_fetch_assoc($rs_alias_usuario);
  16.   }
  17. ?>
  18.                         </select></td>
  19.                     </tr>
  20.                     <tr valign="baseline">
  21.                         <td nowrap="nowrap" align="right">Seleccionar documento:</td>
  22.                         <td><input type="hidden" name="MAX_FILE_SIZE" value="1000000" /><input type="file" name="nombre_doc" value="" size="32" /></td>
  23.                     </tr>
  24.                     <tr valign="baseline">
  25.                         <td nowrap="nowrap" align="right">&nbsp;</td>
  26.                         <td><input name="bot" type="submit" id="bot" value="Enviar" onclick="comprueba_extension(this.form, this.form.nombre_doc.value)" /></td>
  27.                     </tr>
  28.                 </table>
  29.                 <input name="fechar" type="hidden" value="" />
  30.                 <input type="hidden" name="MM_insert" value="form4" />
  31.             </form>

Por otro lado tengo este código php para subir los archivos y llevarlos a la base de datos:

  #2 (permalink)  
Antiguo 22/04/2015, 06:22
Avatar de MariaLSS  
Fecha de Ingreso: abril-2015
Ubicación: Madrid
Mensajes: 53
Antigüedad: 9 años
Puntos: 2
Respuesta: Formulario upload

Ufff. Vaya. Se cortó el mensaje anterior. Decía que tengo, además del formulario, el código php para la subida de archivos:

Código PHP:
Ver original
  1. $editFormAction = $_SERVER['PHP_SELF'];
  2. if (isset($_SERVER['QUERY_STRING'])) {
  3.   $editFormAction .= "?" . htmlentities($_SERVER['QUERY_STRING']);
  4. }
  5.  
  6. if ((isset($_POST["MM_insert"])) && ($_POST["MM_insert"] == "form4")) {
  7.    
  8.  
  9.    
  10.    
  11.     /*Codigo w3schools*/
  12. $target_dir = "docs_para_usuarios/";
  13. $target_file = $target_dir . basename($_FILES["nombre_doc"]["name"]);
  14. $uploadOk = 1;
  15. $hoy = getdate();
  16.  
  17.   $insertSQL = sprintf("INSERT INTO docs_para_usuarios (us_alias, nombre_doc, fecha) VALUES (%s, %s,now())",
  18.                        GetSQLValueString($_POST['us_alias'], "text"),
  19.                        GetSQLValueString($target_file, "text"),
  20.                        GetSQLValueString($_POST['fechar'], "date"));
  21.  
  22.   mysql_select_db($database_PML2, $PML2);
  23.   $Result1 = mysql_query($insertSQL, $PML2) or die(mysql_error());
  24. }
  25.  
  26. mysql_select_db($database_PML2, $PML2);
  27. $query_rs_alias_usuario = "SELECT us_alias FROM usuarios_pml";
  28. $rs_alias_usuario = mysql_query($query_rs_alias_usuario, $PML2) or die(mysql_error());
  29. $row_rs_alias_usuario = mysql_fetch_assoc($rs_alias_usuario);
  30. $totalRows_rs_alias_usuario = mysql_num_rows($rs_alias_usuario);
  31. ?>

El caso es que los datos se cargan en la base de datos... pero los archivos no suben... ¿Alguien puede iluminarme sobre cómo hacer?

Gracias de antemano por su tiempo y sus respuestas. Un saludo
  #3 (permalink)  
Antiguo 22/04/2015, 06:47
Avatar de pateketrueke
Modernizr
 
Fecha de Ingreso: abril-2008
Ubicación: Mexihco-Tenochtitlan
Mensajes: 26.399
Antigüedad: 16 años
Puntos: 2534
Respuesta: Formulario upload

¿Y en qué parte de tu código usas move_uploaded_file() para guardar el archivo que se recibe?

No lo veo por ninguna parte, y es requerido, deberías leer el manual: http://php.net/manual/es/features.file-upload.php
__________________
Y U NO RTFM? щ(ºдºщ)

No atiendo por MP nada que no sea personal.
  #4 (permalink)  
Antiguo 22/04/2015, 08:09
Avatar de MariaLSS  
Fecha de Ingreso: abril-2015
Ubicación: Madrid
Mensajes: 53
Antigüedad: 9 años
Puntos: 2
Respuesta: Formulario upload

Ay, un millon de gracias... Voy a probar una cosa

Etiquetas: fecha, formulario, mysql, registro, select, upload
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 04:52.