Wie kann ich Benutzer Dateien durch Kopieren / Einfügen hochladen lassen?

9

Ich versuche eine Web-App zu erstellen, die auf ExtJS basiert, und ich arbeite am Datei-Upload-Bereich der App.

Ich möchte, dass Benutzer Dateien hochladen können, indem sie sie kopieren und einfügen - nicht nur den Inhalt der Datei kopieren und einfügen, sondern auch die Datei selbst. In Windows können Sie zum Beispiel "Kopieren" oder "Ausschneiden" im Menü "Bearbeiten" wählen, während eine Datei ausgewählt ist. Wählen Sie dann "Einfügen" und kopieren oder verschieben Sie die Datei. Ich möchte, dass Benutzer Dateien hochladen können zu meiner App im Einfügen-Schritt, indem Sie einfach in ihrem Browser Einfügen wählen.

Ich habe bereits die Drag-and-Drop-API von HTML5 ausprobiert, aber wir möchten diese nicht verwenden. Wir möchten, dass Benutzer Dateien kopieren / ausschneiden und einfügen können, um ihre Dateien hochzuladen (solange sie es sind) kleiner als 20 Megabyte). Wenn der Benutzer den Pfad zu seiner Datei kopiert und diesen direkt in die Seite einfügt und uns mitteilt, wo die Datei zu finden ist, könnte das auch funktionieren.

Kann jemand einen Weg vorschlagen, dies zu tun?

    
Saransh Sharma 11.12.2011, 22:16
quelle

2 Antworten

6

Das Problem ist, dass Sie nicht mit Javascript auf das Dateisystem des Clients zugreifen können. Es gibt diese neue Dateisystem-API , aber Sie können damit nur ein virtuelles Sandbox-Dateisystem erstellen. Ich hatte das gleiche Problem, habe eine Weile darüber nachgedacht und kam auf die folgenden Ideen.

  1. Flash

    Schreiben einer Flash-Bridge, die auf das Dateisystem zugreift und die Javascript-Kommunikation mit ihr über swliveconnect

    ermöglicht

    Problem: Flash hat auch keinen Dateisystemzugriff.

  2. Java-Applet

    Dasselbe wie Flash und wieder mit LiveConnect

    Meiner Meinung nach könnte das funktionieren, aber ich habe es nicht ausprobiert, weil mein Ziel war, Dateisystemzugriff auf ein Chromebook zu bekommen. Und chromeOS unterstützt Java nicht (zumindest ohne etwas Hacking)

  3. ActiveX

    Ich habe auch einige Lösungen gefunden. Ich habe im Applet-Teil aufgegeben, also habe ich das auch nicht ausprobiert.

Wie Jared Farrish sagte, speichert das Betriebssystem beim Kopieren einer Datei nur den Pfad zur Datei in der Zwischenablage. Wenn Sie das Ereignis paste auf Ihrer Webanwendung erhalten, holen Sie die Zeichenfolge aus der Zwischenablage und leiten Sie sie an Ihre Dateibrücke weiter.

    
Dominic Bartl 12.12.2011, 21:54
quelle
-1

Ich habe gesehen, dass DropBox.com dies ermöglicht (in Chrome - schien nicht im IE zu funktionieren). Ich habe nicht speziell ausschneiden und einfügen, sondern Dateien aus einem lokalen Ordner in eine Dropbox-Seite gezogen und die Dateien hochgeladen. Also, das beantwortet nicht direkt Ihre Frage, aber vielleicht können Sie sehen, wie dies in ihrem Code getan wird.

    
Brady Moritz 29.01.2013 20:04
quelle
yii\base\ErrorException
Copied! Copy Stacktrace Search Stackoverflow Search Google Error

PHP Core Warningyii\base\ErrorException

PHP Startup: Unable to load dynamic library 'mongodb.so' (tried: /usr/lib64/php/modules/mongodb.so (/usr/lib64/php/modules/mongodb.so: cannot open shared object file: No such file or directory), /usr/lib64/php/modules/mongodb.so.so (/usr/lib64/php/modules/mongodb.so.so: cannot open shared object file: No such file or directory))

$_GET = [
    'id' => '312014',
    'url' => 'how-can-i-let-users-upload-files-by-copy-paste',
];

$_SESSION = [
    '__flash' => [],
];