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实现ping
Oct 09 PHP
PHP多线程抓取网页实现代码
Jul 22 PHP
PHP Warning: PHP Startup: Unable to load dynamic library \ D:/php5/ext/php_mysqli.dll\
Jun 17 PHP
解析php中var_dump,var_export,print_r三个函数的区别
Jun 21 PHP
使用php计算排列组合的方法
Nov 13 PHP
PHP获得数组交集与差集的方法
Jun 10 PHP
前端必学之PHP语法基础
Jan 01 PHP
php设计模式之委托模式
Feb 13 PHP
Android App中DrawerLayout抽屉效果的菜单编写实例
Mar 21 PHP
PHP查询大量数据内存耗尽问题的解决方法
Oct 28 PHP
PHP长网址与短网址的实现方法
Oct 13 PHP
PHP设计模式(三)建造者模式Builder实例详解【创建型】
May 02 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
深入array multisort排序原理的详解
2013/06/18 PHP
php读取excel文件的简单实例
2013/08/26 PHP
laravel框架之数据库查出来的对象实现转化为数组
2019/10/23 PHP
ThinkPHP5 框架引入 Go AOP,PHP AOP编程项目详解
2020/05/12 PHP
我见过最全的个人js加解密功能页面
2007/12/12 Javascript
select标记美化--JS式插件、后期加载
2013/04/01 Javascript
jQuery 和 CSS 的文本特效插件集锦
2014/12/12 Javascript
基于jquery实现轮播特效
2016/04/22 Javascript
JS实现星星评分功能实例代码(两种方法)
2016/06/09 Javascript
详细解读Jquery各Ajax函数($.get(),$.post(),$.ajax(),$.getJSON())
2016/08/15 Javascript
基于Bootstrap实现城市三级联动
2017/11/23 Javascript
Vue2.0 给Tab标签页和页面切换过渡添加样式的方法
2018/03/13 Javascript
微信小程序合法域名配置方法
2019/05/06 Javascript
vuejs+element UI table表格中实现禁用部分复选框的方法
2019/09/20 Javascript
JS快速实现简单计算器
2020/04/08 Javascript
PHP webshell检查工具 python实现代码
2009/09/15 Python
详解Python的Django框架中的中间件
2015/07/24 Python
python获取程序执行文件路径的方法(推荐)
2018/04/26 Python
Python 读取串口数据,动态绘图的示例
2019/07/02 Python
使用Fabric自动化部署Django项目的实现
2019/09/27 Python
Python如何基于smtplib发不同格式的邮件
2019/12/30 Python
python 项目目录结构设置
2020/02/14 Python
python批量处理多DNS多域名的nslookup解析实现
2020/06/28 Python
python与idea的集成的实现
2020/11/20 Python
Django中template for如何使用方法
2021/01/31 Python
说一下mysql, oracle等常见数据库的分页实现方案
2012/09/29 面试题
非功能性需求都包括哪些方面
2013/10/29 面试题
奥巴马竞选演讲稿
2014/05/15 职场文书
装饰工程师岗位职责
2014/06/08 职场文书
法制宣传口号
2014/06/16 职场文书
助学金感谢信
2015/01/20 职场文书
小班下学期个人总结
2015/02/12 职场文书
工厂员工辞职信范文
2015/05/12 职场文书
Redis如何一键部署脚本
2021/04/12 Redis
为什么MySQL 删除表数据 磁盘空间还一直被占用
2021/10/16 MySQL
Python os和os.path模块详情
2022/04/02 Python