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默认安装产生系统漏洞
Oct 09 PHP
php中的登陆login
Jan 18 PHP
实用函数10
Nov 08 PHP
libmysql.dll与php.ini是否真的要拷贝到c:\windows目录下呢
Mar 15 PHP
php实现递归的三种基本方式
Jul 04 PHP
php有效防止同一用户多次登录
Nov 19 PHP
php 二维数组时间排序实现代码
Nov 19 PHP
为何说PHP引用是个坑,要慎用
Apr 02 PHP
php微信开发之音乐回复功能
Jun 14 PHP
PHP基于rabbitmq操作类的生产者和消费者功能示例
Jun 16 PHP
浅谈PHP中的那些魔术常量
Dec 02 PHP
WordPress伪静态规则设置代码实例
Dec 10 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
Extended CHM PHP 语法手册之 DIY
2006/10/09 PHP
php下用cookie统计用户访问网页次数的代码
2010/05/09 PHP
php 判断服务器操作系统的类型
2014/02/17 PHP
php中array_multisort对多维数组排序的方法
2020/06/21 PHP
在WordPress的后台中添加顶级菜单和子菜单的函数详解
2016/01/11 PHP
PHP单链表的实现代码
2016/07/05 PHP
js实现类似MSN提示的页面效果代码分享
2015/08/24 Javascript
浏览器环境下JavaScript脚本加载与执行探析之动态脚本与Ajax脚本注入
2016/01/19 Javascript
jQuery 检查某个元素在页面上是否存在实例代码
2016/10/27 Javascript
JavaScript用200行代码制作打飞机小游戏实例
2017/06/21 Javascript
详解微信小程序Radio选中样式切换
2017/07/06 Javascript
Node.js微信 access_token ( jsapi_ticket ) 存取与刷新的示例
2017/09/30 Javascript
JavaScript实现元素滚动条到达一定位置循环追加内容
2017/12/28 Javascript
js实现轮播图的完整代码
2020/10/26 Javascript
解决vuex数据页面刷新后初始化操作
2020/07/26 Javascript
JavaScript实现点击切换功能
2021/01/27 Javascript
python实现保存网页到本地示例
2014/03/16 Python
Python脚本文件打包成可执行文件的方法
2015/06/02 Python
python文件名和文件路径操作实例
2017/09/29 Python
Python 查找字符在字符串中的位置实例
2018/05/02 Python
python 处理数字,把大于上限的数字置零实现方法
2019/01/28 Python
对python中的try、except、finally 执行顺序详解
2019/02/18 Python
使用Python Pandas处理亿级数据的方法
2019/06/24 Python
python3中TQDM库安装及使用详解
2020/11/18 Python
基于Django快速集成Echarts代码示例
2020/12/01 Python
python 通过 pybind11 使用Eigen加速代码的步骤
2020/12/07 Python
CSS的background属性及CSS3的背景图片设置总结
2016/06/13 HTML / CSS
英国女性运动服品牌:Sweaty Betty
2018/11/08 全球购物
销售高级职员求职信
2013/10/29 职场文书
原材料检验岗位职责
2014/03/15 职场文书
农民工预备党员思想汇报
2014/09/14 职场文书
酒店管理失职检讨书
2014/09/16 职场文书
2019年房屋委托租赁合同范本(通用版)!
2019/07/17 职场文书
详解TypeScript中的类型保护
2021/04/29 Javascript
默认网关不可用修复后过一会又不好使了解决方法
2022/04/08 数码科技
css中有哪些方式可以隐藏页面元素及区别
2022/06/16 HTML / CSS