Maison  >  Article  >  développement back-end  >  Exemple de partage de PHP à l'aide du module APC pour implémenter la barre de progression du téléchargement

Exemple de partage de PHP à l'aide du module APC pour implémenter la barre de progression du téléchargement

*文
*文original
2017-12-25 14:13:311529parcourir

Cet article présente principalement comment PHP utilise le module APC pour implémenter la barre de progression du téléchargement de fichiers, analyse l'utilisation spécifique du module APC et donne les instructions de configuration liées à APC. J'espère que cela aide tout le monde.

Les versions précédentes de php5.2 ne peuvent pas utiliser le module APC, car il n'existe pas du tout de module APC. Si vous souhaitez utiliser le module APC pour implémenter la barre de progression de téléchargement, nous devons être php5.2 ou. version supérieure.

À partir de la version 5.2, APC a ajouté quelque chose appelé APC_UPLOAD_PROGRESS, qui résout le problème de la barre de progression qui dérange tout le monde depuis longtemps. Et cela a modifié la méthode originale de mise en cache de tous les fichiers temporaires dans la mémoire pendant le téléchargement pour les enregistrer automatiquement sur le disque dur lorsque les fichiers temporaires atteignent la valeur définie, ce qui a effectivement amélioré l'utilisation de la mémoire.

Cela fonctionne en attribuant à chaque téléchargement un identifiant unique lors du téléchargement. Lorsque le script PHP reçoit un fichier téléchargé, l'interpréteur vérifie automatiquement le champ caché nommé APC_UPLOAD_PROGRESS dans le tableau $_POST qui deviendra une variable de cache. stocke les informations sur le téléchargement afin que les scripts puissent accéder aux informations d'état sur le fichier téléchargé via l'ID de téléchargement.

APC est l'abréviation de Alternative PHP Cache, qui est un cache de code optimisé gratuit et public pour PHP. Il est utilisé pour fournir un cadre gratuit, ouvert et robuste pour la mise en cache et l'optimisation du code intermédiaire PHP.

Configuration des paramètres du module APC, le code est le suivant :

Name Default Changeable Changelog  
apc.enabled 1 PHP_INI_ALL  
apc.shm_segments 1 PHP_INI_SYSTEM  
apc.shm_size 30 PHP_INI_SYSTEM  
apc.optimization 0 PHP_INI_ALL  
apc.num_files_hint 1000 PHP_INI_SYSTEM  
apc.ttl 0 PHP_INI_SYSTEM  
apc.gc_ttl 3600 PHP_INI_SYSTEM  
apc.cache_by_default On PHP_INI_SYSTEM  
apc.filters "" PHP_INI_SYSTEM  
apc.mmap_file_mask "" PHP_INI_SYSTEM  
apc.slam_defense 0 PHP_INI_SYSTEM  
apc.file_update_protection 2 PHP_INI_SYSTEM  
apc.enable_cli 0 PHP_INI_SYSTEM > APC 3.0.6


Une fois la configuration terminée, commencez à écrire le programme maintenant

Le code XML/HTML est le suivant :

