09月22日, 2014 1958次
ajax上传有多种方式 这里选择 h5 FileReader方法
<!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> <title>上传</title> <script src="http://libs.baidu.com/jquery/1.4.4/jquery.js"></script> </head> <body> <input type="file" id="input" multiple="multiple"> <div id="content"></div> <script> var inputElement = document.getElementById("input"); inputElement.addEventListener("change", handleFiles, false); function handleFiles(){ var fileList = this.files; var dd = document.getElementById('content'); for( var i = 0 ; i < fileList.length ; i++ ){ upfile(fileList[i]); //调用上传函数 dd.innerHTML += fileList[i].name+"<br>"; } } </script> <script type="text/javascript"> function upfile(opfile){ //定义允许上传的图片格式 在前台就可以直接判断,不合法的格式将不会上传 var filetype = ['jpg','jpeg','png','gif']; if(upfile){ fi = opfile; //得到文件信息 //判断文件格式是否是图片 如果不是图片则返回false var fname = fi.name.split('.'); if(filetype.indexOf(fname[1].toLowerCase()) == -1){ alert('文件格式不支持'); return ; } var fr = new FileReader();//实例化h5的fileReader fr.readAsDataURL(fi); //以base64编码格式读取图片文件 fr.onload = function(frev){ pic = frev.target.result; //得到结果数据 //$('.image_thumb').attr('src',pic); //开始上传之前,预览图片 //使用ajax 利用post方式提交数据 $.post( 'multiple_pic_ajax.php', { message:pic, filename:fname[0], filetype:fname[1], filesize:fi.size }, function(data){ data = eval('('+data+')'); if(data.code == 1 || data.code == 2){ console.log('上传失败') }else if(data.code == 0){ console.log('上传成功') } } ); } } } </script> </body> </html>
如果需要预览 可以加上
$('.image_thumb').attr('src',pic); //开始上传之前,预览图片
后端配合接收 multiple_pic_ajax.php
<?php $imgtype = array( 'gif'=>'gif', 'png'=>'png', 'jpg'=>'jpeg', 'jpeg'=>'jpeg' ); //图片类型在传输过程中对应的头信息 $message = $_POST['message']; //接收以base64编码的图片数据 $filename = $_POST['filename']; //接收文件名称 $ftype = $_POST['filetype']; //接收文件类型 //首先将头信息去掉,然后解码剩余的base64编码的数据 $message = base64_decode(substr($message,strlen('data:image/'.$imgtype[strtolower($ftype)].';base64,'))); $filename = $filename.".".$ftype; $furl = "./uploads/"; //开始写文件 $file = fopen($furl.$filename,"w"); if(fwrite($file,$message) === false){ echo json_encode(array('code'=>1,'con'=>'failed')); exit; } echo json_encode(array('code'=>0,'con'=>$filename));
暂无留言,赶快评论吧