Cet article présente principalement la méthode de traitement du téléchargement de fichiers PHP et analyse les problèmes rencontrés lors de l'opération de téléchargement de fichiers PHP et les solutions associées sous forme d'exemples. Les amis dans le besoin peuvent s'y référer
J'ai récemment rencontré. a Je me trompe depuis longtemps et je souhaite partager mes premières réflexions
Le mécanisme de téléchargement de PHP est entièrement encapsulé et peut être implémenté avec seulement quelques lignes de code. comme suit
TÉLÉCHARGEZ le fichier dans le répertoire temporaire –>Utilisez move_uploadde_file() dans le répertoire spécifié
Il s'agit du processus de téléchargement PHP, ou vous pouvez effectuer certains vérification au milieu. Par exemple, déterminez si le document est soumis par téléchargement ou si l'extension de fichier est autorisée par nous
et une série de vérifications. Le code simple que j'ai donné peut être considéré comme un point de départ.
$targetFolder = '/uploads'; // 定义根目录 if (!empty($_FILES)) { $tempFile = $_FILES['Filedata']['tmp_name']; if(is_uploaded_file($tempFile)) { $targetPath = $_SERVER['DOCUMENT_ROOT'] . $targetFolder; $targetFile = rtrim($targetPath,'/') . '/' . $_FILES['Filedata']['name']; $fileTypes = array('jpg','jpeg','gif','png'); // 允许的后缀扩展 $fileParts = pathinfo($_FILES['Filedata']['name']); if (in_array($fileParts['extension'],$fileTypes)) { move_uploaded_file($tempFile,$targetFile); echo '1'; } else { echo '非法上传文档.'; } }else { echo "非法上传文件"; } }
La méthode ci-dessus répond essentiellement aux exigences de téléchargement de fichiers. Mais ce n'est pas ce dont j'ai besoin.
Fonction de téléchargement
Exigences : Cliquez d'abord pour télécharger le document, puis sélectionnez le fichier de téléchargement. Une fois JS téléchargé, une valeur sera renvoyée. afficher le nom d'horodatage actuel. Le fichier se trouve dans la zone Nom du document.
Cliquez ensuite sur Soumettre pour soumettre le formulaire.
Le serveur traite le formulaire soumis et renomme le fichier téléchargé.
Le problème se pose également. Le serveur est IIS, et c'est un répertoire virtuel implémenté à l'aide du mappage.
Dans ce cas, $_SERVER['DOCUMENT_ROOT'] n'est pas dans le répertoire racine du site PHP
Bien que la fonction de téléchargement soit terminée, ce fichier ne peut pas être téléchargé. Pour des raisons de sécurité du serveur, je prévois toujours de placer le fichier sur le site PHP.
Puis je suis tombé dans une limitation de réflexion.
Réfléchissez-y :
Pourquoi je n'ai pas besoin d'implémenter à nouveau le mécanisme de téléchargement de PHP.
PHP ne met-il pas d'abord les fichiers dans le répertoire temporaire ? Alors pourquoi dois-je supposer que le répertoire après le téléchargement JS est également un répertoire temporaire,
, puis copier les fichiers lors de la soumission à nouveau du formulaire. Accédez au répertoire spécifié pour terminer la fonction requise.
PHP a une fonction de copie de fichier Copy(); puis coopère avec la fonction rename(). De cette façon, le deuxième déplacement et le renommage du fichier téléchargé peuvent être terminés.
Remarque : Si vous copiez un fichier de zéro octet sous la plate-forme Windows, copy() renverra FALSE, mais le fichier sera copié correctement.
Ensuite, PHP fait activement référence au mécanisme de traitement de fichiers de Liunx dans le traitement de fichiers. L'efficacité du fonctionnement des fichiers PHP est liée à l'écriture des E/S et au système d'exploitation.
Résumé : Ce qui précède représente l’intégralité du contenu de cet article, j’espère qu’il sera utile à l’étude de chacun.
Recommandations associées :
L'interface d'appel PHP utilise la méthode post pour transmettre les données json
php Méthode simple pour implémenter le tri combiné
Comment combiner PHP avec Ueditor et modifier le chemin de téléchargement de l'image
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!

