效果图【前端页面】:
前端页面:
<form action="upload_file.php" method="post" enctype="multipart/form-data">
<label for="file">文件名:</label>
<input type="file" name="file" id="file"><br>
<input type="submit" name="submit" value="提交">
</form>
注意:
- 标签的 enctype 属性规定了在提交表单时要使用哪种内容类型。在表单需要二进制数据时,比如文件内容,请使用"**multipart/form-data"**。
- 标签的 type=“file”
属性规定了应该把输入作为文件来处理。举例来说,当在浏览器中预览时,会看到输入框旁边有一个浏览按钮。
PHP:
<?php
// 允许上传的图片后缀
$allowedExts = array("gif", "jpeg", "jpg", "png");
$temp = explode(".", $_FILES["file"]["name"]);
echo $_FILES["file"]["size"];
$extension = end($temp); // 获取文件后缀名
if ((($_FILES["file"]["type"] == "image/gif")
|| ($_FILES["file"]["type"] == "image/jpeg")
|| ($_FILES["file"]["type"] == "image/jpg")
|| ($_FILES["file"]["type"] == "image/pjpeg")
|| ($_FILES["file"]["type"] == "image/x-png")
|| ($_FILES["file"]["type"] == "image/png"))
&& ($_FILES["file"]["size"] < 204800) // 小于 200 kb
&& in_array($extension, $allowedExts))
{
if ($_FILES["file"]["error"] > 0)
{
echo "错误:: " . $_FILES["file"]["error"] . "<br>";
}
else
{
echo "上传文件名: " . $_FILES["file"]["name"] . "<br>";
echo "文件类型: " . $_FILES["file"]["type"] . "<br>";
echo "文件大小: " . ($_FILES["file"]["size"] / 1024) . " kB<br>";
echo "文件临时存储的位置: " . $_FILES["file"]["tmp_name"] . "<br>";
// 判断当前目录下的 upload 目录是否存在该文件
// 如果没有 upload 目录,你需要创建它,upload 目录权限为 777
if (file_exists("upload/" . $_FILES["file"]["name"]))
{
echo $_FILES["file"]["name"] . " 文件已经存在。 ";
}
else
{
// 如果 upload 目录不存在该文件则将文件上传到 upload 目录下
move_uploaded_file($_FILES["file"]["tmp_name"], "upload/" . $_FILES["file"]["name"]);
echo "文件存储在: " . "upload/" . $_FILES["file"]["name"];
}
}
}
else
{
echo "非法的文件格式";
}
?>
注意:
- 获取扩展名的另一种方法:pathinfo($_FILES,PATHINFO_EXTENSION);
$_FILES[“file”][“name”] - 上传文件的名称
$_FILES[“file”][“type”] - 上传文件的类型
$_FILES[“file”][“size”] - 上传文件的大小,以字节计
$_FILES[“file”][“tmp_name”] - 存储在服务器的文件的临时副本的名称
$_FILES[“file”][“error”] - 由文件上传导致的错误代码 - List item
if ($_POST) {
$title = $_POST['title']; //名称
$cid = $_POST['cid']; //文章类型
$note = $_POST['note']; //描述
$content = htmlspecialchars($_POST['content']); // 文章内容
$s_title = $_POST['s_title']; //关键字标题
$s_keywords = $_POST['s_keywords']; //内容关键字
$s_desc = $_POST['s_desc']; //关键字描述
$datetime = time(); //发布时间
$authour = $_POST['authour']; //作者
$views = $_POST['views']; //流量
//提前准备好上传图片的路径
$pic_url = "http://localhost/news_admin/upload/"; //上传文件的路径
if ($_FILES['img']['error'] > 0) {
echo "文件上传错误" . $_FILES['img']['error'];
} else {
// 检查文件类型
if (!in_array($_FILES['img']['type'], array('image/jpeg', 'image/png', 'image/gif'))) {
echo "只运行上传jpg或png图片, 文件类型不合法,不允许上传";
return;
}
//检查文件大小
if($_FILES['img']['size'] > 5*1024*1024){
echo '文件最大为5M';
return;
}
//判断文件夹是否存在
if(!is_dir($pic_url)){
mkdir($pic_url,0777,true);
}
// 判断文件是否存在
if(file_exists('upload/'.$_FILES['img']['name'])){
echo $_FILES['img']['name'].'已经存在';
return;
}
// 保存上传的文件
move_uploaded_file($_FILES['img']['tmp_name'],'upload/'.$_FILES['img']['name']);
$pic_url .= $_FILES['img']['name']; //图片路径,用于存入数据库
}
$sql_insert = "insert into news_list(category_id,title,content,tag,author,pic,created_at) values('$cid','$title','$content','$s_title','$authour','$pic_url','$datetime')";
$res_insert = mysqli_query($conn,$sql_insert);
// echo $sql_insert;
// var_dump($res_insert);
if($res_insert){
echo '<script>alert("发布成功");</script>';
header('Location:list.php');
}
}
总结:
-
与文件上传有关的配置
post_max_size = 8M:表单允许的最大值 upload_max_filesize = 2M:允许上传的文件大小 upload_tmp_dir =F:\wamp\tmp:指定临时文件地址,如果不知道操作系统指定 file_uploads = On:是否允许文件上传 max_file_uploads = 20:允许同时上传20个文件
-
pathinfo("1.txt",PATHINFO_EXTENSION)
-
$extension = pathinfo("1.txt");返回的一个数组