mysql|程序|数据
PHP代码:-------------------------------------------------------------------------------- // 文件名:filedb.php 将文件储存到数据库中 /* 将文件上传存入 MySQL 数据库的例子 数据表的结构如下: CREATE TABLE files ( id int(4) NOT NULL auto_increment, filename varchar(64), filesize int(16), filetype varchar(64), filecontent longblob, remark text, PRIMARY KEY (id) ); */ // 设定系统参数变量,根据需要修改 $DB_SERVER = "127.0.0.1"; # 数据库连接字 $DB_USER = "root"; # 用户名 $DB_PASS = ""; # 密码 $DB_NAME = "article"; # 数据库名 $TABLE_NAME = "files"; # 数据表名 $HANDLER_SCRIPT = "mysql数据库显示文件.php"; # 处理数据的脚本文件名 $PHP_SELF=$_SERVER['PHP_SELF']; ?>
将文件存入数据库 if (isset($_POST["submit"])) // 表单被提交后执行以下代码
{
if (!is_uploaded_file($_FILES['userfile']['tmp_name'])) // 检查文件是否上传成功
{
die("文件上传失败!");
}
$link = mysql_connect($DB_SERVER, $DB_USER, $DB_PASS) // 连接数据库
or die("连接数据库失败!");
mysql_select_db($DB_NAME);
$filename = addslashes($_FILES['userfile']['name']); # 为了正确保存入数据库,
$filesize = addslashes($_FILES['userfile']['size']); # 对所有的插入数据都要
$filetype = addslashes($_FILES['userfile']['type']); # 进行 addslashes 操作
// 读入上传的文件并做预处理 #
$tmp_name = $_FILES['userfile']['tmp_name'];
$fd = fopen ($tmp_name, "rb");
$contents = fread ($fd, filesize ($tmp_name));
fclose ($fd);
$filecontent = addslashes($contents);
$tmp_name = $_FILES['userfile']['tmp_name'];
$fd = fopen ($tmp_name, "rb");
$contents = fread ($fd, filesize ($tmp_name));
fclose ($fd);
$filecontent = addslashes($contents);
$remark = addslashes($_POST['description']);
$query_string = "INSERT INTO $TABLE_NAME VALUES ('', '$filename', '$filesize', '$filetype', '$filecontent', '$remark')";
$result = mysql_query($query_string) or die("数据插入失败!"); # 进行数据插入操作
echo "
保存成功! \n"; echo "文件名 :{$_FILES['userfile']['name']} \n"; echo "文件大小:{$_FILES['userfile']['size']} 字节 \n"; echo "文件类型:{$_FILES['userfile']['type']}
\n";
echo "
";
}
echo "
\n";
$link = mysql_connect($DB_SERVER, $DB_USER, $DB_PASS) // 显示数据库已有记录
or die("连接数据库失败!");
mysql_select_db($DB_NAME);
$query_string = "SELECT * FROM $TABLE_NAME ORDER BY id"; # 取出所有记录,无分页显示功能
$result = mysql_query($query_string) or die("查询出错!");
while ($row = mysql_fetch_array($result))
{
$remark = nl2br(htmlspecialchars($row["remark"])); # 为了正确显示说明,需要作预处理
echo "
ID 文件名 文件大小 文件类型 说明 连接 删除
$row[id] $row[filename] $row[filesize] $row[filetype] $remark 点击查看
$result = mysql_query($query_string) or die("查询出错!"); if (mysql_num_rows($result) == 0) // 判断查询是否成功 die("查无记录!"); $row = mysql_fetch_array($result); # 取得查询结果 $filecontent = $row["filecontent"]; # 取得文件内容 $filetype = $row["filetype"]; # 取得文件类型 $filename = $row["filename"]; # 取得文件名 header("Content-Type: $filetype"); # 输出 HTTP 头信息,文件的 MIME 类型 header("Content-Disposition: inline; filename=\"$filename\""); # 这样可以给出文件# header("Content-Disposition: attachment; filename=\"$filename\""); # 这样可以迫使 IE 下载文件而不显示 echo $filecontent; # 输出文件 } } ?>