PSD-Tutorials.de
Forum für Design, Fotografie & Bildbearbeitung
Tutkit
Agentur
Hilfe
Kontakt
Start
Forum
Aktuelles
Besonderer Inhalt
Foren durchsuchen
Tutorials
News
Anmelden
Kostenlos registrieren
Aktuelles
Suche
Suche
Nur Titel durchsuchen
Von:
Menü
Anmelden
Kostenlos registrieren
App installieren
Installieren
JavaScript ist deaktiviert. Für eine bessere Darstellung aktiviere bitte JavaScript in deinem Browser, bevor du fortfährst.
Du verwendest einen veralteten Browser. Es ist möglich, dass diese oder andere Websites nicht korrekt angezeigt werden.
Du solltest ein Upgrade durchführen oder einen
alternativen Browser
verwenden.
Antworten auf deine Fragen:
Neues Thema erstellen
Start
Forum
Sonstiges
Webdesign, Webentwicklung & Programmierung
PHP, Javascript, jQuery, Ajax, nodeJS, MySQL...
AJAX Fileupload - Server erhält zu große Daten
Beitrag
<blockquote data-quote="rilight" data-source="post: 1980356" data-attributes="member: 77589"><p>Hallo liebes Forum,</p><p></p><p>ich arbeite immer noch an meinem FileUpload mit Ajax, jQuery und PHP.</p><p>Ich bin jetzt soweit, dass ich Daten vom Client an den Server übertragen kann.</p><p>Was leider nicht funktioniert, dass Daten von Clien- und Serverseite übereinstimmen.</p><p>Wie schon im Titel beschrieben, sind die Daten auf Serverseite größer.</p><p></p><p>Ich hab es bis jetzt immer mit einem Bild getestet:</p><p>Soll: 53.367 Byte</p><p>Ist: 79.034 Byte</p><p></p><p>Könnte das Problem am encoding liegen?</p><p></p><p>Mein Quellcode ist:</p><p></p><p>Client:</p><p></p><p>Hier hatte ich mit $.ajax() und $.post() experimentiert, aber bei beiden kommt das gleiche Ergebnis, die Daten sind auf dem Server zu groß.</p><p>[HTML]</p><p><!Doctype HTML></p><p><html></p><p> <head></p><p> <meta charset="utf-8"></p><p> <title>Dateiupload mit Javascript</title></p><p> </p><p> <style type="text/css"></p><p> #output</p><p> {</p><p> width : 350px;</p><p> border : 1px dotted black;</p><p> padding : 10px;</p><p> margin-top : 25px;</p><p> }</p><p> </style></p><p> </head></p><p> </p><p> <body></p><p> <h2>Meine kleine Spielwiese</h2></p><p> <form id="fileUpload" action="upload.php" method="POST"></p><p> <input type="file" name="dateien[]" id="uploadInput" multiple="multiple"></p><p> <input type="button" value="upload starten" id="uploadStart"></p><p> </form></p><p> <div id="output"></div></p><p> </p><p> <!-- JavaScript Bereich --></p><p> <script type="text/javascript" src="http://code.jquery.com/jquery-1.7.2.js"></script></p><p> <script type="text/javascript"></p><p> $("document").ready(function() {</p><p> </p><p> $("#uploadStart").click(function() {</p><p> // input auswaehlen</p><p> var dateien = $("#uploadInput")[0].files;</p><p> console.log(dateien);</p><p> </p><p> // groesse feststellen</p><p> var groesse = dateien.length;</p><p> </p><p> // jedes Element durchgehen</p><p> for(var i = 0, datei = dateien[i]; i < groesse; ++i)</p><p> {</p><p> var dateiName = datei.name;</p><p> var reader = new FileReader();</p><p> reader.onload = function()</p><p> {</p><p> console.log(reader);</p><p> console.log(reader.result.length);</p><p> //console.log(reader.result);</p><p> /*</p><p> $.ajax({</p><p> url : "upload.php",</p><p> type : "POST",</p><p> timeout : 5000,</p><p> processData : false, // data nicht in String konvertieren</p><p> data : {</p><p> "file_name" : dateiName,</p><p> "file" : this.result</p><p> },</p><p> headers : {</p><p> "enctype" : "multipart/form-data",</p><p> "encoding" : "multipart/form-data"</p><p> }</p><p> });</p><p> */</p><p> $.post('upload.php', {</p><p> file_name : dateiName,</p><p> file : reader.result</p><p> }, function( data ) {</p><p> $("#output").append(data);</p><p> });</p><p> }</p><p> reader.readAsBinaryString(datei);</p><p> }</p><p> });</p><p> </p><p> });</p><p> </script></p><p> </body></p><p></html></p><p>[/HTML]Server:</p><p>[PHP]<?php</p><p></p><p>if( isset($_FILES['file']) )</p><p>{</p><p> echo '$_File isset'."\n";</p><p>}</p><p>elseif( isset($_POST['file']) && isset($_POST['file_name']) )</p><p>{</p><p> $upload_dir = 'upload/';</p><p> $file_name = $_POST['file_name'];</p><p> $file = $_POST['file'];</p><p> </p><p> $handle = fopen($upload_dir.$file, 'wb');</p><p> fwrite($handle, $file);</p><p> fclose($handle);</p><p> </p><p> echo '$_POST isset'."\n";</p><p> echo 'strlen(file_name)'.strlen($_POST['file_name'])."\n";</p><p> echo 'strlen(file)'.strlen($_POST['file'])."\n";</p><p> echo 'strlen(urldecode(file))'.strlen(urldecode($_POST['file']))."\n";</p><p>}</p><p>else</p><p>{</p><p> echo 'nothing isset'."\n";</p><p>}</p><p></p><p>?></p><p>[/PHP]Außerdem merkwürdig ist, dass die Daten nicht in $_FILES sind, sondern nur in $_POST. Laut handbuch, sollten FileUploads mit POST in $_FILES stehen.</p><p></p><p>Daher meine Frage: warum kommen die Daten nicht sauber auf der Serverseite an?</p><p></p><p>Danke schon im Voraus</p><p>rilight</p></blockquote><p></p>
[QUOTE="rilight, post: 1980356, member: 77589"] Hallo liebes Forum, ich arbeite immer noch an meinem FileUpload mit Ajax, jQuery und PHP. Ich bin jetzt soweit, dass ich Daten vom Client an den Server übertragen kann. Was leider nicht funktioniert, dass Daten von Clien- und Serverseite übereinstimmen. Wie schon im Titel beschrieben, sind die Daten auf Serverseite größer. Ich hab es bis jetzt immer mit einem Bild getestet: Soll: 53.367 Byte Ist: 79.034 Byte Könnte das Problem am encoding liegen? Mein Quellcode ist: Client: Hier hatte ich mit $.ajax() und $.post() experimentiert, aber bei beiden kommt das gleiche Ergebnis, die Daten sind auf dem Server zu groß. [HTML] <!Doctype HTML> <html> <head> <meta charset="utf-8"> <title>Dateiupload mit Javascript</title> <style type="text/css"> #output { width : 350px; border : 1px dotted black; padding : 10px; margin-top : 25px; } </style> </head> <body> <h2>Meine kleine Spielwiese</h2> <form id="fileUpload" action="upload.php" method="POST"> <input type="file" name="dateien[]" id="uploadInput" multiple="multiple"> <input type="button" value="upload starten" id="uploadStart"> </form> <div id="output"></div> <!-- JavaScript Bereich --> <script type="text/javascript" src="http://code.jquery.com/jquery-1.7.2.js"></script> <script type="text/javascript"> $("document").ready(function() { $("#uploadStart").click(function() { // input auswaehlen var dateien = $("#uploadInput")[0].files; console.log(dateien); // groesse feststellen var groesse = dateien.length; // jedes Element durchgehen for(var i = 0, datei = dateien[i]; i < groesse; ++i) { var dateiName = datei.name; var reader = new FileReader(); reader.onload = function() { console.log(reader); console.log(reader.result.length); //console.log(reader.result); /* $.ajax({ url : "upload.php", type : "POST", timeout : 5000, processData : false, // data nicht in String konvertieren data : { "file_name" : dateiName, "file" : this.result }, headers : { "enctype" : "multipart/form-data", "encoding" : "multipart/form-data" } }); */ $.post('upload.php', { file_name : dateiName, file : reader.result }, function( data ) { $("#output").append(data); }); } reader.readAsBinaryString(datei); } }); }); </script> </body> </html> [/HTML]Server: [PHP]<?php if( isset($_FILES['file']) ) { echo '$_File isset'."\n"; } elseif( isset($_POST['file']) && isset($_POST['file_name']) ) { $upload_dir = 'upload/'; $file_name = $_POST['file_name']; $file = $_POST['file']; $handle = fopen($upload_dir.$file, 'wb'); fwrite($handle, $file); fclose($handle); echo '$_POST isset'."\n"; echo 'strlen(file_name)'.strlen($_POST['file_name'])."\n"; echo 'strlen(file)'.strlen($_POST['file'])."\n"; echo 'strlen(urldecode(file))'.strlen(urldecode($_POST['file']))."\n"; } else { echo 'nothing isset'."\n"; } ?> [/PHP]Außerdem merkwürdig ist, dass die Daten nicht in $_FILES sind, sondern nur in $_POST. Laut handbuch, sollten FileUploads mit POST in $_FILES stehen. Daher meine Frage: warum kommen die Daten nicht sauber auf der Serverseite an? Danke schon im Voraus rilight [/QUOTE]
Bilder bitte
hier hochladen
und danach über das Bild-Icon (Direktlink vorher kopieren) platzieren.
Zitate einfügen…
Authentifizierung
Wenn ▲ = 7, ▼ = 3, ◇ = 2 und die Summe von ▲ und ▼ durch ◇ geteilt wird, was ist das Ergebnis?
Antworten
Start
Forum
Sonstiges
Webdesign, Webentwicklung & Programmierung
PHP, Javascript, jQuery, Ajax, nodeJS, MySQL...
AJAX Fileupload - Server erhält zu große Daten
Oben