博客列表 >文件上传的完整实现过程,要求提示信息全部采用Ajax方式显示: 2018年4月19日作业

文件上传的完整实现过程,要求提示信息全部采用Ajax方式显示: 2018年4月19日作业

杜苏华迈专注于物联网可视化管理的博客
杜苏华迈专注于物联网可视化管理的博客原创
2018年04月20日 23:44:12827浏览

作业截图.png作业截图2.png



实例  Ajax  上传前端代码

<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>文件上传的完整实现过程,要求提示信息全部采用Ajax方式显示</title>
	<style type="text/css">
	form {
		width: 400px;
	}
	button {
	        width: 400px;
			height: 50px;
            background-color: greenyellow;
		}
	button:hover {
			background-color: green;
			color: white;
			font-size:1.2em;
		}
	</style>
</head>
<body>


	<form action="upload.php" method="POST" enctype="multipart/form-data">
		<!-- 用隐藏域设置允许上传的文件大小:MAX_FILE_SIZE 按字节计算 -->
		<input type="hidden" name="MAX_FILE_SIZE" value="542488">
		<fieldset>
			<legend align="center">上传文件</legend>
			<p align="center"><strong>请选择文件:</strong><input type="file" name="upload"></p>
		</fieldset>
		<p align="center"><button type="submit" name="submit" id="sub">点击上传文件</button></p>
	</form>



	<script type="text/javascript" src="http://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js"></script>
	<script type="text/javascript">


			$.ajax({
				//请求外部资源
				url:'upload.php',
				//客户端请求类型:GET,POST...
	            dataType: "POST",


	            	//成功回调
	            success: function (data) {
	            	console.log(data)
					$('p span').empty()
					$('p').append($(data))

                }
	            })
		    })

	</script>
</body>
</html>

运行实例 »

点击 "运行实例" 按钮查看在线实例



实例  上传后台代码  upload.php

<meta charset="UTF-8">
<?php
	//检测请求类型是否POST,如果不是应该提示用户类型不对
	if ($_SERVER['REQUEST_METHOD'] == 'POST') {
		//检测是否有文件被上传
		if (isset($_FILES['upload'])) {
			//设置允许上传的文件类型
			$allow = ['image/jpg','image/jpeg', 'image/png','image/gif'];
			if (in_array($_FILES['upload']['type'], $allow)) {
				//将文件先移动到临时目录
				if (move_uploaded_file($_FILES['upload']['tmp_name'], "upload/{$_FILES['upload']['name']}")){
					//上传成功
					echo "<script>alert('文件上传成功')</script>";
				}
			}else {
					//提示格式不对
					echo "<script>alert('仅允许上传jpg和png格式的图片')</script>";
				}
		}
		//对上传错误进行处理
		if ($_FILES['upload']['error'] > 0 ) {
			echo '<p>错误原因是:<strong>';

			switch ($_FILES['upload']['error']) {
				case 1:
					echo '文件超过了php.ini配置中设置的大小';
					break;
				case 2:
					echo '文件超过了表单中常量设置的大小';
					break;
				case 3:
					echo '仅有部分文件被上传';
					break;
				case 4:
					echo '没有文件被上传';
					break;
				case 6:
					echo '没有可用的临时文件夹';
					break;
				case 7:
					echo '磁盘已满,写入失败';
					break;
				case 8:
					echo '上传意外中止';
					break;

				default:
					echo '系统未知错误';
					break;
			}

			echo '</strong></p>';
			//保险起见,最好把创建的临时文件删除,当然系统也会在结束会话时自动清空
			if (file_exists($_FILES['upload']['tmp_name']) && is_file($_FILES['upload']['tmp_name'])) {
				unlink($_FILES['upload']['tmp_name']);
			}
		}
	} else {
		echo '1';
	}
?>

运行实例 »

点击 "运行实例" 按钮查看在线实例


声明:本文内容转载自脚本之家,由网友自发贡献,版权归原作者所有,如您发现涉嫌抄袭侵权,请联系admin@php.cn 核实处理。
全部评论
文明上网理性发言,请遵守新闻评论服务协议