Advertisement
Guest User

insertar imagen

a guest
Oct 18th, 2011
161
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
PHP 4.20 KB | None | 0 0
  1. <?php require_once('../Connections/conexion.php'); ?>
  2. <?php
  3.  
  4.  
  5. // Verificamos que el formulario no ha sido enviado aun
  6.  
  7. $postback = (isset($_POST["enviar"])) ? true : false;
  8.  
  9. if($postback){
  10.  
  11.   // Nivel de errores
  12.  
  13.   error_reporting(E_ALL);
  14.  
  15.   // Constantes
  16.  
  17.   # Altura de el thumbnail en píxeles
  18.  
  19.   define("ALTURA", 100);
  20.  
  21.   # Nombre del archivo temporal del thumbnail
  22.  
  23.   //define("NAMETHUMB", "/tmp/thumbtemp"); //Esto en servidores Linux, en Windows podría ser:
  24.  
  25.   define("NAMETHUMB", "c:/windows/temp/thumbtemp"); //y te olvidas de los problemas de permisos
  26.  
  27.   # Servidor de base de datos
  28.  
  29.   define("DBHOST", $hostname_conexion);
  30.  
  31.   # nombre de la base de datos
  32.  
  33.   define("DBNAME", $database_conexion);
  34.  
  35.   # Usuario de base de datos
  36.  
  37.   define("DBUSER", $username_conexion);
  38.  
  39.   # Password de base de datos
  40.  
  41.   define("DBPASSWORD", $password_conexion);
  42.  
  43.   // Mime types permitidos
  44.  
  45.   $mimetypes = array("image/jpeg", "image/pjpeg", "image/gif", "image/png");
  46.  
  47.   // Variables de la foto
  48.  
  49.   $name = $_FILES["foto"]["name"];
  50.  
  51.   $type = $_FILES["foto"]["type"];
  52.  
  53.   $tmp_name = $_FILES["foto"]["tmp_name"];
  54.  
  55.   $size = $_FILES["foto"]["size"];
  56.  
  57.   // Verificamos si el archivo es una imagen válida
  58.  
  59.   if(!in_array($type, $mimetypes))
  60.  
  61.     die("El archivo que subiste no es una imagen válida");
  62.  
  63.   // Creando el thumbnail
  64.  
  65.   switch($type) {
  66.  
  67.     case $mimetypes[0]:
  68.  
  69.     case $mimetypes[1]:
  70.  
  71.       $img = imagecreatefromjpeg($tmp_name);
  72.  
  73.       break;
  74.  
  75.     case $mimetypes[2]:
  76.  
  77.       $img = imagecreatefromgif($tmp_name);
  78.  
  79.       break;
  80.  
  81.     case $mimetypes[3]:
  82.  
  83.       $img = imagecreatefrompng($tmp_name);
  84.  
  85.       break;
  86.  
  87.   }
  88.  
  89.   $datos = getimagesize($tmp_name);
  90.  
  91.   $ratio = ($datos[1]/ALTURA);
  92.  
  93.   $ancho = round($datos[0]/$ratio);
  94.  
  95.   $thumb = imagecreatetruecolor($ancho, ALTURA);
  96.  
  97.   imagecopyresized($thumb, $img, 0, 0, 0, 0, $ancho, ALTURA, $datos[0], $datos[1]);
  98.  
  99.   switch($type) {
  100.  
  101.     case $mimetypes[0]:
  102.  
  103.     case $mimetypes[1]:
  104.  
  105.       imagejpeg($thumb, NAMETHUMB);
  106.  
  107.           break;
  108.  
  109.     case $mimetypes[2]:
  110.  
  111.       imagegif($thumb, NAMETHUMB);
  112.  
  113.       break;
  114.  
  115.     case $mimetypes[3]:
  116.  
  117.       imagepng($thumb, NAMETHUMB);
  118.  
  119.       break;
  120.  
  121.   }
  122.  
  123.   // Extrae los contenidos de las fotos
  124.  
  125.   # contenido de la foto original
  126.  
  127.   $fp = fopen($tmp_name, "rb");
  128.  
  129.   $tfoto = fread($fp, filesize($tmp_name));
  130.  
  131.   $tfoto = addslashes($tfoto);
  132.  
  133.   fclose($fp);
  134.  
  135.   # contenido del thumbnail
  136.  
  137.   $fp = fopen(NAMETHUMB, "rb");
  138.  
  139.   $tthumb = fread($fp, filesize(NAMETHUMB));
  140.  
  141.   $tthumb = addslashes($tthumb);
  142.  
  143.   fclose($fp);
  144.  
  145.   // Borra archivos temporales si es que existen
  146.  
  147.   @unlink($tmp_name);
  148.  
  149.   @unlink(NAMETHUMB);
  150.  
  151.   // Guardamos todo en la base de datos
  152.  
  153.   #nombre de la foto
  154.  
  155.   $nombre = $_POST["nombre"];
  156.  
  157.   $link = mysql_connect(DBHOST, DBUSER, DBPASSWORD) or die(mysql_error($link));;
  158.  
  159.   mysql_select_db(DBNAME, $link) or die(mysql_error($link));
  160.  
  161.   $sql = "INSERT INTO imagen(nombre, foto, thumb, mime)
  162.  
  163.    VALUES
  164.  
  165.    ('$nombre', '$tfoto', '$tthumb', '$type')";
  166.  
  167.   mysql_query($sql, $link) or die(mysql_error($link));
  168.  
  169.   echo "Fotos guardadas";
  170.  
  171.   exit();
  172.  
  173. }
  174.  
  175. ?>
  176.  
  177.  
  178. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
  179.  
  180.         "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  181.  
  182. <html xmlns="http://www.w3.org/1999/xhtml">
  183.  
  184. <head>
  185.  
  186. <title>Imagenes</title>
  187.  
  188. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  189.  
  190. <link href="../ArchivoEstilo.css" rel="stylesheet" type="text/css" />
  191. </head>
  192.  
  193. <body>
  194. <form name="frmimage" id="frmimage" method="post"
  195.  
  196.         enctype="multipart/form-data" action="<?php echo $_SERVER['../PHP_SELF'];?>">
  197.   <table width="200" border="1" align="center" cellpadding="1" cellspacing="1">
  198.           <tr>
  199.             <td>Nombre:</td>
  200.             <td><input type="text" id="nombre" name="nombre" /></td>
  201.           </tr>
  202.           <tr>
  203.             <td>Imagen:</td>
  204.             <td><input type="file" id="foto" name="foto" /></td>
  205.           </tr>
  206.           <tr>
  207.             <td>&nbsp;</td>
  208.             <td><input type="submit" name="enviar" id="enviar" value="Guardar" /></td>
  209.           </tr>
  210.         </table>
  211. </form>
  212.  
  213. </body>
  214.  
  215. </html>
  216.  
  217.  
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement