@@ -46,7 +47,45 @@ class formAddFilm extends Form{
protected function procesaFormulario($datos){
$result = array();
-
+ $ok = count($_FILES) == 1 && $_FILES['archivo']['error'] == UPLOAD_ERR_OK;
+ if ( $ok ) {
+ $archivo = $_FILES['archivo'];
+ $nombre = $_FILES['archivo']['name'];
+ /* 1.a) Valida el nombre del archivo */
+ $ok = $this->check_file_uploaded_name($nombre) && $this->check_file_uploaded_length($nombre) ;
+
+ /* 1.b) Sanitiza el nombre del archivo
+ $ok = $this->sanitize_file_uploaded_name($nombre);
+ */
+
+ /* 1.c) Utilizar un id de la base de datos como nombre de archivo */
+
+ /* 2. comprueba si la extensión está permitida*/
+ $ok = $ok && in_array(pathinfo($nombre, PATHINFO_EXTENSION), self::EXTENSIONS);
+
+ /* 3. comprueba el tipo mime del archivo correspode a una imagen image/* */
+ $finfo = new \finfo(FILEINFO_MIME_TYPE);
+ $mimeType = $finfo->file($_FILES['archivo']['tmp_name']);
+ $ok = preg_match('/image\/*./', $mimeType);
+
+ if ( $ok ) {
+ $tmp_name = $_FILES['archivo']['tmp_name'];
+
+ if ( !move_uploaded_file($tmp_name, "../img/films/{$nombre}") ) {
+ $result['img'] = 'Error al mover el archivo';
+ }
+
+ /*if ( !copy("../img/tmp/{$nombre}", "/{$nombre}") ) {
+ $result['img'] = 'Error al mover el archivo';
+ }*/
+
+ }else {
+ $result['img'] = 'El archivo tiene un nombre o tipo no soportado';
+ }
+ } else {
+ $result['img'] = 'Error al subir el archivo.';
+ }
+
$tittle = $this->test_input($datos['tittle']) ?? null;
//|| !mb_ereg_match(self::HTML5_EMAIL_REGEXP, $tittle)
if ( empty($tittle) ) {
@@ -80,20 +119,30 @@ class formAddFilm extends Form{
$result[] = "Ya existe una nueva pelicula con el mismo titulo e idioma.";
}
else{
- $bd->createFilm(null, $tittle,$duration,$language,$description);
- $_SESSION['message'] = "
-
-
-
-
Operacion realizada con exito
-
Se ha añadido la pelicula correctamente en la base de datos.
-
+
+ $tmp_name = $_FILES['img']['tmp_name'];
+ if ( !move_uploaded_file($tmp_name, "../img/films/{$nombre}") ) {
+ $result[] = 'Error al mover el archivo';
+ }
+ /*else if ( !copy(DIR_ALMACEN. "/{$nombre}", DIR_ALMACEN_PROTEGIDO. "/{$nombre}") ) {
+ $result[] = 'Error al mover el archivo';
+ }*/
+ else {
+ $bd->createFilm(null, $tittle,$duration,$language,$description,$nombre);
+ $_SESSION['message'] = "
+
+
+
+
Operacion realizada con exito
+
Se ha añadido la pelicula correctamente en la base de datos.