|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
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给生吞活剥了,因为这一行一列的东东简直让自己头晕目眩。 |
|