17/07/2009, 00:58
|
| | Fecha de Ingreso: julio-2009 Ubicación: Villa Alemana
Mensajes: 2
Antigüedad: 15 años, 4 meses Puntos: 0 | |
Respuesta: se puede aumentar campos a insertar con php ??? Hola ,
Sabes tengo el mismo problema que tu, por esas cosas de la vida y por lo que me ha tocado buscar en la web me encontre con parte de tu solucion, sin embargo me falta la otra parte que es la forma que se grabe en la base de datos.
el codigo que tengo y que no es mio, da la posibilidad de ir agregando mas informacion a demanda del visitante.
El codigo se compone de un formulario para ir agregando archivos los cuales se envian a una carpeta en especifico, lo cual lo hace bastante bien, pero el tema es como los guardo en la base de datos...
Se me ha ocurrido que en el mismo "for" se agregue la info a la base de datos, pero como soy algo novicio en el tema de programacion no se si estara bien escrito o exista otra manera de hacerlo.
Este codigo es el formulario.
<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
<title>Documento sin título</title>
</head>
<script type="text/javascript">
var numero = 0; //Esta es una variable de control para mantener nombres
//diferentes de cada campo creado dinamicamente.
evento = function (evt) { //esta funcion nos devuelve el tipo de evento disparado
return (!evt) ? event : evt;
}
//Aqui se hace lamagia... jejeje, esta funcion crea dinamicamente los nuevos campos file
addCampo = function () {
//Creamos un nuevo div para que contenga el nuevo campo
nDiv = document.createElement('div');
//con esto se establece la clase de la div
nDiv.className = 'archivo';
//este es el id de la div, aqui la utilidad de la variable numero
//nos permite darle un id unico
nDiv.id = 'file' + (++numero);
//creamos el input para el formulario:
nCampo = document.createElement('input');
//le damos un nombre, es importante que lo nombren como vector, pues todos los campos
//compartiran el nombre en un arreglo, asi es mas facil procesar posteriormente con php
nCampo.name = 'archivos[]';
//Establecemos el tipo de campo
nCampo.type = 'file';
//Ahora creamos un link para poder eliminar un campo que ya no deseemos
a = document.createElement('a');
//El link debe tener el mismo nombre de la div padre, para efectos de localizarla y eliminarla
a.name = nDiv.id;
//Este link no debe ir a ningun lado
a.href = '#';
//Establecemos que dispare esta funcion en click
a.onclick = elimCamp;
//Con esto ponemos el texto del link
a.innerHTML = 'Eliminar';
//Bien es el momento de integrar lo que hemos creado al documento,
//primero usamos la función appendChild para adicionar el campo file nuevo
nDiv.appendChild(nCampo);
//Adicionamos el Link
nDiv.appendChild(a);
//Ahora si recuerdan, en el html hay una div cuyo id es 'adjuntos', bien
//con esta función obtenemos una referencia a ella para usar de nuevo appendChild
//y adicionar la div que hemos creado, la cual contiene el campo file con su link de eliminación:
container = document.getElementById('adjuntos');
container.appendChild(nDiv);
}
//con esta función eliminamos el campo cuyo link de eliminación sea presionado
elimCamp = function (evt){
evt = evento(evt);
nCampo = rObj(evt);
div = document.getElementById(nCampo.name);
div.parentNode.removeChild(div);
}
//con esta función recuperamos una instancia del objeto que disparo el evento
rObj = function (evt) {
return evt.srcElement ? evt.srcElement : evt.target;
}
</script>
<?php
$variable= $_GET["cod"];
echo "Proceso de Carga de Imagenes para Codigo ".$variable."";
?>
<body>
<form name="formu" id="formu" action="upload.php" method="post" enctype="multipart/form-data">
<dl>
<dt><label>Archivos a Subir:</label>
<input name="cod" type="hidden" id="cod" value="<?php echo $variable ?>" />
</dt>
<!-- Esta div contendrá todos los campos file que creemos -->
<dd><div id="adjuntos">
<!-- Hay que prestar atención a esto, el nombre de este campo debe siempre terminar en []
como un vector, y ademas debe coincidir con el nombre que se da a los campos nuevos
en el script -->
<input type="file" name="archivos[]" /><br />
</div></dd>
<dt><a href="#" onClick="addCampo()">Subir otro archivo</a></dt>
<dd><input type="submit" value="Enviar" id="envia" name="envia" /></dd>
</dl>
</form>
</body>
</html> Luego esta el codigo que procesa la info.
<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
<title>Documento sin título</title>
</head>
<?php
$cd = $_POST['cod'];// recogo la variable la que ocupare para discriminar el update
$destino= 'flagla';// este es mi directorio al cual se van las fotos
//Preguntamos si nuetro arreglo 'archivos' fue definido
if (isset ($_FILES["archivos"])) {
//de se asi, para procesar los archivos subidos al servidor solo debemos recorrerlo
//obtenemos la cantidad de elementos que tiene el arreglo archivos
$tot = count($_FILES["archivos"]["name"]);
//este for recorre el arreglo
for ($i = 0; $i < $tot; $i++){
//con el indice $i, poemos obtener la propiedad que desemos de cada archivo
//para trabajar con este
$tmp_name = $_FILES["archivos"]["tmp_name"][$i];
$name = $_FILES["archivos"]["name"][$i];
move_uploaded_file ( $_FILES [ 'archivos' ][ 'tmp_name' ][$i], $destino . '/' . $_FILES [ 'archivos' ][ 'name' ][$i]);
//Hasta aqui el scrip graba el archivo en el directorio de mi servidor a traves de un bucle hecho //por el for. Sin embargo se me ocurre aprovecharme de esto para tambien grabar en la base //de datos el nombre del archivo. En mi caso particular tengo 8 campos para fotos lo que //corresponden a un registro, sin embargo como solo hace un par de meses me ido metiendo //en el tema de php aun no lo domino muy bien la manera de ingresar la sentencia, por lo que //pido las disculpas por quizas la aberracion que pueden ver mas abajo.
//En mi caso los campos se llaman dt los que van enumerados del 1 al 8, mi intencion es que //al incrementarse el valor de "$i" en en for tambien cambie el valor del campo en el update, //algo asi como una asignacion dinamica para la actualizacion en la tabla.Sin embargo aun no //lo he podido lograr..
mysql_connect("server", "user","password");
mysql_select_db("database");
mysql_query("Update catalogo set ['dt'][$i]='".$name."' where cod='".$cd."'");
mysql_close();
}
}
?>
<body>
</body>
</html>
Agradecere a quienes nos puedan ayudar en dar un final feliz a esta consulta de la cual me he colgado.. |