Maison développement back-end tutoriel php Comment le type de valeur renvoyée par la fonction PHP affecte-t-il la sécurité des téléchargements de fichiers ?

Comment le type de valeur renvoyée par la fonction PHP affecte-t-il la sécurité des téléchargements de fichiers ?

Apr 15, 2024 pm 12:42 PM
php 函数返回值

Le type de valeur de retour de la fonction PHP joue un rôle essentiel dans la sécurité du téléchargement de fichiers, notamment : is_uploaded_file() vérifie la légalité du téléchargement de fichiers. filesize() limite la taille du fichier pour empêcher les téléchargements de fichiers malveillants. pathinfo() vérifie l'extension du fichier et limite les types de fichiers téléchargés. move_uploaded_file() indique si le fichier a été déplacé avec succès vers un emplacement permanent.

PHP 函数返回值的类型如何影响文件上传的安全性?

Comment le type de valeur de retour de la fonction PHP affecte la sécurité des téléchargements de fichiers

Introduction

Le téléchargement de fichiers est une opération courante dans les applications Web, mais s'il n'est pas géré correctement, il peut conduire à une sécurité sérieuse risques Vulnérabilité sexuelle. Le type de valeur de retour de la fonction en PHP joue un rôle crucial dans la sécurité du téléchargement de fichiers.

Vérification du type de fichier

Lors du téléchargement de fichiers, il est crucial de vérifier le type du fichier. Cela permet d'empêcher le téléchargement de fichiers malveillants sur le système. La fonction is_uploaded_file() en PHP renvoie une valeur booléenne indiquant si le fichier a été téléchargé via le mécanisme de téléchargement de fichier HTTP traditionnel. is_uploaded_file() 函数返回一个布尔值,指示文件是否通过了传统的 HTTP 文件上传机制上传。

if (is_uploaded_file($_FILES['file']['tmp_name'])) {
    // 文件上传正确
} else {
    // 文件上传无效
}
Copier après la connexion

文件大小限制

限制上传文件的最大尺寸对于防止攻击者上传恶意或大型文件至关重要。PHP 中 filesize() 函数返回文件的大小,以字节为单位。

$size = filesize($_FILES['file']['tmp_name']);
if ($size > 1000000) {
    // 文件太大,拒绝上传
}
Copier après la connexion

扩展名检查

检查文件的扩展名可以帮助限制上传的文件类型。PHP 中 pathinfo() 函数可以获取文件的扩展名。

$info = pathinfo($_FILES['file']['name']);
if (!in_array($info['extension'], ['jpg', 'png', 'pdf'])) {
    // 非法文件类型,拒绝上传
}
Copier après la connexion

移动上传文件

一旦文件经过验证,将其移动到永久位置至关重要。PHP 中 move_uploaded_file()

if (move_uploaded_file($_FILES['file']['tmp_name'], '/uploads/file.jpg')) {
    // 文件已成功移动
} else {
    // 文件移动失败
}
Copier après la connexion

Limite de taille de fichier

Il est crucial de limiter la taille maximale des fichiers téléchargés pour empêcher les attaquants de télécharger des fichiers malveillants ou volumineux. La fonction filesize() en PHP renvoie la taille du fichier en octets.

<?php

if (!is_uploaded_file($_FILES['file']['tmp_name'])) {
    die('文件上传错误');
}

$size = filesize($_FILES['file']['tmp_name']);
if ($size > 1000000) {
    die('文件太大');
}

$info = pathinfo($_FILES['file']['name']);
if (!in_array($info['extension'], ['jpg', 'png', 'pdf'])) {
    die('非法文件类型');
}

if (!move_uploaded_file($_FILES['file']['tmp_name'], '/uploads/' . $info['basename'])) {
    die('文件移动失败');
}

echo '文件已成功上传';
?>
Copier après la connexion
🎜Extension Check🎜🎜🎜Vérifier l'extension d'un fichier peut aider à limiter les types de fichiers téléchargés. La fonction pathinfo() en PHP peut obtenir l'extension de fichier. 🎜rrreee🎜🎜Fichiers de téléchargement mobile🎜🎜🎜Une fois le fichier vérifié, il est crucial de le déplacer vers un emplacement permanent. La fonction move_uploaded_file() en PHP renvoie une valeur booléenne indiquant si le fichier a été déplacé avec succès. 🎜rrreee🎜🎜Cas pratique🎜🎜🎜Le code suivant montre un script de traitement de téléchargement de fichier PHP sécurisé. 🎜rrreee

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 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)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Où trouver la courte de la grue à atomide atomique
1 Il y a quelques semaines By DDD

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)

Configuration du projet CakePHP Configuration du projet CakePHP Sep 10, 2024 pm 05:25 PM

Dans ce chapitre, nous comprendrons les variables d'environnement, la configuration générale, la configuration de la base de données et la configuration de la messagerie dans CakePHP.

Guide d'installation et de mise à niveau de PHP 8.4 pour Ubuntu et Debian Guide d'installation et de mise à niveau de PHP 8.4 pour Ubuntu et Debian Dec 24, 2024 pm 04:42 PM

PHP 8.4 apporte plusieurs nouvelles fonctionnalités, améliorations de sécurité et de performances avec une bonne quantité de dépréciations et de suppressions de fonctionnalités. Ce guide explique comment installer PHP 8.4 ou mettre à niveau vers PHP 8.4 sur Ubuntu, Debian ou leurs dérivés. Bien qu'il soit possible de compiler PHP à partir des sources, son installation à partir d'un référentiel APT comme expliqué ci-dessous est souvent plus rapide et plus sécurisée car ces référentiels fourniront les dernières corrections de bogues et mises à jour de sécurité à l'avenir.

Date et heure de CakePHP Date et heure de CakePHP Sep 10, 2024 pm 05:27 PM

Pour travailler avec la date et l'heure dans cakephp4, nous allons utiliser la classe FrozenTime disponible.

CakePHP travaillant avec la base de données CakePHP travaillant avec la base de données Sep 10, 2024 pm 05:25 PM

Travailler avec la base de données dans CakePHP est très simple. Nous comprendrons les opérations CRUD (Créer, Lire, Mettre à jour, Supprimer) dans ce chapitre.

Téléchargement de fichiers CakePHP Téléchargement de fichiers CakePHP Sep 10, 2024 pm 05:27 PM

Pour travailler sur le téléchargement de fichiers, nous allons utiliser l'assistant de formulaire. Voici un exemple de téléchargement de fichiers.

Routage CakePHP Routage CakePHP Sep 10, 2024 pm 05:25 PM

Dans ce chapitre, nous allons apprendre les sujets suivants liés au routage ?

Discuter de CakePHP Discuter de CakePHP Sep 10, 2024 pm 05:28 PM

CakePHP est un framework open source pour PHP. Il vise à faciliter grandement le développement, le déploiement et la maintenance d'applications. CakePHP est basé sur une architecture de type MVC à la fois puissante et facile à appréhender. Modèles, vues et contrôleurs gu

CakePHP créant des validateurs CakePHP créant des validateurs Sep 10, 2024 pm 05:26 PM

Le validateur peut être créé en ajoutant les deux lignes suivantes dans le contrôleur.

See all articles