怎样用php实现上传图片到数据库 10

以及实现从数据库把图片的展示的功能您只要告诉我怎样将图片路径存到数据库里就行... 以及实现从数据库把图片的展示的功能
您只要告诉我怎样将图片路径存到数据库里就行
展开
 我来答
笑破你的肚子
2015-10-15 · TA获得超过598个赞
知道小有建树答主
回答量:737
采纳率:33%
帮助的人:277万
展开全部

php实现上传图片保存到数据库的方法。具体分析如下:

php 上传图片,一般都使用move_uploaded_file方法保存在服务器上。但如果一个网站有多台服务器,就需要把图片发布到所有的服务器上才能正常使用(使用图片服务器的除外)
如果把图片数据保存到数据库中,多台服务器间可以实现文件共享,节省空间。

首先图片文件是二进制数据,所以需要把二进制数据保存在mysql数据库。
mysql数据库提供了BLOB类型用于存储大量数据,BLOB是一个二进制对象,能容纳不同大小的数据。

BLOB类型有以下四种,除存储的最大信息量不同外,其他都是一样的。可根据需要使用不同的类型。

TinyBlob       最大 255B
Blob              最大 65K
MediumBlob  最大 16M
LongBlob      最大 4G

数据表photo,用于保存图片数据,结构如下:

CREATE TABLE `photo` (  
  `id` int(10) unsigned NOT NULL auto_increment,  
  `type` varchar(100) NOT NULL,  
  `binarydata` mediumblob NOT NULL,  
  PRIMARY KEY  (`id`)  
) ENGINE=MyISAM DEFAULT CHARSET=latin1 AUTO_INCREMENT=1 ;

upload_image_todb.php代码如下:

<?php  
// 连接数据库  
$conn=@mysql_connect("localhost","root","")  or die(mysql_error());  
@mysql_select_db('demo',$conn) or die(mysql_error()); // 判断action  
$action = isset($_REQUEST['action'])? $_REQUEST['action'] : ''; 
// 上传图片  
if($action=='add'){  
    $image = mysql_escape_string(file_get_contents($_FILES['photo']['tmp_name']));  
    $type = $_FILES['photo']['type'];  
    $sqlstr = "insert into photo(type,binarydata) values('".$type."','".$image."')";  
    @mysql_query($sqlstr) or die(mysql_error());  
    header('location:upload_image_todb.php');  
    exit();  
// 显示图片  
}elseif($action=='show'){  
    $id = isset($_GET['id'])? intval($_GET['id']) : 0;  
    $sqlstr = "select * from photo where id=$id";  
    $query = mysql_query($sqlstr) or die(mysql_error());  
    $thread = mysql_fetch_assoc($query);  
    if($thread){  
        header('content-type:'.$thread['type']);  
        echo $thread['binarydata'];  
        exit();  
    }  
}else{  
// 显示图片列表及上传表单  
?>  
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">  
<html>  
 <head>  
  <meta http-equiv="content-type" content="text/html; charset=utf-8">  
  <title> upload image to db demo </title>  
 </head>  
  
 <body>  
  <form name="form1" method="post" action="upload_image_todb.php" enctype="multipart/form-data">  
  <p>图片:<input type="file" name="photo"></p>  
  <p><input type="hidden" name="action" value="add"><input type="submit" name="b1" value="提交"></p>  
  </form>  
  
<?php  
    $sqlstr = "select * from photo order by id desc";  
    $query = mysql_query($sqlstr) or die(mysql_error());  
    $result = array();  
    while($thread=mysql_fetch_assoc($query)){  
        $result[] = $thread;  
    }  
    foreach($result as $val){  
        echo '<p><img 
src="upload_image_todb.php?action=show&id='.$val['id'].'&t='.time().'"
 width="150"></p>';  
    }  
?>  
</body>  
</html>  
<?php  
}  
?>

程序运行截图和数据库截图:

介尘珺6726
2011-08-01 · TA获得超过7.1万个赞
知道大有可为答主
回答量:5.1万
采纳率:0%
帮助的人:6727万
展开全部
先将你上传图片的路径直接存到upload文件夹中,在由upload文件夹中直接传入数据库,再输出就是直接的图片形式。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
zhaoziyun58
2011-07-19
知道答主
回答量:2
采纳率:0%
帮助的人:0
展开全部
<?php
@session_start();

require_once("./conf/config.php");

$file_type = $_FILES["pic"]["type"];
$file_name = $_FILES["pic"]["name"];

if ((($file_type == "image/gif")
|| ($file_type == "image/jpeg")
|| ($file_type == "image/pjpeg"))
&& ($_FILES["pic"]["size"] < 1000000))
{

if(!is_dir("upload/". date("md") . "/"))
{
mkdir("upload/". date("md") . "/");
}
if (file_exists("upload/" . date("md") . "/" . $file_name))
{
echo "图片 " . $file_name . " 文件名已存在,请更换文件名再进行上传. ";
}
else
{
$url = "upload/" . date("md") . "/" .$file_name;
move_uploaded_file($_FILES["pic"]["tmp_name"],
"upload/" . date("md") . "/" . $file_name);
}
}

else
{
echo "图片文件不可用";
}

$userId = $_SESSION["userId"];

if($url){
$sql = "insert into photos(url, userId) values('$url', '$userId')";

$query = mysql_query($sql);
if($query){
die('<script>alert("图片上传成功");window.location="/photolist.htm";</script>');
}
}
?>
追问
您只要把怎样将图片路径上传到数据库里面,并稍微解释一下就好
追答
$sql = "insert into photos(url, userId) values('$url', '$userId')";
$query = mysql_query($sql);

这两句就是加入数据库的,加入到的是photos表,photos有两个字段,一个图片路径一个是用户Id,路径自定义,但是调用的时候得和物理路径对应上。这样就可以了。
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
3211_204
2011-07-19 · TA获得超过586个赞
知道小有建树答主
回答量:1021
采纳率:100%
帮助的人:731万
展开全部
你该不会在设置上传的表单时出现问题了吧。

参考资料: http://www.cncms.com.cn/php/6666.htm

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
xtsanglei
2011-07-19 · 超过19用户采纳过TA的回答
知道答主
回答量:55
采纳率:0%
帮助的人:70.1万
展开全部
其实很简单的,三个步骤,我找了一个资料给你,很详细,你看下应该可以明白!
http://www.soft6.com/tech/16/168882.html
追问
您只要告诉我怎样获取文件域的值就行
追答
这是我写的简单的一个,你看看

alert('上传成功');
";
echo "您的文件已经上传完毕 上传图片预览: ";
}else{echo " alert('上传失败'); ";}
}
}
?>

function selectpic(imagepatch){
window.opener.document.form1.imagepatch.value=imagepatch;
window.close();}

")' value="确认用此图片"/>
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 2条折叠回答
收起 更多回答(3)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式