Torna indietro   Hardware Upgrade Forum > Software > Programmazione

ASUS NUC 15 Pro e NUC 15 Pro+, mini PC che fondono completezza e duttilità
ASUS NUC 15 Pro e NUC 15 Pro+, mini PC che fondono completezza e duttilità
NUC 15 Pro e NUC 15 Pro+ sono i due nuovi mini-PC di casa ASUS pensati per uffici e piccole medie imprese. Compatti, potenti e pieni di porte per la massima flessibilità, le due proposte rispondono in pieno alle esigenze attuali e future grazie a una CPU con grafica integrata, accompagnata da una NPU per la gestione di alcuni compiti AI in locale.
Cybersecurity: email, utenti e agenti IA, la nuova visione di Proofpoint
Cybersecurity: email, utenti e agenti IA, la nuova visione di Proofpoint
Dal palco di Proofpoint Protect 2025 emerge la strategia per estendere la protezione dagli utenti agli agenti IA con il lancio di Satori Agents, nuove soluzioni di governance dei dati e partnership rafforzate che ridisegnano il panorama della cybersecurity
Hisense A85N: il ritorno all’OLED è convincente e alla portata di tutti
Hisense A85N: il ritorno all’OLED è convincente e alla portata di tutti
Dopo alcuni anni di assenza dai cataloghi dei suoi televisori, Hisense riporta sul mercato una proposta OLED che punta tutto sul rapporto qualità prezzo. Hisense 55A85N è un televisore completo e versatile che riesce a convincere anche senza raggiungere le vette di televisori di altra fascia (e altro prezzo)
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 25-09-2010, 18:49   #1
DNAx86
Member
 
Iscritto dal: Dec 2007
Città: Friuli
Messaggi: 154
[jquery][php] primo utilizzo

Dato che ho la necessità di inviare un file al server (cosa che non avevo mai fatto) ho provato a utilizzare jquery nel codice JS, scrivendo questa funzione per inviare il file:


Codice:
InsertHandler.prototype.handleFile = function(event) {

    var file = event.target.id;
    //  var filename = file.value;
    //section = SPLIT id
    var filename = $("#OffertaFile").val();

    var par = {};
    par[file] = filename;

    $.post( "http://www.nomeserver.it/PATH/test.php", par, function(){alert("Data Uploaded:");} );
}
Lato server, c'è questo semplice file php di prova:
Codice:
<?php
   print "Received {$_FILES['OffertaFile']['name']} - its size is {$_FILES['OffertaFile']['size']}";
?>
Esito?
Non arriva il file, nel senso che l'output è: Received - its size is

Motivo?

PS: stesso risultato con $.ajax (jquery)
__________________
iPhone4, MacBook
DNAx86 è offline   Rispondi citando il messaggio o parte di esso
Old 25-09-2010, 19:17   #2
Slayer86
Senior Member
 
Iscritto dal: Mar 2006
Città: Riccione
Messaggi: 1851
anche io sto facendo a cazzotti con jquery e php... per realizzare un semplice login...
sembra quasi che il metodo post non faccia niente... non capisco... ho aperto il topic oggi pomeriggio e si potrebbero quasi unire...
Slayer86 è offline   Rispondi citando il messaggio o parte di esso
Old 26-09-2010, 10:28   #3
DNAx86
Member
 
Iscritto dal: Dec 2007
Città: Friuli
Messaggi: 154
Sono riuscito a inviare il file (e a riceverlo),

ho create un iframe invisibile cablato in html.

Ci aggiungo dinamicamente un form con i dovuti attributi,

quindi (dopo aver fatto selezionare il file) sposto un elemento <input type=file> nel form del iFrame invisibile.

a questo punto invio il submit del form nel iFrame invisibile con una chiamata esplicita a submit()

Tutto riesce, MA PERCHE' HO IL CAMBIO PAGINA ?
Non dovrebbe essere una richiesta nascosta dato che a farla è un form dentro un iFrame invisibile?


Manca qualche attributo nel iFrame o nel form in esso contenuto?

qui i codici:

Codice html dell'iFrame
Codice:
                <iframe id="hiddenFrame" style="display:none">
                </iframe>
Settaggio JS
Codice:
    // iFrame & hidden_form  //
    this.hiddenFrame = document.getElementById("hiddenFrame");
    this.hiddenForm = document.createElement("form");
    this.hiddenForm.id = "hiddenForm";
    this.hiddenForm.name = "hiddenForm";
    this.hiddenForm.method = "post";
    this.hiddenForm.action = "http://www.XXX.xxx/test.php";//this.URL;
    this.hiddenForm.enctype="multipart/form-data";
    this.hiddenForm.src="about:blank";
    //this.hiddenForm.target="hiddenForm";
    this.hiddenForm.addEventListener("submit",function(){alert("four");},false);
 
    this.hiddenFrame.appendChild(this.hiddenForm);
