PHP脚本数据库功能详解(中)


Posted in PHP onOctober 09, 2006

利用PHP将文件保存到数据库

数据库是数据组织、存储的中心。将要处理的也可能是各种数据,包括程序、文件、报表,甚至音频、视频数据。由于通过浏览器,个人用户只能填写少部分的个人简历。因此,我们这里示范用户个人简历上载的功能。其他类型的数据可以模仿此例进行操作。

首先是信息收集页面。让用户选择要上载的文件。此页面的html代码如下:

〈!-- begin of post.htm--〉

〈p〉 〈/p〉

〈form method="POST" action="insert.php" ENCTYPE="multipart/form-data"〉

〈p〉〈b〉个人简历提交〈/b〉〈/p〉

〈p〉姓名:〈br〉

〈input type="text" name="Name" size="20"〉〈/p〉

〈p〉个人简介:〈br〉

〈textarea rows="2" name="Intro" cols="20"〉〈/textarea〉〈/p〉

〈p〉简历文件:〈br〉

〈input type="file" name="ResuFile"〉〈/p〉

〈p〉〈input type="submit" value="提交" name="B1"〉〈/p〉

〈/form〉

〈!-End of post.htm--〉

注意,ENCTYPE关键字一定不能省,否则文件无法正确上载。

这里,我们再把向数据库插入记录的代码重新设计:

〈?

//begin of file insert.php

if($ResuFile != "none")

//确定用户选择了文件

{

$Size = filesize($ResuFile);

//确定文件大小

$mFileData = addslashes(fread(fopen($ResuFile, "r"), $Size));

//读取文件,对内容进行处理

unlink($ResuFile);

//删除上载临时文件

}

$LinkID=@mysql_connect("localhost", "root" , "") or die("不能连接到数据库服务器!可能是数据库服务器没有启动,或者用户名密码有误!");

$DBID = @mysql_select_db("ResumeDB",$LinkID) or die("选择数据库出错,可能是您指定的数据库不存在!");

$query = "insert into Resume(Name,Intro,ResuFile) values('$Name', '$Intro', '$mFileData')";

$result = @mysql_query("$query",$LinkID); //执行查询,插入文件到数据库

if(! $result)

echo "数据插入失败!";

else

echo "文件上载成功!";

@mysql_close($LinkID);

//end of file insert.php

?〉

有了上面的基础,写出从数据库读数据的程序应该很简单了。需要注意的是文件向客户发送的方法。服务器必须向浏览器发送头信息,说明将要发送的数据为word文档。如果用户计算机装有MSWord,浏览器将自动调用word进行文档显示。

我们可以设置一个超级链接,来下载这个Word文件:

〈?

//begin of file show.php

$LinkID=@mysql_connect("localhost", "root" , "") or die("不能连接到数据库服务器!可能是数据库服务器没有启动,或者用户名密码有误!");

$DBID = @mysql_select_db("ResumeDB",$LinkID) or die("选择数据库出错,可能是您指定的数据库不存在!");

$query = "insert into Resume(Name,Intro,ResuFile) values('$Name', '$Intro', '$mFileData')";

$result = @mysql_query("$query",$LinkID);

//执行查询,插入文件到数据库

$query= "select ID,Name,Intro from Resume";

//生成SQL语句

$result = mysql_query($query,$LinkID); //执行,结果集保存到变量$result中

$num= mysql_num_rows($result); //取得查询返回的记录行数

if($num == 0)

{

echo "没有找到任何记录";

exit();

}

while($row=mysql_fetch_array($result)) //取结果集的下一行数据到数组$row中

{

echo $row["ID"]." ".$row["Name"]." ".$row["Intro"]." ";

echo "〈a href= "download.php?ID=".$row["ID"].""〉查看Word文档〈/a〉〈br〉";

}

//end of file show.php

?〉

访问文件show.php,用户看到的是个人简要信息的列表。点击“查看Word文档”,即可看到对应成员详细的个人简历。

Word文档的显示是用下面的文件:

〈?

// begin of file download.php

$LinkID=@mysql_connect("localhost", "root" , "") or die("不能连接到数据库服务器!可能是数据库服务器没有启动,或者用户名密码有误!");

$DBID = @mysql_select_db("ResumeDB",$LinkID) or die("选择数据库出错,可能是您指定的数据库不存在!");

$query = "select ResuFile from Resume where ID=$ID";

//$ID为调用传递的变量

$result = @mysql_query("$query",$LinkID);

//执行查询,从数据库读取文件内容

if(mysql_num_rows($result) 〈 1 )

{

echo "没有找到相应的文件!";

exit();

}

$row = mysql_fetch_array($result);

$mFileData = $row["ResuFile"];

