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 error_log 函数的使用
Apr 13 PHP
php下统计用户在线时间的一种尝试
Aug 26 PHP
php读取mysql乱码,用set names XXX解决的原理分享
Dec 29 PHP
PHPEXCEL 使用小记
Jan 06 PHP
DOM XPATH获取img src值的query
Sep 23 PHP
FireFox浏览器使用Javascript上传大文件
Oct 30 PHP
php文件上传的例子及参数详解
Dec 12 PHP
如何使用php脚本给html中引用的js和css路径打上版本号
Nov 18 PHP
smarty的section嵌套循环用法示例
May 28 PHP
CI框架入门之MVC简单示例
Nov 21 PHP
thinkPHP引入类的方法详解
Dec 08 PHP
php记录搜索引擎爬行记录的实现代码
Mar 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
《逃离塔科夫》——“萌新劝退,老手自嗨”的硬核FPS游戏
2020/04/03 其他游戏
长波有什么东西
2021/03/01 无线电
PHP入门速成(2)
2006/10/09 PHP
PHP gbk环境下json_dencode传送来的汉字
2012/11/13 PHP
浅谈PHP中output_buffering
2015/07/13 PHP
php获取目录中所有文件名及判断文件与目录的简单方法
2017/03/04 PHP
PHP递归实现文件夹的复制、删除、查看大小操作示例
2017/08/11 PHP
ASP.NET中使用后端代码注册脚本 生成JQUERY-EASYUI的界面错位的解决方法
2010/06/12 Javascript
深入理解JavaScript系列(6) 强大的原型和原型链
2012/01/15 Javascript
浏览器解析js生成的html出现样式问题的解决方法
2012/04/16 Javascript
JS提交form表单实例分析
2015/12/10 Javascript
jQuery插件学习教程之SlidesJs轮播+Validation验证
2016/07/12 Javascript
浅谈JavaScript中的this指针和引用知识
2016/08/05 Javascript
基于MVC5和Bootstrap的jQuery TreeView树形控件(二)之数据支持json字符串、list集合
2016/08/11 Javascript
基于JavaScript实现下拉列表左右移动代码
2017/02/07 Javascript
使用jQuery实现简单的tab框实例
2017/08/22 jQuery
完美解决手机网页中输入框被输入法遮挡的问题
2017/12/19 Javascript
Vue 通过自定义指令回顾v-内置指令(小结)
2018/09/03 Javascript
Vue触发隐藏input file的方法实例详解
2019/08/14 Javascript
Vue双向绑定实现原理与方法详解
2020/05/07 Javascript
Python采集腾讯新闻实例
2014/07/10 Python
用Django实现一个可运行的区块链应用
2018/03/08 Python
python实现将读入的多维list转为一维list的方法
2018/06/28 Python
python 定时任务去检测服务器端口是否通的实例
2019/01/26 Python
Pycharm运行加载文本出现错误的解决方法
2019/06/27 Python
3种python调用其他脚本的方法
2020/01/06 Python
Python Websocket服务端通信的使用示例
2020/02/25 Python
FOREO官方网站:LUNA露娜洁面仪
2016/11/28 全球购物
泰国在线书店:SE-ED
2020/06/21 全球购物
2014离婚协议书范文
2014/09/10 职场文书
农村文化建设标语
2014/10/07 职场文书
乱丢垃圾袋检讨书
2014/10/08 职场文书
2014年学习委员工作总结
2014/11/14 职场文书
2014年高校辅导员工作总结
2014/12/09 职场文书
大学生考试作弊被抓检讨书
2014/12/27 职场文书
python中的3种定义类方法
2021/11/27 Python