Funzione che si attiva quando è stato selezionato il file nel frame visibile
Codice:
InsertHandler.prototype.handleFile = function(event) {

    var file = event.target;
    var fileParent = file.parentNode;

    this.hiddenForm.appendChild(file);
 
    this.hiddenForm.submit();
}
__________________
iPhone4, MacBook
DNAx86 è offline   Rispondi citando il messaggio o parte di esso
Old 27-09-2010, 13:11   #4
vladix
Member
 
L'Avatar di vladix
 
Iscritto dal: Jan 2008
Città: roma
Messaggi: 296
lascia perdere jquery e utilizza dojo ... io mi trovo bene ed ha un sacco di widget che puoi utilizzare
qui trovi una demo di un "file uploader" . Te lo consiglio perchè puoi definire che tipi di file puo uploadare l'utente , la grandezza del file e l'upload multiplo ( puoi selezionare più files contemporaneamente ) non conosco jquery ma da quel che ho visto non mi risulta che abbia queste opzioni
__________________
Acer 5940G{Intel Core i7 Q720 Quadri motore; 8Gb DDR3; ATI Radeon HD 4650 1024MB; 500Gb hdd}
vladix è offline   Rispondi citando il messaggio o parte di esso
Old 28-09-2010, 13:20   #5
Slayer86
Senior Member
 
Iscritto dal: Mar 2006
Città: Riccione
Messaggi: 1851
Quote:
Originariamente inviato da DNAx86 Guarda i messaggi
Sono riuscito a inviare il file (e a riceverlo),

ho create un iframe invisibile cablato in html.

Ci aggiungo dinamicamente un form con i dovuti attributi,

quindi (dopo aver fatto selezionare il file) sposto un elemento <input type=file> nel form del iFrame invisibile.

a questo punto invio il submit del form nel iFrame invisibile con una chiamata esplicita a submit()

Tutto riesce, MA PERCHE' HO IL CAMBIO PAGINA ?
Non dovrebbe essere una richiesta nascosta dato che a farla è un form dentro un iFrame invisibile?


Manca qualche attributo nel iFrame o nel form in esso contenuto?

qui i codici:

Codice html dell'iFrame
Codice:
                <iframe id="hiddenFrame" style="display:none">
                </iframe>
Settaggio JS
Codice:
    // iFrame & hidden_form  //
    this.hiddenFrame = document.getElementById("hiddenFrame");
    this.hiddenForm = document.createElement("form");
    this.hiddenForm.id = "hiddenForm";
    this.hiddenForm.name = "hiddenForm";
    this.hiddenForm.method = "post";
    this.hiddenForm.action = "http://www.XXX.xxx/test.php";//this.URL;
    this.hiddenForm.enctype="multipart/form-data";
    this.hiddenForm.src="about:blank";
    //this.hiddenForm.target="hiddenForm";
    this.hiddenForm.addEventListener("submit",function(){alert("four");},false);
 
    this.hiddenFrame.appendChild(this.hiddenForm);
Funzione che si attiva quando è stato selezionato il file nel frame visibile
Codice:
InsertHandler.prototype.handleFile = function(event) {

    var file = event.target;
    var fileParent = file.parentNode;

    this.hiddenForm.appendChild(file);
 
    this.hiddenForm.submit();
}
DNAx86, istruiscimi... pure io mi ritrovo a fare a pugni con l'upload di un file, poi siccome il file in questione dovrà avere dei riferimenti all'interno di un db mi trovo un atimo in difficoltà...

Cmq... io creo nel codice html l'iframe nascosto, poi ci inserisco dentro un form e tutti i campi che mi servono via javascript, una volta fatto questo posso passare al form nascosto tutti i dati che ho inserito in quello visibile giusto?
Slayer86 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


ASUS NUC 15 Pro e NUC 15 Pro+, mini PC che fondono completezza e duttilità ASUS NUC 15 Pro e NUC 15 Pro+, mini PC che fondo...
Cybersecurity: email, utenti e agenti IA, la nuova visione di Proofpoint Cybersecurity: email, utenti e agenti IA, la nuo...
Hisense A85N: il ritorno all’OLED è convincente e alla portata di tutti Hisense A85N: il ritorno all’OLED è convi...
Recensione Borderlands 4, tra divertimento e problemi tecnici Recensione Borderlands 4, tra divertimento e pro...
TCL NXTPAPER 60 Ultra: lo smartphone che trasforma la lettura da digitale a naturale TCL NXTPAPER 60 Ultra: lo smartphone che trasfor...
Steelseries Arctis Nova Elite: le prime ...
30 anni di PlayStation da indossare: arr...
Amazon lancia gli Echo più potent...
Amazon rinnova la gamma Fire TV: ecco le...
Ring lancia le sue prime videocamere con...
Blink amplia la gamma di videocamere di ...
Jaguar Land Rover riprende (gradualmente...
HONOR inaugura il primo ALPHA Flagship S...
Yamaha: ecco il brevetto del 'finto moto...
'Console obsoleta e utenti ingannati': u...
Stop al ransomware su Google Drive, graz...
L'IA è la nuova interfaccia utent...
Battlefield 6: confermata la dimensione ...
Windows 11 porta il Wi-Fi 7 alle aziende...
Logitech MX Master 4 subito disponibile ...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 20:44.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Served by www3v