关闭

用PHP和MySQL保存和输出图片

732人阅读 评论(0) 收藏 举报
建表:CREATE TABLE Images ( PicNum int NOT NULL AUTO_INCREMENT PRIMARY KEY, Image BLOB );
我们假定文件上传域的名称为Picture:
<?
  If($Picture != "none") { $PSize = filesize($Picture);
  $mysqlPicture = addslashes(fread(fopen($Picture, "r"), $PSize));
  mysql_connect($host,$username,$password) or die("Unable to connect to SQL server");
  @mysql_select_db($db) or die("Unable to select database");
  mysql_query("INSERT INTO Images (Image) VALUES '($mysqlPicture')")
  or die("Can't Perform Query");
  }
  else
  { echo"You did not upload any picture"; }
?>
第二个文件则被用来从数据库中实际输出文件流,作为<IMG>标签的SRC属性。
第一个文件的简单形式可以如下:
<HTML>
<BODY>
<?
mysql_connect($host,$username,$password)
or die("Unable to connect to SQL server");
@mysql_select_db($db) or die("Unable to select database");
$result=mysql_query("SELECT * FROM Images") or die("Can't Perform Query");
While($row=mysql_fetch_object($result)) {
  echo "<IMG SRC=/"Second.php3? PicNum=$row->PicNum/">";
}
?>
</BODY>
</HTML>
  当HTML页面被浏览时,每显示一副图片就会调用一次Second.php3文件。当第二个文件被调用时会传入相应的Picture ID,我们可以借此从数据库中取回对应的图片并显示。
Second.php3文件如下:
<?
$result=mysql_query("SELECT * FROM Images WHERE PicNum=$PicNum")
or die("Can't perform Query"); $row=mysql_fetch_object($result);
Header( "Content-type: image/gif"); echo $row->Image;
?>
0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:53454次
    • 积分:853
    • 等级:
    • 排名:千里之外
    • 原创:28篇
    • 转载:9篇
    • 译文:0篇
    • 评论:2条
    文章分类
    最新评论