php+ajax 文件上传代码实例

这篇文章主要介绍了php+ajax的文件上传,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。

本文实例为大家分享了php+ajax 文件上传的具体代码,供大家参考,具体内容如下

html 代码

  1. <form action="{pboot:form fcode=8}" method="post" enctype="multipart/form-data">
  2. <input type="file" name='tables_a' onchange="abs()">
  3. <input type="hidden" name='tables' >
  4. <input type="submit" value="提交">
  5. </form>

项目使用的是pbootCMS 所以地址可忽略

enctype="multipart/form-data"因为设计到文件上传必须在from 表单中添加该属性

js代码

  1. function abs(){
  2. var fileArray = document.getElementById('tables').files[0];
  3. var formData = new FormData();
  4. formData.append("fileArray", fileArray)
  5. $.ajax({
  6. url: "{pboot:httpurl}/api.php/Tables/index",//传向后台服务器文件
  7. type: 'POST', //传递方法
  8. data: formData, //传递的数据
  9. dataType : 'json', //传递数据的格式
  10. async:false, //这是重要的一步,防止重复提交的
  11. cache: false, //设置为false,上传文件不需要缓存。
  12. contentType: false,//设置为false,因为是构造的FormData对象,所以这里设置为false。
  13. processData: false,//设置为false,因为data值是FormData对象,不需要对数据做处理。
  14. success: function (responseStr){
  15. if(responseStr.code != 0){
  16. alert('上传成功');
  17. $('#tables_2').val('{pboot:httpurl}'+responseStr.data);
  18. }else{
  19. alert('上传失败');
  20. }
  21. },
  22. error: function () {
  23. alert("上传错误!");
  24. }
  25. });
  26. }

PHP代码:

  1. public function index()
  2. {
  3. $name = $_FILES['fileArray']['name'];
  4. $last = substr($name,strrpos($name,'.'));
  5. $name = date('YmdHis').rand(10000,99999).$last;
  6. $address = ROOT_PATH.'/upload/'.$name;
  7. if(move_uploaded_file($_FILES['fileArray']['tmp_name'],$address)){
  8. return json(1,'/upload/'.$name);
  9. }else{
  10. return json(0);
  11. }
  12. }

$_FILES['fileArray']['tmp_name'] 是文件的临时存储位置,所以直接将他移动过去就好了。