sql >> Databáze >  >> RDS >> Mysql

soubor se nenahrává v ajax php mysql

Za prvé, funkce serialize() nefunguje pro soubor, měli byste vytvořit objekt formuláře, přes který můžete odesílat data a bude fungovat perfektně Měl jsem stejný problém a právě jsem vyřešil váš problém a funguje 100% protože jsem to testoval. Podívejte se prosím na formulář.

<form name="multiform" id="multiform" action="process.php" method="POST" enctype="multipart/form-data">
               name : <input type="text" name="name" id="name"/>
               </br>
               message : <input type="text" name="message" id="message" />
               </br>
               Image : <input type="file" name="file" id="file" />
        </form>
               <input  type="button" id="multi-post" value="Run Code"></input>
               <div id="multi-msg"></div>
 

Skript.

<script type="text/javascript">
$(document).ready(function(){
$("#multiform").submit(function(e)
{
    var formObj = $(this);
    var formURL = formObj.attr("action");

if(window.FormData !== undefined)  
    {
        var formData = new FormData(this);
        $.ajax({
            url: formURL,
            type: 'POST',
            data:  formData,
            mimeType:"multipart/form-data",
            contentType: false,
            cache: false,
            processData:false,
            success: function(data, textStatus, jqXHR)
            {
                    $("#multi-msg").html('<pre><code>'+data+'</code></pre>');
            },
            error: function(jqXHR, textStatus, errorThrown) 
            {
                $("#multi-msg").html('<pre><code class="prettyprint">AJAX Request Failed<br/> textStatus='+textStatus+', errorThrown='+errorThrown+'</code></pre>');
            }           
       });
        e.preventDefault();
        e.unbind();
   }
});
$("#multi-post").click(function()
    {
    //sending form from here
    $("#multiform").submit();
});

});

</script>
'); }, chyba:function(jqXHR, textStatus, errorThrown) { $("#multi-msg").html('
Žádost AJAX se nezdařila
textStatus='+textStatus+', errorThrown='+errorThrown+'
'); } }); e.preventDefault(); e.unbind( ); }});$("#vícenásobný příspěvek").click(function() { //odeslání formuláře $("#multiform").submit();});});

A váš soubor php je stejný, jaký jsem testoval a funguje.

<?php
  mysql_connect("localhost","root","");
  mysql_select_db("ajaxdatabase");

  $name=$_POST["name"];
  $message=$_POST["message"];
  //storing file in filename variable
    $fileName = $_FILES['file']['name'];
    //destination dir
    $to="image/".$fileName;

    move_uploaded_file($_FILES['file']['tmp_name'],$to);

  $query=mysql_query("INSERT INTO common(name,message,destination) values('$name','$message','$to') ");

  if($query){
    echo "Your comment has been sent";
  }
  else{
    echo "Error in sending your comment";
  }

?>
 



  1. Funkce DATEDIFF v Oracle

  2. Jak vytvořit novou databázi po prvotní instalaci databáze Oracle 11g Express Edition?

  3. SQL Stále dostává chybu s ON UPDATE CASCADE

  4. Pokud je předán prázdný řetězec, nastavte výchozí hodnotu