仓酷云

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 2106|回复: 18
打印 上一主题 下一主题

[学习教程] PHP网站制作之用PHP完成把图像上传到数据库

[复制链接]
金色的骷髅 该用户已被删除
跳转到指定楼层
楼主
发表于 2015-2-16 00:24:38 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
熟悉了PHP和MYSQL开发的要领之后,再回头看你写的那个留言本,你也许会怀疑那真的是你写的吗?当然,如果屋里还有鬼的话,也许是它写的-_-上传|数据|数据库     有甚么成绩请与我接洽: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>
学习数据库了,MYSQL可算是PHP的黄金搭档了,不过,虽然话是这么说,你也可能恨不得把MYSQL给生吞活剥了,因为这一行一列的东东简直让自己头晕目眩。
谁可相欹 该用户已被删除
沙发
发表于 2015-2-16 01:10:44 | 只看该作者
小鸟是第一次发帖(我习惯潜水的(*^__^*) 嘻嘻……),有错误之处还请大家批评指正,另外,前些日子听人说有高手能用php写驱动程序,真是学无止境,人外有人,天外有天。
精灵巫婆 该用户已被删除
板凳
发表于 2015-3-1 01:27:49 | 只看该作者
最后介绍一个代码出错,但是老找不到错误方法,就是 go to wc (囧),出去换换气没准回来就找到错误啦。
变相怪杰 该用户已被删除
地板
发表于 2015-3-10 11:13:31 | 只看该作者
如果你已经到这种程度了,那么你已经可以做我的老师了。其实php也分很多的区域,
蒙在股里 该用户已被删除
5#
发表于 2015-3-11 06:20:43 | 只看该作者
有时候汉字的空格也能导致页面出错,所以在写代码的时候,要输入空格最好用引文模式。
山那边是海 该用户已被删除
6#
发表于 2015-3-17 22:10:20 | 只看该作者
最后祝愿,php会给你带来快乐的同时 你也会给他带来快乐。
若相依 该用户已被删除
7#
发表于 2015-3-25 03:35:08 | 只看该作者
多看优秀程序员编写的代码,仔细理解他们解决问题的方法,对自身有很大的帮助。
8#
发表于 2015-3-30 20:34:38 | 只看该作者
Ps:以上纯属原创,如有雷同,纯属巧合
小魔女 该用户已被删除
9#
发表于 2015-3-31 21:12:53 | 只看该作者
Ps:以上纯属原创,如有雷同,纯属巧合
不帅 该用户已被删除
10#
发表于 2015-4-3 19:49:31 | 只看该作者
当留言板完成的时候,下步可以把做1个单人的blog程序,做为目标,
分手快乐 该用户已被删除
11#
发表于 2015-4-25 17:16:02 | 只看该作者
有位前辈曾经跟我说过,phper 至少要掌握200个函数 编起程序来才能顺畅点,那些不熟悉的函数记不住也要一拿手册就能找到。所以建议新手们没事就看看php的手册(至少array函数和string函数是要记牢的)。
因胸联盟 该用户已被删除
12#
发表于 2015-4-27 19:30:57 | 只看该作者
作为一个合格的coder 编码的规范是必须,命名方面我推崇“驼峰法”,另外就是自己写的代码最好要带注释,不然时间长了,就算是自己的代码估计看起来都费事,更不用说别人拉。
老尸 该用户已被删除
13#
发表于 2015-5-1 19:09:23 | 只看该作者
做为1门年轻的语言,php一直很努力。
莫相离 该用户已被删除
14#
发表于 2015-5-11 17:29:50 | 只看该作者
学好程序语言,多些才是王道,写两个小时代码的作用绝对超过看一天书,这个我是深有体会(顺便还能练打字速度)。
透明 该用户已被删除
15#
发表于 2015-5-12 04:43:42 | 只看该作者
其实也不算什么什么心得,在各位大侠算是小巫见大巫了吧,望大家不要见笑,若其中有错误的地方请各位大虾斧正。
乐观 该用户已被删除
16#
发表于 2015-6-10 20:27:58 | 只看该作者
php是动态网站开发的优秀语言,在学习的时候万万不能冒进。在系统的学习前,我认为不应该只是追求实现某种效果,因为即使你复制他人的代码调试成功,实现了你所期望的效果,你也不了解其中的原理。
金色的骷髅 该用户已被删除
17#
 楼主| 发表于 2015-6-15 14:13:44 | 只看该作者
遇到出错的时候,我经常把错误信息直接复制到 google的搜索栏,一般情况都是能搜到结果的,不过有时候会搜出来一大片英文的出来,这时候就得过滤一下,吧中文的弄出来,挨着式方法。
活着的死人 该用户已被删除
18#
发表于 2015-6-19 13:18:59 | 只看该作者
环境搭建好,当你看见你的浏览器输出“it works\\\\\\\"时你一定是喜悦的。在你解决问题的时候,我强烈建议多读php手册。
兰色精灵 该用户已被删除
19#
发表于 2015-6-20 21:44:55 | 只看该作者
我要在声明一下:我是个菜鸟!!我对php这门优秀的语言也是知之甚少。但是我要在这里说一下php在网站开发中最常用的几个功能:
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|仓酷云 鄂ICP备14007578号-2

GMT+8, 2024-4-28 08:48

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表