实例 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'; } ?>
运行实例 »
点击 "运行实例" 按钮查看在线实例