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的header和asp中的redirect比较
Oct 09 PHP
PHP下打开phpMyAdmin出现403错误的问题解决方法
May 23 PHP
修改php.ini以达到屏蔽错误信息并记录日志
Jun 16 PHP
PHP错误提示的关闭方法详解
Jun 23 PHP
php使用cookie显示用户上次访问网站日期的方法
Jan 26 PHP
PHP性能分析工具XHProf安装使用教程
May 13 PHP
PHP下载文件的函数实例代码
May 18 PHP
PHP获取不了React Native Fecth参数的解决办法
Aug 26 PHP
PHP入门教程之日期与时间操作技巧总结(格式化,验证,获取,转换,计算等)
Sep 11 PHP
利用php做服务器和web前端的界面进行交互
Oct 31 PHP
php伪静态验证码不显示的解决方案
Sep 26 PHP
PHP 进程池与轮询调度算法实现多任务的示例代码
Nov 26 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
PHP通用检测函数集合
2011/02/08 PHP
PHP常用的文件操作函数经典收藏
2013/04/02 PHP
深入php常用函数的使用汇总
2013/06/08 PHP
使用PHP接受文件并获得其后缀名的方法
2015/08/05 PHP
WordPress迁移时一些常见问题的解决方法整理
2015/11/24 PHP
PHP超低内存遍历目录文件和读取超大文件的方法
2019/05/01 PHP
显示、隐藏密码
2006/07/01 Javascript
JavaScript 动态添加表格行 使用模板、标记
2009/10/24 Javascript
JS 图片缩放效果代码
2010/06/09 Javascript
jQuery 联动日历实现代码
2012/05/31 Javascript
IE的事件传递-event.cancelBubble示例介绍
2014/01/12 Javascript
setTimeout自动触发一个js的方法
2014/01/15 Javascript
node.js中的console.warn方法使用说明
2014/12/09 Javascript
老司机带你解读jQuery插件开发流程
2016/05/16 Javascript
深入理解JavaScript中的并行处理
2016/09/22 Javascript
jquery实现页面加载效果
2017/02/21 Javascript
vue之nextTick全面解析
2017/05/17 Javascript
socket.io与pm2(cluster)集群搭配的解决方案
2017/06/02 Javascript
详解JS转换数值函数Number()、parseInt()、parseFloat()
2018/08/24 Javascript
详解vue-cli@2.x项目迁移日志
2019/06/06 Javascript
JavaScript命名空间模式实例详解
2019/06/20 Javascript
详解为什么Vue中不要用index作为key(diff算法)
2020/04/04 Javascript
从0到1学习JavaScript编写贪吃蛇游戏
2020/07/28 Javascript
实例讲解python中的协程
2018/10/08 Python
python解析含有重复key的json方法
2019/01/22 Python
Python 调用 Outlook 发送邮件过程解析
2019/08/08 Python
Python使用grequests(gevent+requests)并发发送请求过程解析
2019/09/25 Python
HTML5之多线程(Web Worker)
2019/01/02 HTML / CSS
世界上最大的汽车共享网站:Zipcar
2017/01/14 全球购物
delegate与普通函数的区别
2014/01/22 面试题
结婚典礼证婚词
2014/01/08 职场文书
技术股东合作协议书
2014/12/02 职场文书
提取视频中的音频 Python只需要三行代码!
2021/05/10 Python
MySql开发之自动同步表结构
2021/05/28 MySQL
java executor包参数处理功能 
2022/02/15 Java/Android
Win11运行cmd提示“请求的操作需要提升”的两种解决方法
2022/07/07 数码科技