Table des matières
(把图片拖拽到这里)利用 filereader 获取文件 base64 编码
Maison développement back-end tutoriel php php中通过Ajax如何实现异步文件上传的代码实例_php技巧

php中通过Ajax如何实现异步文件上传的代码实例_php技巧

May 17, 2016 am 09:19 AM
异步 文件上传

1:取得file对象
2:读取2进制数据
3:模拟http请求,把数据发送出去(这里通常比较麻烦)
在forefox下使用 xmlhttprequest 对象的 sendasbinary 方法发送数据;
4:完美实现
遇到的问题
目前仅有 firefox 可以正确上传文件。(chrome也可以采google.gears上传)
对于从firefox和chrome下读取到的文件数据好像不一样(不知道是否是调试工具的原因)
chrome以及其他高级浏览器没有 sendasbinary 方法 只能使用 send 方法发送数据,有可能是上面的原因导致无法正确上传。(经过测试普通文本文件可以正确上传)

复制代码 代码如下:





html5 file and filereader





(把图片拖拽到这里)利用 filereader 获取文件 base64 编码











'
var log = function(msg){
//console['log'](msg);
document.getelementbyid('log').innerhtml += '
  • '+ msg +'
  • ';
    }
    var dp = function(){
    var defconfig = {
    dropwrap : window
    }
    this.init.apply(this, [defconfig]);
    this.file = null;
    }
    dp.prototype = {
    init:function(args){
    var dropwrap = args.dropwrap;
    var _this = this;
    dropwrap.addeventlistener("dragenter", this._dragenter, false);
    dropwrap.addeventlistener("dragover", this._dragover, false);
    dropwrap.addeventlistener('drop', function(e){_this.readfile.call(_this,e)} , false);
    log('window drop bind--ok');
    },
    _dragenter:function(e){e.stoppropagation();e.preventdefault();},
    _dragover:function(e){e.stoppropagation();e.preventdefault();},
    readfile:function(e){
    e.stoppropagation();
    e.preventdefault();
    var dt = e.datatransfer;
    var files = dt.files;
    for(var i = 0; ivar html = html.slice();
    html = this.writeheader(files[i], html);
    this.read(files[i], html);
    }
    },
    read:function(file, h){
    var type = file.type;
    var reader = new filereader();
    reader.onprogress = function(e){
    if (e.lengthcomputable){
    log('progress: ' + math.ceil(100*e.loaded/file.size) +'%')
    }
    };
    reader.onloadstart = function(e){
    log('onloadstart: ok');
    };
    reader.onloadend = function(e){
    var _result = e.target.result;
    //console['log'](e.target);
    log('data uri--ok');
    var d = document.createelement('div');
    h = h.replace('$filebase64$', _result);
    if(/image/.test(file.type)){
    h = h.replace('$data$',_result);
    }
    d.innerhtml = h;
    document.getelementbyid('baseinfo').appendchild(d);
    };
    reader.readasdataurl(file); // www.3ppt.com base 64 编码
    return;
    },
    writeheader:function(file, h){
    log(file.filename + '+' + (file.size/1024));
    return h.replace('$filename$', file.filename).replace("$filesize$",(file.size/1024)+'kb').replace("$filetype$",file.type);
    }
    }
    new dp();
    })()
    // -->


    filereader对象
    var filereader = new filereader();
    filereader.onloadend = function(){
    console.log(this.readystate); // 这个时候 应该是 2
    console.log(this.result); 读取完成回调函数,数据保存在result中
    }
    filereader.readasbinarystring(file);// 开始读取2进制数据 异步 参数为file 对象
    //filereader.readasdataurl(file); // 读取base64
    //filereader.readastext(file);//读取文本信息
    Déclaration de ce site Web
    Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

    Outils d'IA chauds

    Undresser.AI Undress

    Undresser.AI Undress

    Application basée sur l'IA pour créer des photos de nu réalistes

    AI Clothes Remover

    AI Clothes Remover

    Outil d'IA en ligne pour supprimer les vêtements des photos.

    Undress AI Tool

    Undress AI Tool

    Images de déshabillage gratuites

    Clothoff.io

    Clothoff.io

    Dissolvant de vêtements AI

    AI Hentai Generator

    AI Hentai Generator

    Générez AI Hentai gratuitement.

    Article chaud

    R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
    2 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O. Meilleurs paramètres graphiques
    2 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O. Comment réparer l'audio si vous n'entendez personne
    2 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

    Outils chauds

    Bloc-notes++7.3.1

    Bloc-notes++7.3.1

    Éditeur de code facile à utiliser et gratuit

    SublimeText3 version chinoise

    SublimeText3 version chinoise

    Version chinoise, très simple à utiliser

    Envoyer Studio 13.0.1

    Envoyer Studio 13.0.1

    Puissant environnement de développement intégré PHP

    Dreamweaver CS6

    Dreamweaver CS6

    Outils de développement Web visuel

    SublimeText3 version Mac

    SublimeText3 version Mac

    Logiciel d'édition de code au niveau de Dieu (SublimeText3)

    Comment utiliser Laravel pour implémenter les fonctions de téléchargement et de téléchargement de fichiers Comment utiliser Laravel pour implémenter les fonctions de téléchargement et de téléchargement de fichiers Nov 02, 2023 pm 04:36 PM

    Comment utiliser Laravel pour implémenter les fonctions de téléchargement et de téléchargement de fichiers Laravel est un framework Web PHP populaire qui fournit une multitude de fonctions et d'outils pour rendre le développement d'applications Web plus facile et plus efficace. L'une des fonctions couramment utilisées est le téléchargement et le téléchargement de fichiers. Cet article expliquera comment utiliser Laravel pour implémenter les fonctions de téléchargement et de téléchargement de fichiers, et fournira des exemples de code spécifiques. Téléchargement de fichiers Le téléchargement de fichiers fait référence au téléchargement de fichiers locaux sur le serveur pour le stockage. Dans Laravel, nous pouvons utiliser le téléchargement de fichiers

    Implémenter le téléchargement et le téléchargement de fichiers dans les documents Workerman Implémenter le téléchargement et le téléchargement de fichiers dans les documents Workerman Nov 08, 2023 pm 06:02 PM

    Pour implémenter le téléchargement et le téléchargement de fichiers dans des documents Workerman, des exemples de code spécifiques sont requis Introduction : Workerman est un framework de communication réseau asynchrone PHP hautes performances, simple, efficace et facile à utiliser. Dans le développement réel, le téléchargement et le téléchargement de fichiers sont des exigences fonctionnelles courantes. Cet article explique comment utiliser le framework Workerman pour implémenter le téléchargement et le téléchargement de fichiers, et donne des exemples de code spécifiques. 1. Téléchargement de fichiers : le téléchargement de fichiers fait référence à l'opération de transfert de fichiers de l'ordinateur local vers le serveur. Ce qui suit est utilisé

    Comment utiliser gRPC pour implémenter le téléchargement de fichiers dans Golang ? Comment utiliser gRPC pour implémenter le téléchargement de fichiers dans Golang ? Jun 03, 2024 pm 04:54 PM

    Comment implémenter le téléchargement de fichiers à l'aide de gRPC ? Créez des définitions de service de support, y compris des messages de demande et de réponse. Sur le client, le fichier à télécharger est ouvert et divisé en morceaux, puis diffusé sur le serveur via un flux gRPC. Côté serveur, des fragments de fichiers sont reçus et stockés dans un fichier. Le serveur envoie une réponse une fois le téléchargement du fichier terminé pour indiquer si le téléchargement a réussi.

    Simplifiez le traitement du téléchargement de fichiers avec les fonctions Golang Simplifiez le traitement du téléchargement de fichiers avec les fonctions Golang May 02, 2024 pm 06:45 PM

    Réponse : Oui, Golang fournit des fonctions qui simplifient le traitement du téléchargement de fichiers. Détails : le type MultipartFile permet d'accéder aux métadonnées et au contenu des fichiers. La fonction FormFile obtient un fichier spécifique à partir de la demande de formulaire. Les fonctions ParseForm et ParseMultipartForm sont utilisées pour analyser les données de formulaire et les données de formulaire en plusieurs parties. L'utilisation de ces fonctions simplifie le processus de traitement des fichiers et permet aux développeurs de se concentrer sur la logique métier.

    Application rapide : analyse de cas de développement pratique du téléchargement HTTP asynchrone PHP de plusieurs fichiers Application rapide : analyse de cas de développement pratique du téléchargement HTTP asynchrone PHP de plusieurs fichiers Sep 12, 2023 pm 01:15 PM

    Application rapide : analyse de cas de développement pratique de PHP Téléchargement HTTP asynchrone de plusieurs fichiers Avec le développement d'Internet, la fonction de téléchargement de fichiers est devenue l'un des besoins fondamentaux de nombreux sites Web et applications. Pour les scénarios dans lesquels plusieurs fichiers doivent être téléchargés en même temps, la méthode de téléchargement synchrone traditionnelle est souvent inefficace et prend du temps. Pour cette raison, utiliser PHP pour télécharger plusieurs fichiers de manière asynchrone via HTTP est devenu une solution de plus en plus courante. Cet article analysera en détail comment utiliser le HTTP asynchrone PHP à travers un cas de développement réel.

    Comment implémenter le téléchargement de fichiers par glisser-déposer dans Golang ? Comment implémenter le téléchargement de fichiers par glisser-déposer dans Golang ? Jun 05, 2024 pm 12:48 PM

    Comment implémenter le téléchargement de fichiers par glisser-déposer dans Golang ? Activez le middleware ; gérez les demandes de téléchargement de fichiers ; créez du code HTML pour la zone de glisser-déposer ; ajoutez du code JavaScript pour gérer les événements de glisser-déposer.

    Guide avancé de Python asyncio : du débutant à l'expert Guide avancé de Python asyncio : du débutant à l'expert Mar 04, 2024 am 09:43 AM

    Programmation simultanée et asynchrone La programmation simultanée traite de plusieurs tâches s'exécutant simultanément, la programmation asynchrone est un type de programmation simultanée dans laquelle les tâches ne bloquent pas les threads. asyncio est une bibliothèque de programmation asynchrone en python, qui permet aux programmes d'effectuer des opérations d'E/S sans bloquer le thread principal. Boucle d'événements Le cœur d'asyncio est la boucle d'événements, qui surveille les événements d'E/S et planifie les tâches correspondantes. Lorsqu'une coroutine est prête, la boucle d'événements l'exécute jusqu'à ce qu'elle attende les opérations d'E/S. Il met ensuite la coroutine en pause et continue d'exécuter d'autres coroutines. Coroutines Les coroutines sont des fonctions qui peuvent suspendre et reprendre l'exécution. Le mot-clé asyncdef est utilisé pour créer des coroutines. La coroutine utilise le mot-clé wait pour attendre la fin de l'opération d'E/S. Les bases suivantes d'asyncio

    Comment utiliser le framework Hyperf pour le téléchargement de fichiers Comment utiliser le framework Hyperf pour le téléchargement de fichiers Oct 21, 2023 am 09:06 AM

    Comment utiliser le framework Hyperf pour le téléchargement de fichiers nécessite des exemples de code spécifiques Introduction : Avec le développement d'applications Web, la fonction de téléchargement de fichiers est devenue un élément indispensable dans de nombreux projets. Hyperf est un framework de microservices PHP hautes performances qui fournit un riche ensemble de fonctions, notamment le téléchargement de fichiers. Cet article explique comment utiliser le framework Hyperf pour le téléchargement de fichiers et donne des exemples de code spécifiques. 1. Installez le framework Hyperf : Tout d'abord, vous devez installer le framework Hyperf. Vous pouvez passer des compositions

    See all articles