菜单

ajax实现公文异步上传并回显文件有关消息功能示例

2018年11月15日 - Ajax

正文实例讲述了ajax实现文件异步上传并回显文件有关信息意义。分享给大家供大家参考,具体如下:

世家吓,这篇稿子我而叫大家大饱眼福一个网页文件上传功能的代码,希望大家可以有所参考,或者受自己取些建议。

上传文件之音

明明现在底诸大网站为主都是文件及传功能,用户可以管自己爱的图样或外文件在网上存起来,以便以后用的下便宜去追寻,可是一个网页的文本上传功能究竟欠怎么去装也?今天己就为图上传为条例为大家来得文件及传功能的具体步骤。

<div class="form-group">
  <div class="col-sm-4">
  <label class="control-label">应用文件</label>
</div>
<div class="col-sm-8">
  <input type="file" name="appFile" id="appFile">
  <input type="submit" value="确认上传" id="subm">
</div>

实际上文件上污染有些许种植办法,一种是from表单submit提交,一种是ajax实现异步提交,可是form表单提交有只问题虽是每次在上传完成时会刷新界面,不克兑现异步上传,所以现在几乎有网站都采用ajax异步上传,现在本人受大家来得ajax异步上传该如何实现。

ajax提交

第一自己先创造一个form表单,代码如下:

$("#subm").click(function(){
    var formData = new FormData();
    formData.append("appFile", document.getElementById("appFile").files[0]);
    alert("8888888888888888888888888");
    $.ajax({
      url: '${ctx}/appresources/fileUpload.shtml',
      type: "POST",
      data: formData,
      dataType: "json",
      contentType: false,
      processData: false,
      success: function (data) {
        alert("上传成功");
        $("#versionCode").val(data.versionCode);
        $("#appVersion").val(data.appVersion);
        $("#appPackageName").val(data.appPackageName);
      },
      error: function () {
        alert("上传失败!");
      }
    });
});
 <form action="" id="form">
  用户名:<input type="text" name="user"/></br>
  密码:<input type="password" name="pass" /></br>
  性别:<input type="radio" name="sex" value="男"/>男
   <input type="radio" name="sex" value="女"/>女
  头像:<input type="file" id="file" name="file"/></br>
  <button id="btn" type="button">提交</button>
 </form>
 <div class="con"></div>

后台处理:

开创好后,首先我们而先拿到用户从以及污染之图形的音信,代码如下

@ResponseBody
@RequestMapping("fileUpload")
public JSONObject fileUpload(MultipartFile appFile,Model model,HttpServletRequest request,HttpServletResponse response) {
    ServletContext
//........................省略
    String infos=ApkUtil.getApkInfo(needPath+"source"+File.separator+"apk"+File.separator+fileName);
    String[] info=infos.split(",");
    String versionCode=info[0];//版本号
    String versionName=info[1];//版本名
    String packageName=info[2];//包名
    String appName=fileName;
    AppResourcesFormMap appResourcesFormMap = getFormMap(AppResourcesFormMap.class);
    appResourcesFormMap.put("appName",fileName);
    appResourcesFormMap.put("appVersion",versionName);
    appResourcesFormMap.put("appPackageName",packageName);
    appResourcesFormMap.put("versionCode", versionCode);
    System.out.println(appResourcesFormMap);
    //model.addAttribute("appresources", appResourcesFormMap);
    JSONObject fromObject = JSONObject.fromObject(appResourcesFormMap);
    //String string = fromObject.toString();
    return fromObject;
}
var imgs=[];//存储图片链接
 //为文件上传添加change事件
 var fileM=document.querySelector("#file");
 $("#file").on("change",function(){
  console.log(fileM.files);
  //获取文件对象,files是文件选取控件的属性,存储的是文件选取控件选取的文件对象,类型是一个数组
  var fileObj=fileM.files[0];
  //创建formdata对象,formData用来存储表单的数据,表单数据时以键值对形式存储的。
  var formData=new FormData();
  formData.append('file',fileObj);

又多关于ajax相关内容感兴趣的读者可查本站专题:《jquery中Ajax用法总结》、《JavaScript中ajax操作技能总结》、《PHP+ajax技巧及以小结》及《asp.net
ajax技巧总结专题》

这边的formData就是咱们现在使之仓储文件信息之对象,然后我们用将其用ajax请求提交给后台:

希望本文所述对大家ajax程序设计具有助。

  //创建ajax对象
  var ajax=new XMLHttpRequest();
  //发送POST请求
  ajax.open("POST","http://localhost/phpClass/file-upload/move_file.php",true);
  ajax.send(formData);
  ajax.onreadystatechange=function(){
  if (ajax.readyState == 4) {
   if (ajax.status>=200 &&ajax.status<300||ajax.status==304) {
   console.log(ajax.responseText);
   var obj=JSON.parse(ajax.responseText);
   alert(obj.msg);
   if(obj.err == 0){、
    //上传成功后自动动创建img标签放在指定位置
    var img =$("<img src='"+obj.msg+"' alt='' />");
    $(".con").append(img);
    imgs.push(obj.msg);
   }else{
    alert(obj.msg);
   }
   }
  }
  }
 });

而或许感兴趣的篇章:

然后我们请求成功后,后台肯定使做出相应的拍卖,并且把图纸存到指定的公文夹里,所以相应的PHP应该形成这些操作:

<?php
//解决跨域问题
header("Access-Control-Allow-Origin:*");
//说明向前台返回的数据类型为JSON
header("Content-type:text/json");
//$_FILES超全局变量存储是文件数据,是一个关联数组
 $fileObj=$_FILES['file'];
 var_dump($fileObj);
 if($fileObj["error"]==0){
 //判断文件是否合法
 $types=["jpg","jpeg","png","gif"];
 $type = explode("/", $fileObj["type"])[1];
 if(in_array($type, $types)){
  $time = time();//获取时间戳 返回一个整形
  //获取文件详细路径
  $filePath="http://localhost/phpClass/image1".$time.".".$type;
  echo $filePath;
  //移动文件
  $res=move_uploaded_file($fileObj["tmp_name"],"../image1/".$time.".".$type);
  if($res){
  $infor=array("err"=>0,"msg"=>"文件移动成功");
  }else{
  $infor=array("err"=>1,"msg"=>"文件移动失败");
  }
 }else{
  $infor=array("err"=>1,"msg"=>"文件格式不合法");
 }
 echo json_encode($infor);
 }
?>

这样我们就是完了了文本上传的拥有手续,如果你想把好爱的图片,上传到自己之网页上,希望马上段代码可以拉及您!

倚:如果达到污染文书时还要附带上您的旁信息,你才待另行前端页面请求完成后增长这段代码即可实现:

//完成form表单数据的提交
 $('#btn').on('click',function(){
//  serializeArray()将form表单控件中的数据序列化成数组,数组中含有若干对象,对象包含对应控件的name和value
  var infor = $('#form').serializeArray();
//  console.log(infor);
  var stu = {};
  for (var i=0;i<infor.length;i++) {
  var obj=infor[i];
  stu[obj.name] = obj.value;
  }
  stu["imgs"] = imgs;
  stu["imgs"] = imgs[0];

  //发送ajax请求
  $.ajax({
  url:"http://localhost/phpClass/file-upload/data.php",
  data:{
   parameter :JSON.stringify(stu)
  },
  success:function(res){
   console.log(res.msg);
  }
  });
 });

又多精彩内容请参见专题《ajax上传技能汇总》展开学习。

上述就是本文的全部内容,希望对大家的念有助,也指望大家多多支持脚本的拙。

公可能感兴趣之章:

相关文章

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图