//读取个人简历的内容(Word文件格式的数据)

header("Content-type: application/msword");

//发送头信息,说明将要发送的数据为word文档

echo $mFileData;

//发送文档数据

//end of file download.php

?〉

至此,我们已经实现了个人简历的提交、数据库存储、信息浏览等功能,基本完成了“人才信息交流”的框架功能。

需要说明的是,通过PHP进行文件上载及数据库存储是个较突出的技术难题。很多关于PHP的网站都不断出现这类问题。这些操作,对平台、环境设置依赖性较大。不同的平台配置,都可能导致操作的失败。本文后面附了上述程序的运行平台、编译参数,以供参考。

PHP 相关文章推荐
php Undefined index和Undefined variable的解决方法
Mar 27 PHP
解析PHP无限级分类方法及代码
Jun 21 PHP
Laravel框架数据库CURD操作、连贯操作总结
Sep 03 PHP
php约瑟夫问题解决关于处死犯人的算法
Mar 23 PHP
[原创]php求圆周率的简单实现方法
May 30 PHP
laravel学习教程之存取器
Jul 30 PHP
PHP进程通信基础之信号量与共享内存通信
Feb 19 PHP
thinkphp5.1 文件引入路径问题及注意事项
Jun 13 PHP
Yii框架视图、视图布局、视图数据块操作示例
Oct 14 PHP
laravel5.6 框架邮件队列database驱动简单demo示例
Jan 26 PHP
php 函数中静态变量使用的问题实例分析
Mar 05 PHP
Yii实现微信公众号场景二维码的方法实例
Aug 30 PHP
PHP脚本数据库功能详解(上)
Oct 09 #PHP
屏蔽浏览器缓存另类方法
Oct 09 #PHP
使用网络地址转换实现多服务器负载均衡
Oct 09 #PHP
php抓即时股票信息
Oct 09 #PHP
利用PHP动态生成VRML网页
Oct 09 #PHP
一个SQL管理员的web接口
Oct 09 #PHP
如何实现给定日期的若干天以后的日期
Oct 09 #PHP
You might like
MySql 按时间段查询数据方法(实例说明)
2008/11/02 PHP
php微信支付之APP支付方法
2015/03/04 PHP
PHP查看当前变量类型的方法
2015/07/31 PHP
php创建类并调用的实例方法
2019/09/25 PHP
基于JQuery.timer插件实现一个计时器
2010/04/25 Javascript
基于jquery自定义图片热区效果
2012/07/21 Javascript
jquery入门—数据删除与隔行变色以及图片预览
2013/01/07 Javascript
JS二维数组的定义说明
2014/03/03 Javascript
基于PHP和Mysql相结合使用jqGrid读取数据并显示
2015/12/02 Javascript
深入浅析JavaScript字符串操作方法 slice、substr、substring及其IE兼容性
2015/12/16 Javascript
JS实现图片的不间断连续滚动的简单实例
2016/06/03 Javascript
关于JavaScript限制字数的输入框的那些事
2016/08/14 Javascript
js实现select选择框效果及美化
2016/08/19 Javascript
运用js教你轻松制作html音乐播放器
2020/04/17 Javascript
原生Javascript和jQuery做轮播图简单例子
2016/10/11 Javascript
jQuery length 和 size()区别总结
2018/04/26 jQuery
ES7之Async/await的使用详解
2019/03/28 Javascript
基于three.js实现的3D粒子动效实例代码
2019/04/09 Javascript
layui 表格操作列按钮动态显示的实现方法
2019/09/06 Javascript
javascript代码实现简易计算器
2021/01/25 Javascript
详解Python中的条件判断语句
2015/05/14 Python
在Python中字符串、列表、元组、字典之间的相互转换
2019/11/15 Python
Spark处理数据排序问题如何避免OOM
2020/05/21 Python
python读取xml文件方法解析
2020/08/04 Python
Python + opencv对拍照得到的图片进行背景去除的实现方法
2020/11/18 Python
英国家喻户晓的家居商店:The Range
2019/03/25 全球购物
意大利在线大学图书馆:Libreria universitaria
2019/07/16 全球购物
亚洲在线旅行门户网站:Expedia.com.hk(智游网)
2020/04/14 全球购物
PHP如何自定义函数
2016/09/16 面试题
SQL Server数据库笔试题和答案
2016/02/04 面试题
大学三年的自我评价
2013/12/25 职场文书
文明寄语大全
2014/04/11 职场文书
小学庆六一活动总结
2014/08/28 职场文书
2014村党支部书记党建工作汇报材料
2014/11/02 职场文书
用Python提取PDF表格的方法
2021/04/11 Python
SpringBoot集成Redis,并自定义对象序列化操作
2021/06/22 Java/Android