Ajaxを使用してファイルと画像を非同期でアップロードする方法

php中世界最好的语言
リリース: 2018-04-25 14:28:32
オリジナル
1450 人が閲覧しました

今回は、ajaxを使用してファイルと画像を非同期にアップロードする方法を説明します。ajaxがファイルと画像を非同期でアップロードするために使用できる注意事項は何ですか?以下は実際的なケースです。

皆さんこんにちは。この記事では、ウェブページの

ファイルアップロード 機能のコードを紹介します。参考にしていただければ幸いです。

ご存知のとおり、今日のほとんどの主要な Web サイトには、基本的に、ユーザーがお気に入りの写真やその他のファイルをオンラインに保存して、後で使用できるようにすることができます。しかし、Web のファイル アップロード機能とは正確には何でしょうか。ページはどうやって設定するのですか?今回は画像アップロードを例に、ファイルアップロード機能の具体的な手順を説明します。

実際、ファイルをアップロードするには 2 つの方法があります。1 つはフォーム送信からの送信、もう 1 つは ajax を使用して非同期送信を実装することです。ただし、フォームフォーム送信の問題は、アップロードのたびにインターフェイスが更新されることです。が完了し、非同期アップロードが実現できないため、現在、ほとんどすべての Web サイトで ajax 非同期アップロードが使用されています。次に、ajax 非同期アップロードを実装する方法を説明します。

最初にフォームフォームを作成します。コードは次のとおりです:

 <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>
 <p class="con"></p>
ログイン後にコピー
作成が完了したら、まずユーザーがこのWebサイトからアップロードした画像の情報を取得する必要があります。コードは次のとおりです

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);
ログイン後にコピー
ここの formData は、現在必要なストレージ ファイルである Information オブジェクトであり、それを 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=&#39;"+obj.msg+"&#39; alt=&#39;&#39; />");
    $(".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[&#39;file&#39;];
 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);
 }
?>
ログイン後にコピー
このようにして、お気に入りの写真を自分の Web ページにアップロードする手順がすべて完了しました。このコードが役立つことを願っています。

添付ファイル: ファイルをアップロードするときに自分自身に関する他の情報を添付する必要がある場合は、フロントエンド ページのリクエストが完了した後にこのコードを追加するだけです:

//完成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);
  }
  });
 });
ログイン後にコピー
このケースを読んだ後は、この方法をマスターしたと思います。記事など、とても興味深いですね。php 中国語 Web サイトの他の関連記事にも注目してください。

推奨読書:

jQuery は非同期更新を実装します

jQuery がサーバーへのリクエストの取得と投稿を行う方法

以上がAjaxを使用してファイルと画像を非同期でアップロードする方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート