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...
[jQuery] Komplexes Problem mit $.Ajax
Beitrag
<blockquote data-quote="Crackp0t" data-source="post: 1448102" data-attributes="member: 55692"><p><strong>[jQuery] Problem beim Senden von Daten mit $.Ajax</strong></p><p></p><p>Hi, ich steh mal wieder total aufm Schlauch, vieleicht könnt ihr mir weiterhelfen :hmpf:</p><p></p><p>Ich habe eine Form die wie folgt aussieht:</p><p></p><p>[html]<span id="setIp" class="values"></p><p><p class="attributes">IP-Address:</p></p><p><span class="edit"></p><p><span class="fields"></p><p><input class="valIP" name="ip_1" type="text" value="" maxlength="3" size="2" disabled="true" />.</p><p><input class="valIP" name="ip_2" type="text" value="" maxlength="3" size="2" disabled="true" />.</p><p><input class="valIP" name="ip_3" type="text" value="" maxlength="3" size="2" disabled="true" />.</p><p><input class="valIP" name="ip_4" type="text" value="" maxlength="3" size="2" disabled="true" /></p><p></span></p><p><input class="enableForm" type="button" value="edit" /></p><p><input class="send" type="submit" value="save" /></p><p><input class="reset" type="reset" value="reset" /></p><p><p class="invalInput"></p></p><p></span></p><p></span>[/html]Die Daten in den Input-Feldern sollen beim Klick auf "save" per Ajax an eine CGI-Datei geschickt werden. Da ich mehrere Forms dieser Art auf einer Seite benutze, habe ich mir einen entsprechenden Selektor in jQuery (jQ ist mit jQuery.noConflict() aufgrund von MooTools als neuer Namespace gewählt) gebastelt, um genau auf diese Forms zu kommen:</p><p></p><p>[php]var elm= "#" + jQ(this).parents().map(function () { </p><p>return this.id; </p><p>}).get(1);</p><p>[/php]Dabei dient das <span> Element mit der Klasse "values" und der jeweiligen ID als Referenzpunkt um anschließend mit</p><p></p><p>[php]jQ(elm).find(".valIP")[/php]Die Felder oder Buttons zu selektieren.</p><p></p><p>Leider weiß ich leider nicht wie ich diese Daten korrekt an das Script per $.Ajax bzw jQ.Ajax übergebe. Mein Ansatz ist total umständlich und liefert eine seltsam-falsche URL:</p><p></p><p>[php]</p><p></p><p>var sdata = new Array();</p><p>sdata[0] = new Object();</p><p>sdata[0] [jQ(elm).find(".valIP").map(function(){</p><p>return jQ(this).attr("name");</p><p>}).get(0)] = jQ(elm).find(".valIP").map(function(){</p><p>return jQ(this).val();</p><p>}).get(0);</p><p></p><p>sdata[1] = new Object();</p><p>sdata[1] [jQ(elm).find(".valIP").map(function(){</p><p>return jQ(this).attr("name");</p><p>}).get(1)] = jQ(elm).find(".valIP").map(function(){</p><p>return jQ(this).val();</p><p>}).get(1);</p><p></p><p>sdata[2] = new Object();</p><p>sdata[2] [jQ(elm).find(".valIP").map(function(){</p><p>return jQ(this).attr("name");</p><p>}).get(2)] = jQ(elm).find(".valIP").map(function(){</p><p>return jQ(this).val();</p><p>}).get(2);</p><p></p><p>sdata[3] = new Object();</p><p>sdata[3] [jQ(elm).find(".valIP").map(function(){</p><p>return jQ(this).attr("name");</p><p>}).get(3)] = jQ(elm).find(".valIP").map(function(){</p><p> return jQ(this).val();</p><p>}).get(3);</p><p></p><p>jQ.ajax({</p><p>url: "cgi-bin/set_ip_test.sh",</p><p>type: "get",</p><p>dataType: "html",</p><p>data: sdata,</p><p>cache: false,</p><p>error: function(){</p><p>jQ(elm).find(".invalInput").text("Failed to send data");</p><p>},</p><p>success: function(strData){</p><p>jQ(this).css("display", "none");</p><p>jQ(elm).find(".reset").css("display", "none");</p><p>jQ(elm).find(".enableForm").css("display", "inline");</p><p>jQ(elm).find(".valIP").attr("disabled", "true");</p><p>jQ(elm).find(".invalInput").text(strData);</p><p>}</p><p>});[/php]URL, die ich mit Tamper-Data abgefangen habe:</p><p></p><p>[code]http://192.168.0.140/includes/cgi-bin/set_ip_test.sh?_=1273237148309&undefined=undefined&undefined=undefined&undefined=undefined&undefined=undefined[/code]Ich weiß nicht wo auf einmal "?_=1273237148309" herkommt und warum die Elemente undefined sind. Vieleicht wisst ihr es ja?</p><p></p><p>Bin für jeden Lösungsansatz dankbar <img src="data:image/gif;base64,R0lGODlhAQABAIAAAAAAAP///yH5BAEAAAAALAAAAAABAAEAAAIBRAA7" class="smilie smilie--sprite smilie--sprite1" alt=":)" title="Smile :)" loading="lazy" data-shortname=":)" /></p></blockquote><p></p>
[QUOTE="Crackp0t, post: 1448102, member: 55692"] [b][jQuery] Problem beim Senden von Daten mit $.Ajax[/b] Hi, ich steh mal wieder total aufm Schlauch, vieleicht könnt ihr mir weiterhelfen :hmpf: Ich habe eine Form die wie folgt aussieht: [html]<span id="setIp" class="values"> <p class="attributes">IP-Address:</p> <span class="edit"> <span class="fields"> <input class="valIP" name="ip_1" type="text" value="" maxlength="3" size="2" disabled="true" />. <input class="valIP" name="ip_2" type="text" value="" maxlength="3" size="2" disabled="true" />. <input class="valIP" name="ip_3" type="text" value="" maxlength="3" size="2" disabled="true" />. <input class="valIP" name="ip_4" type="text" value="" maxlength="3" size="2" disabled="true" /> </span> <input class="enableForm" type="button" value="edit" /> <input class="send" type="submit" value="save" /> <input class="reset" type="reset" value="reset" /> <p class="invalInput"></p> </span> </span>[/html]Die Daten in den Input-Feldern sollen beim Klick auf "save" per Ajax an eine CGI-Datei geschickt werden. Da ich mehrere Forms dieser Art auf einer Seite benutze, habe ich mir einen entsprechenden Selektor in jQuery (jQ ist mit jQuery.noConflict() aufgrund von MooTools als neuer Namespace gewählt) gebastelt, um genau auf diese Forms zu kommen: [php]var elm= "#" + jQ(this).parents().map(function () { return this.id; }).get(1); [/php]Dabei dient das <span> Element mit der Klasse "values" und der jeweiligen ID als Referenzpunkt um anschließend mit [php]jQ(elm).find(".valIP")[/php]Die Felder oder Buttons zu selektieren. Leider weiß ich leider nicht wie ich diese Daten korrekt an das Script per $.Ajax bzw jQ.Ajax übergebe. Mein Ansatz ist total umständlich und liefert eine seltsam-falsche URL: [php] var sdata = new Array(); sdata[0] = new Object(); sdata[0] [jQ(elm).find(".valIP").map(function(){ return jQ(this).attr("name"); }).get(0)] = jQ(elm).find(".valIP").map(function(){ return jQ(this).val(); }).get(0); sdata[1] = new Object(); sdata[1] [jQ(elm).find(".valIP").map(function(){ return jQ(this).attr("name"); }).get(1)] = jQ(elm).find(".valIP").map(function(){ return jQ(this).val(); }).get(1); sdata[2] = new Object(); sdata[2] [jQ(elm).find(".valIP").map(function(){ return jQ(this).attr("name"); }).get(2)] = jQ(elm).find(".valIP").map(function(){ return jQ(this).val(); }).get(2); sdata[3] = new Object(); sdata[3] [jQ(elm).find(".valIP").map(function(){ return jQ(this).attr("name"); }).get(3)] = jQ(elm).find(".valIP").map(function(){ return jQ(this).val(); }).get(3); jQ.ajax({ url: "cgi-bin/set_ip_test.sh", type: "get", dataType: "html", data: sdata, cache: false, error: function(){ jQ(elm).find(".invalInput").text("Failed to send data"); }, success: function(strData){ jQ(this).css("display", "none"); jQ(elm).find(".reset").css("display", "none"); jQ(elm).find(".enableForm").css("display", "inline"); jQ(elm).find(".valIP").attr("disabled", "true"); jQ(elm).find(".invalInput").text(strData); } });[/php]URL, die ich mit Tamper-Data abgefangen habe: [code]http://192.168.0.140/includes/cgi-bin/set_ip_test.sh?_=1273237148309&undefined=undefined&undefined=undefined&undefined=undefined&undefined=undefined[/code]Ich weiß nicht wo auf einmal "?_=1273237148309" herkommt und warum die Elemente undefined sind. Vieleicht wisst ihr es ja? Bin für jeden Lösungsansatz dankbar :) [/QUOTE]
Bilder bitte
hier hochladen
und danach über das Bild-Icon (Direktlink vorher kopieren) platzieren.
Zitate einfügen…
Authentifizierung
Wenn ★ = 12, ◇ = 4 und die Hälfte von ★ zu ◇ addiert wird, was ist das Ergebnis?
Antworten
Start
Forum
Sonstiges
Webdesign, Webentwicklung & Programmierung
PHP, Javascript, jQuery, Ajax, nodeJS, MySQL...
[jQuery] Komplexes Problem mit $.Ajax
Oben