Dans PHP, vous pouvez utiliser session_status () ou session_id () pour vérifier si la session a commencé. 1) Utilisez la fonction session_status (). Si php_session_active est retourné, la session a été lancée. 2) Utilisez la fonction session_id (), si une chaîne non vide est renvoyée, la session a été démarrée. Les deux méthodes peuvent vérifier efficacement l'état de session et le choix de la méthode à utiliser dépend de la version PHP et des préférences personnelles.

SessionsaRevitalInWebapplications, en particulier pour le commerce de commerce.

La gestion de l'accès simultané sur la session en PHP peut être effectuée par les méthodes suivantes: 1. Utilisez la base de données pour stocker les données de session, 2. Utilisez Redis ou Memcached, 3. Implémentez une stratégie de verrouillage de session. Ces méthodes aident à garantir la cohérence des données et à améliorer les performances de la concurrence.

PhpSessionShaveSeverallimitations: 1) StorageConstraintsCanleadToperformanceIssues; 2) SecurityVulnerAbilitiesLikeSessionFixationAttackSexist; 3) ScaliabilityShalngingDuetoServer-SpecificStorage; 4) SessionxpirationManagementCanBeproblematic; 5) DatapeSisSis irest;

L'équilibrage de charge affecte la gestion de la session, mais peut être résolu avec la réplication de la session, l'adhérence des sessions et le stockage centralisé de session. 1. Session Replication Copy Données de session entre les serveurs. 2. Session Stickleness dirige les demandes d'utilisateurs vers le même serveur. 3. Le stockage centralisé de session utilise des serveurs indépendants tels que Redis pour stocker les données de session pour assurer le partage de données.

Session BlockingSateChnique utilisétoenSureAuser'sessionremainSexclusiVetoonUseratatime.ITCUCIALFORPREVERSDATACORUPRUPTIONANDSECRYSEURCHEBRESSInMulti-userApplications.SessionLockingisImplementEdUsingServer-SidelockingMechanisms, telasreentrantLockinjj

Les alternatives aux séances PHP comprennent des cookies, une authentification basée sur des jetons, des sessions basées sur la base de données et Redis / Memcached. 1.CooKies Gérer les sessions en stockant des données sur le client, ce qui est simple mais faible en sécurité. 2. L'authentification basée sur le token utilise des jetons pour vérifier les utilisateurs, ce qui est hautement sécurisé mais nécessite une logique supplémentaire. 3.Database basée sur les séances stocke les données dans la base de données, qui a une bonne évolutivité mais peut affecter les performances. 4. redis / memcached utilise un cache distribué pour améliorer les performances et l'évolutivité, mais nécessite une correspondance supplémentaire

SessionHijacking fait référence à un attaquant imitant un utilisateur en obtenant le SessionID de l'utilisateur. Les méthodes de prévention comprennent: 1) le chiffrement de la communication à l'aide de HTTPS; 2) Vérification de la source du sessionID; 3) Utilisation d'un algorithme de génération de sessionID sécurisé; 4) Mise à jour régulière du SessionID.


Outils d'IA chauds

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

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

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

Adaptateur de serveur SAP NetWeaver pour Eclipse
Intégrez Eclipse au serveur d'applications SAP NetWeaver.

MinGW - GNU minimaliste pour Windows
Ce projet est en cours de migration vers osdn.net/projects/mingw, vous pouvez continuer à nous suivre là-bas. MinGW : un port Windows natif de GNU Compiler Collection (GCC), des bibliothèques d'importation et des fichiers d'en-tête librement distribuables pour la création d'applications Windows natives ; inclut des extensions du runtime MSVC pour prendre en charge la fonctionnalité C99. Tous les logiciels MinGW peuvent fonctionner sur les plates-formes Windows 64 bits.

VSCode Windows 64 bits Télécharger
Un éditeur IDE gratuit et puissant lancé par Microsoft

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

SublimeText3 version anglaise
Recommandé : version Win, prend en charge les invites de code !
