快精灵印艺坊 您身边的文印专家
广州名片 深圳名片 会员卡 贵宾卡 印刷 设计教程
产品展示 在线订购 会员中心 产品模板 设计指南 在线编辑
 首页 名片设计   CorelDRAW   Illustrator   AuotoCAD   Painter   其他软件   Photoshop   Fireworks   Flash  

 » 彩色名片
 » PVC卡
 » 彩色磁性卡
 » 彩页/画册
 » 个性印务
 » 彩色不干胶
 » 明信片
   » 明信片
   » 彩色书签
   » 门挂
 » 其他产品与服务
   » 创业锦囊
   » 办公用品
     » 信封、信纸
     » 便签纸、斜面纸砖
     » 无碳复印纸
   » 海报
   » 大篇幅印刷
     » KT板
     » 海报
     » 横幅

用PHP实现把图象上传到数据库

  有什么问题请与我联系:http://www.webjx.com web@webjx.com
 转载请注明出处

  今天教给大家如何用PHP实现把图象上传到MYSQL数据库中。 在这个教程中我们需要建立3个PHP文件:

  readdir.php - 把图片放到数据库的代码
  image.php - 显示实际图片的代码
  view.php - 显示你如何调用数据库中的图片的代码

1.创建一个数据库

CREATE TABLE `images` (
`imgid` INT NOT NULL AUTO_INCREMENT ,
`sixfourdata` LONGTEXT NOT NULL ,
PRIMARY KEY ( `imgid` )
);
READDIR.PHP

详细的内容:
<?
$dbcnx = mysql_connect("localhost", "username", "password");
mysql_select_db("base64imgdb");
?>
\\'我们需要打开一个目录
"./"
\\'readdir.php 文件定位于这个目录:
$path = "./";
$dir_handle = opendir($path) or die("Unable to open directory $path");

  下面是比较难的部分,大家需要好好研究一下:把图象分类,并且读出正在使用的一些数据

fopen

\\'转变

base64_encode

\\' 插入到表里

<?
while ($file = readdir($dir_handle)) {
$filetyp = substr($file, -3);
if ($filetyp == \\'gif\\' OR $filetyp == \\'jpg\\') {
$handle = fopen($path . "/" . $file,\\'r\\');
$file_content = fread($handle,filesize($path . "/" . $file));
fclose($handle);
$encoded = chunk_split(base64_encode($file_content));
$sql = "INSERT INTO images SET sixfourdata=\\'$encoded\\'";
mysql_query($sql);
}
}
?>

  关闭设置的目录,然后处理:

<?
closedir($dir_handle);
echo("complete");
mysql_close($dbcnx);
?>

  读出图片的代码:IMAGE.PHP
  这段代码比较难,我们要好好看看

<?
$dbcnx = mysql_connect("localhost", "username", "password");
mysql_select_db("base64imgdb");
?>
我们读出图片使用的代码image.php?img=x:
<?
$img = $_REQUEST["img"];
?>
之后我们需要连接数据库,然后读出
<?
$result = mysql_query("SELECT * FROM images WHERE imgid=" . $img . "");
if (!$result) {
echo("<b>哀求错误: " . mysql_error() . "</b>");
exit();
}
while ($row = mysql_fetch_array($result)) {
$imgid = $row["imgid"];
$encodeddata = $row["sixfourdata"];
}
?>

<?
mysql_close($dbcnx);
echo base64_decode($encodeddata);
?>

  在这里我们要理解base64-encoded 图象数据格式。

  "让我们来看看详细的图片吧!" VIEW.PHP

image.php?img=1

image.php?img=357

<img src=\\'image.php?img=1\\' border="0" alt="">

看看完整的一个例子吧!

readdir.php:
<?
###############################
# DB CONNECTION
# CHANGE THESE VALUES
###############################
$dbcnx = mysql_connect("localhost", "username", "password");
mysql_select_db("base64imgdb");

$path = "./";
$dir_handle = opendir($path) or die("Unable to open directory $path");
while ($file = readdir($dir_handle)) {
$filetyp = substr($file, -3);
if ($filetyp == \\'gif\\' OR $filetyp == \\'jpg\\') {
$handle = fopen($file,\\'r\\');
$file_content = fread($handle,filesize($file));
fclose($handle);
$encoded = chunk_split(base64_encode($file_content));
$sql = "INSERT INTO images SET sixfourdata=\\'$encoded\\'";
mysql_query($sql);
}
}

closedir($dir_handle);
echo("complete");
mysql_close($dbcnx);
?>
image.php:
<?
$dbcnx = mysql_connect("localhost", "username", "password");

mysql_select_db("base64imgdb");

$img = $_REQUEST["img"];

$result = mysql_query("SELECT * FROM images WHERE imgid=" . $img . "");

if (!$result) {

echo("<b>Error performing query: " . mysql_error() . "</b>");
exit();
}
while ($row = mysql_fetch_array($result) ) {
$imgid = $row["imgid"];
$encodeddata = $row["sixfourdata"];
}
mysql_close($dbcnx);
echo base64_decode($encodeddata);
?>
And view.php (i shouldnt need to post this..)
<html>
<body>
..
<img src=\\'image.php?img=1\\' border="0" alt="">
..
</body>
</html>

返回类别: 教程
上一教程: 提升PHP执行速度全攻略(下) 
下一教程: 利用递归把多维数组转为一维数组的函数

您可以阅读与"用PHP实现把图象上传到数据库"相关的教程:
· 用PHP实现XML备份Mysql数据库
· PHP文本型数据库分类排序的实现
· [转]Apache+PHP3+PostgreSQL作为基于Web的数据库平台的安装
· 关于PHP中操作MySQL数据库的一些要注重的问题
· 无数据库的具体域名查询程序PHP版(5) 
    微笑服务 优质保证 索取样品