<!–以下为上传表单–>  
<form enctype="multipart/form-data" id="upload_form" action="" method="POST">  
<input type="hidden" name="APC_UPLOAD_PROGRESS" id="progress_key" value="upid"/>  
视频标题:<input type="text" id="subject" name="subject"/>  
视频说明:<input type="text" id="content" name="content"/>  
视频TAG(以逗号分割)<input type="text" id="tag" name="tags"/>  
<input type="file" id="upfile" name="upfile"/>  
<input type="submit" id="filesubmit" value="上传" onclick="startProgress(&#39;upid&#39;); return true;"/>  
<!–注意:startProgress(&#39;upid&#39;)中的参数是你从php中分配的唯一上传参数–>  
</form>  
<!–以下为上传进度条–>  
<p id="upstatus" style="width: 500px; height: 30px; border: 1px solid ##ffffde; color:#796140;">  
</p  
<p id="progressouter" style="width: 500px; height: 20px; border: 3px solid #de7e00; display:none;">  
<p id="progressinner" style="position: relative; height: 20px; color:#796140; background-color: #f6d095; width: 0%; "></p>  
</p>

Le plus important est le champ caché de APC_UPLOAD_PROGRESS. Avec lui, le script peut accéder à l'état du fichier. fichier actuellement téléchargé, et ajoutez-en un autre pour afficher l'état de téléchargement.

Ce qui suit est un script pour gérer Ajax. J'ai utilisé le framework Jquery et json pour transmettre des messages.

Le code JavaScript est le suivant :

function getProgress(upid){  
var url = "<{$siteurl}>epadmin/upprocess";  
$.getJSON(  
url,  
{ progress_key: upid },  
function(json){  
$("#progressinner").width(json.per+"%");  
$("#upstatus").html(&#39;文件大小:&#39;+json.total+&#39;KB&#39;+&#39; 已上传:&#39;+json.current+&#39;KB&#39;);  
if (json.per < 100){  
setTimeout(function(){  
getProgress(upid);  
}, 10);  
}else{  
$("#upstatus").html("视频上传完成,正在处理数据,请稍后……");  
}  
}  
)  
}  
function startProgress(upid){  
$("#progressouter").css({ display:"block" });  
setTimeout(function(){  
getProgress(upid);  
}, 100);  
}

Ce qui suit est le code PHP pour lire l'état de téléchargement. Quant au traitement des fichiers téléchargés, vous. peut l'écrire comme d'habitude. Le code est le suivant :

//上传文件操作函数,可按照自己的需要编写  
function upflvAction()  
{  
if($_SERVER[&#39;REQUEST_METHOD&#39;]==&#39;POST&#39;){  
$subject = trim($this->f->filter($this->_request->getPost(&#39;subject&#39;)));  
$content = trim($this->f->filter($this->_request->getPost(&#39;content&#39;)));  
Zend_Loader::loadClass(&#39;Custom_FlvOp&#39;);  
$flv = new Custom_FlvOp;  
$flv->uploadFlv(&#39;upfile&#39;,$subject,$content);  
}
}  
//这就是读取上传状态的函数了~~  
function upprocessAction()  
{   
if(isset($_GET[&#39;progress_key&#39;])) {  
$status = apc_fetch(&#39;upload_&#39;.$_GET[&#39;progress_key&#39;]);  
$json = array(  
&#39;per&#39;=>$status[&#39;current&#39;]/$status[&#39;total&#39;]*100,  
&#39;total&#39;=>round($status[&#39;total&#39;]/1024),  
&#39;current&#39;=>round($status[&#39;current&#39;]/1024),  
);  
require_once("Zend/Json.php");  
echo Zend_Json::encode($json);  
}  
}


Quelques détails sur la configuration d'apc :

apc.enabled Boolean

apc.enabled peut être défini sur 0 pour désactiver APC. Ceci est principalement utile lorsque APC est lors de la compilation statique en PHP, car il n'y a pas d'autre moyen de le désactiver, lors de la compilation en DSO, vous pouvez commenter la ligne d'extension dans php.ini.

apc.shm_segments entier

Le nombre de blocs de mémoire partagée alloués au cache de compilation Si APC manque de mémoire partagée et que vous avez défini apc.shm_size sur la valeur maximale. autorisé par le système, vous pouvez essayer d'augmenter la valeur de ce paramètre

apc.shm_size Integer

La taille de chaque bloc de mémoire partagée est en Mo. Par défaut, certains systèmes (y compris la plupart des variantes BSD) ont des limites de taille de bloc de mémoire partagée très faibles.

apc.optimization Integer

Niveau d'optimisation. Réglé sur 0 pour désactiver l'optimisation, des valeurs plus élevées utilisent des optimisations plus puissantes. Attendez-vous à de modestes améliorations de vitesse. Ceci est encore de nature expérimentale.

apc.num_files_hint integer

Un indice sur le nombre de fichiers sources différents inclus et demandés sur votre serveur Web. En cas de doute, définissez-le sur 0 ou omettez-le ; ce paramètre sera probablement utile principalement sur les sites contenant des milliers de fichiers sources.

apc.ttl Integer

Lorsqu'une entrée de cache est nécessaire à une autre entrée dans la zone de cache, ce que nous devons considérer est que l'emplacement de l'entrée de cache dans la zone de cache peut être libre . Nombre de secondes. Définir ce paramètre sur 0 signifie que votre cache peut être rempli d'entrées obsolètes et que les nouvelles entrées ne seront pas mises en cache.

apc.gc_ttl Integer

Le nombre de secondes pendant lesquelles l'entrée du cache reste active dans la liste de récupération de place. Cette valeur offre une protection contre les erreurs dans le cas où un fichier source mis en cache est exécuté alors que le processus serveur s'arrête. Si ce fichier source est modifié, la mémoire allouée à l'ancienne version de l'entrée de cache ne sera pas récupérée tant que la valeur TTL définie par ce paramètre n'est pas atteinte. Le définir sur 0 désactive cette fonctionnalité.

apc.cache_by_default Booléen

Par défaut sur On, mais peut être défini sur Off et utilisé avec apc.filters commençant par un signe plus. Les fichiers ne seront mis en cache que s'ils correspondent au filtre.

apc.filters String

Une liste d'expressions régulières étendues POSIX séparées par des virgules. Si un modèle correspond au nom du fichier source, le fichier ne sera pas mis en cache. Notez que le nom de fichier utilisé pour la correspondance est le nom de fichier transmis à include/require, et non le chemin absolu. Si le premier caractère de l'expression régulière est + , alors l'expression signifie que tout fichier correspondant à l'expression sera mis en cache, si le premier caractère est - alors aucune correspondance ne sera mise en cache. - est la valeur par défaut, elle peut donc être omise.

apc.mmap_file_mask chaîne

apc.slam_defense entier

Sur un serveur très occupé, que vous démarriez un service ou modifiiez un fichier, vous provoquerez une course à plusieurs processus essayant de mettre en cache le même fichier en même temps. Cette option définit le pourcentage auquel le processus ignore les tentatives de mise en cache d'un fichier non mis en cache. Ou considérez cela comme la probabilité qu'un seul processus ignore le cache. Par exemple, définir apc.slam_defense sur 75 signifie que le processus a 75 % de chances de ne pas mettre en cache les fichiers non mis en cache. Par conséquent, plus le paramètre est élevé, plus il est probable que la probabilité de collision du cache soit réduite. Réglez sur 0 pour désactiver cette fonctionnalité.

apc.file_update_protection integer

Lorsque vous modifiez un fichier sur un serveur en cours d'exécution, vous devez effectuer des opérations atomiques. Autrement dit, écrivez d'abord un fichier temporaire, puis renommez (mv) le fichier à son emplacement final une fois terminé. De nombreux éditeurs de texte, cp, tar et certains autres programmes similaires ne fonctionnent pas de cette façon. Cela signifie qu'il est possible d'accéder et de (mettre en cache) le fichier pendant que le fichier est encore en cours d'écriture. Le paramètre apc.file_update_protection entraîne un retard du cache dans le marquage des nouveaux fichiers. La valeur par défaut est 2, ce qui signifie que si l'heure de modification du fichier s'avère inférieure à 2 secondes de l'heure d'accès, le fichier ne sera pas mis en cache. Les utilisateurs malchanceux qui accèdent à un fichier à moitié écrit verront un comportement bizarre, mais au moins il n'est pas persistant. Si vous êtes sûr d'utiliser fréquemment des opérations atomiques pour mettre à jour vos fichiers, vous pouvez désactiver cette protection en définissant ce paramètre sur 0. Si votre système est inondé d'opérations d'E/S et que le processus de mise à jour prend plus de 2 secondes, vous devrez peut-être augmenter cette valeur.

apc.enable-cli integer

est principalement destiné aux tests et au débogage, pour activer la fonctionnalité APC pour la version CLI de PHP De manière générale, vous n'y penserez pas pour chaque requête CLI Créer. , portez et supprimez le cache d'APC, mais pour diverses situations de test, il est facile d'activer APC pour la version CLI

Recommandations associées :>Exemple de code pour utiliser le cache apc en php

.

Memcached PHP Memcached + APC + code d'implémentation de l'encapsulation du cache de fichiers

PHP OPCode cache APC introduction détaillée

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
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