PHP上传文件代码之入门代码
在php中文件上传我们都是利用表单的post来实例了,注意:标签的 enctype 属性规定了在提交表单时要使用哪种内容类型.在表单需要二进制数据时,比如文件内容,请使用 "multipart/form-data"
这是一种非常简单文件上传方式.基于安全方面的考虑,您应当增加有关什么用户有权上传文件的限制.
实例代码如下:
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<meta http-equiv="Content-Language" content="zh-cn" />
</head>
<body>
<form action="/upload.php" method="post" enctype="multipart/form-data">
<label for="file">Filename:</label>
<input type="file" name="file" id="file" /><br />
<input type="submit" name="submit" value="Submit" />
</form>
<?php
if ($_POST) {
if ($_FILES["file"]["size"] < 2000000) {
if ($_FILES["file"]["error"] > 0) {
echo "Return Code: " . $_FILES["file"]["error"] . "<br />";
} else {
echo "Upload: " . $_FILES["file"]["name"] . "<br />";
echo "Type: " . $_FILES["file"]["type"] . "<br />";
echo "Size: " . ($_FILES["file"]["size"] / 1024) . " Kb<br />";
echo "Temp file: " . $_FILES["file"]["tmp_name"] . "<br />";
if (file_exists("upload/" . $_FILES["file"]["name"])) {
echo $_FILES["file"]["name"] . " already exists. ";
} else {
move_uploaded_file($_FILES["file"]["tmp_name"], "upload/" . $_FILES["file"]["name"]);
echo "Stored in: " . "upload/" . $_FILES["file"]["name"];
}
}
} else {
echo "Invalid file";
}
}
?>
</body>
</html>第一个参数是表单的 input name,第二个下标可以是 "name", "type", "size", "tmp_name" 或 "error".就像这样:
$_FILES["file"]["name"] - 被上传文件的名称
$_FILES["file"]["type"] - 被上传文件的类型
$_FILES["file"]["size"] - 被上传文件的大小,以字节计
$_FILES["file"]["tmp_name"] - 存储在服务器的文件的临时副本的名称
$_FILES["file"]["error"] - 由文件上传导致的错误代码
首先是上传的提交页面upfile.html
实例代码如下:
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> <form action="upload.php" enctype="multipart/form-data" method="POST"> <input type="hidden" name="max_file_size" value="33554432"> <input type="file" name="file"> <input type="submit" name="submit" value="上传" /> </form>
1. PHP支持HTML以POST的方法传输文件,但是form中必须声明enctype的属性="multipart/form-data",否则整个form表单将不起任何作用.
2. form表单中必须含有一个name为MAX_FILE_SIZE的隐藏域,这个隐藏域用来指定用户最大能上传的文件大小,必须声明在所有其他input标签之前.如果文件超大的话,浏览器直接就可以给出提示,不必浪费上传的时间.
下面就是上传处理文件upload.ph,实例代码如下:
<?php
/* 设定上传目录 */
$dest_dir = 'uploads';
/* 检测上传目录是否存在 */
if (!is_dir($dest_dir) || !is_writeable($dest_dir)) {
die("上传目录 " . $dest_dir . " 不存在或无法写入");
}
/* 设置允许上传文件的类型 */
$type = array(
"rar",
"zip",
"txt",
"c"
);
/* 获取上传文件信息 */
$upfile = & $HTTP_POST_FILES['file'];
/* 获取文件后缀名函数 */
function fileext($filename) {
return substr(strrchr($filename, '.') , 1);
}
/* 判断上传文件类型 */
if (!in_array(strtolower(fileext($upfile['name'])) , $type)) {
$text = implode(",", $type);
echo "对不起,您只能上传以下类型文件: ", $text, "<br>";
} else {
/* 设置文件名为"日期_文件名" */
$dest = $dest_dir . '/' . date("ymdHis") . "_" . $upfile['name'];
/* 移动上传文件到指定文件夹 */
$state = move_uploaded_file($upfile['tmp_name'], $dest);
if ($state) {
print ("文件上传成功!<br>");
print ("文件名:" . $dest . "<br>");
print ("上传的文件大小:" . (round($upfile['size'] / 1024, 2)) . " KB<br>");
} else {
/* 处理错误信息 */
switch ($upfile['error']) {
case 1:
die("上传文件大小超出 php.ini:upload_max_filesize 限制<br>");
case 2:
die("上传文件大小超出 MAX_FILE_SIZE 限制<br>");
case 3:
die("文件仅被部分上传<br>");
case 4:
die("没有文件被上传<br>");
case 5:
die("找不到临时文件夹<br>");
case 6:
die("文件写入失败<br>");
}
}
}
?>教程网址:http://www.phprm.com/scxz/fs1691.html
欢迎收藏∩_∩但请保留本文链接。