php关于file表单与ajax无刷新的问题
upload1.php代码如下
<br /><script type="text/javascript"><br />function checkfile(name){<br /> var xhr;<br /> if(window.XMLHttpRequest){<br /> xhr = new XMLHttpRequest();<br /> }<br /> else xhr = new ActiveXObject("Microsoft.XMLHTTP");<br /><br /> xhr.onreadystatechange=function(){<br /> if(xhr.readyState == "4" && xhr.status == "200"){<br /> document.getElementById("err").innerHTML = xhr.responseText;<br /> }<br /> }<br /><br /> xhr.open("POST","result.php",true);<br /> xhr.setRequestHeader("Content-type","application/x-www-form-urlencoded");<br /> xhr.send("name=" + name);<br />}<br /></script><br /><form enctype="multipart/form-data" method="post" action="upload2.php"><br /> <input type="hidden" name="MAX_FILE_SIZE" value="10000" /><br /> 上传文件:<input type="file" name="filename" onchange="checkfile(this.value)" /><br /><br /> <input type="submit" value="上传" /><br /><br /> <br /> <p id="err"></p><br /></form><br />
现将file中的onchange作为事件将我选择的文件名通过value传入checkfile()并请求result.php进行处理并回发,从而实现无刷新提示.
result.php代码如下
<br /><?php<br /><br /> $filepath = $_POST["name"]; <br /> $err = "";<br /> if(filesize($filepath) > 10000) $err = "文件不得超过10kb!";<br /> <br /> echo $err;<br /><br />?><br />
运行结果显示警告:

我把获取到的$_POST["name"] echo 显示出来确实是“E:\\图册\\图片\\壁纸\\其他\\2.jpg”,感觉不是upload1.php那边传值的问题。
然后我新建一个文件测试filesize(“E:\\图册\\图片\\壁纸\\其他\\2.jpg”),echo出来页面显示是109739也没问题。
那么到底哪里出了问题?
------解决方案--------------------
filesize 只能返回本地文件的大小
------解决方案--------------------
先搞清楚,客户端与服务器端。
filesize只能获取到服务器上的文件大小。
一开始你post的name,路径是你客户端的图片,并未保存到服务器,因此,filesize不可以获取到。
而你写死了if(filesize("E:\\图册\\图片\\壁纸\\其他\\2.jpg")>10000) 相当于直接读取服务器文件,当然就可以了。

Pour protéger l'application des attaques XSS liées à la session, les mesures suivantes sont nécessaires: 1. Définissez les drapeaux httponly et sécurisés pour protéger les cookies de session. 2. Codes d'exportation pour toutes les entrées utilisateur. 3. Implémentez la politique de sécurité du contenu (CSP) pour limiter les sources de script. Grâce à ces politiques, les attaques XSS liées à la session peuvent être protégées efficacement et les données utilisateur peuvent être assurées.

Les méthodes pour optimiser les performances de la session PHP incluent: 1. Delay Session Start, 2. Utilisez la base de données pour stocker les sessions, 3. Compress Session Data, 4. Gérer le cycle de vie de la session et 5. Implémenter le partage de session. Ces stratégies peuvent améliorer considérablement l'efficacité des applications dans des environnements de concurrence élevés.

Thesesse.gc_maxlifetimesettingInphpdeterminesthelifespanofessiondata, setInSeconds.1) it'sconfiguredInphp.Iniorviaini_set (). 2)

Dans PHP, vous pouvez utiliser la fonction session_name () pour configurer le nom de session. Les étapes spécifiques sont les suivantes: 1. Utilisez la fonction session_name () pour définir le nom de session, tel que session_name ("my_session"). 2. Après la définition du nom de la session, appelez session_start () pour démarrer la session. La configuration des noms de session peut éviter les conflits de données de session entre plusieurs applications et améliorer la sécurité, mais faire attention à l'unicité, à la sécurité, à la longueur et à la définition du calendrier des noms de session.

L'ID de session doit être régénéré régulièrement lors de la connexion, avant les opérations sensibles et toutes les 30 minutes. 1. Régénérez l'ID de session lors de la connexion pour empêcher les attaques fixes de session. 2. Régénérer avant les opérations sensibles pour améliorer la sécurité. 3. La régénération régulière réduit les risques d'utilisation à long terme, mais l'expérience utilisateur doit être pesée.

La définition des paramètres de cookie de session dans PHP peut être réalisée via la fonction Session_Set_COOKIE_PARAMS (). 1) Utilisez cette fonction pour définir des paramètres, tels que le temps d'expiration, le chemin, le nom de domaine, le drapeau de sécurité, etc.; 2) Appelez session_start () pour que les paramètres prennent effet; 3) Ajuster dynamiquement les paramètres en fonction des besoins, tels que l'état de connexion de l'utilisateur; 4) Faites attention à la définition de drapeaux sécurisés et httponly pour améliorer la sécurité.

L'objectif principal de l'utilisation de sessions en PHP est de maintenir l'état de l'utilisateur entre différentes pages. 1) La session est lancée via la fonction session_start (), créant un ID de session unique et le stockant dans le cookie utilisateur. 2) Les données de session sont enregistrées sur le serveur, permettant de passer les données entre différentes demandes, telles que l'état de connexion et le contenu du panier.

Comment partager une session entre les sous-domaines? Implémenté en définissant des cookies de session pour les noms de domaine communs. 1. Définissez le domaine du cookie de session sur .example.com côté serveur. 2. Choisissez la méthode de stockage de session appropriée, telle que la mémoire, la base de données ou le cache distribué. 3. Passez l'ID de session via des cookies, et le serveur récupère et met à jour les données de session en fonction de l'ID.


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

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

Navigateur d'examen sécurisé
Safe Exam Browser est un environnement de navigation sécurisé permettant de passer des examens en ligne en toute sécurité. Ce logiciel transforme n'importe quel ordinateur en poste de travail sécurisé. Il contrôle l'accès à n'importe quel utilitaire et empêche les étudiants d'utiliser des ressources non autorisées.

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 !