La sécurité est une autre fonctionnalité importante lors de la création d'applications Web. Il assure aux utilisateurs du site que leurs données sont sécurisées. CakePHP fournit quelques outils pour sécuriser votre application.
Cryptage et Décryptage
La bibliothèque de sécurité de CakePHP fournit des méthodes par lesquelles nous pouvons crypter et déchiffrer les données. Voici les deux méthodes utilisées dans le même but.
static Cake\Utility\Security::encrypt($text, $key, $hmacSalt = null) static Cake\Utility\Security::decrypt($cipher, $key, $hmacSalt = null)
La méthode de cryptage prendra le texte et la clé comme argument pour crypter les données et la valeur de retour sera la valeur cryptée avec la somme de contr?le HMAC.
Pour hacher une donnée, la méthode hash() est utilisée. Voici la syntaxe de la méthode hash().
static Cake\Utility\Security::hash($string, $type = NULL, $salt = false)
CSRF
CSRF signifie Cross Site Request Forgery. En activant le composant CSRF, vous bénéficiez d'une protection contre les attaques. CSRF est une vulnérabilité courante dans les applications Web.
Il permet à un attaquant de capturer et de rejouer une requête précédente, et parfois de soumettre des requêtes de données à l'aide de balises d'image ou de ressources sur d'autres domaines. Le CSRF peut être activé en ajoutant simplement le CsrfComponent à votre tableau de composants comme indiqué ci-dessous ?
public function initialize(): void { parent::initialize(); $this->loadComponent('Csrf'); }
Le CsrfComponent s'intègre parfaitement à FormHelper. Chaque fois que vous créez un formulaire avec FormHelper, il insérera un champ masqué contenant le jeton CSRF.
Bien que cela ne soit pas recommandé, vous souhaiterez peut-être désactiver le CsrfComponent sur certaines requêtes. Vous pouvez le faire en utilisant le répartiteur d'événements du contr?leur, pendant la méthode beforeFilter().
public function beforeFilter(Event $event) { $this->eventManager()->off($this->Csrf); }
Composant de sécurité
Le composant de sécurité applique une sécurité plus stricte à votre application. Il fournit des méthodes pour diverses taches comme ?
Restriction des méthodes HTTP acceptées par votre application - Vous devez toujours vérifier la méthode HTTP utilisée avant d'exécuter les effets secondaires. Vous devez vérifier la méthode HTTP ou utiliser CakeNetworkRequest::allowMethod() pour vous assurer que la bonne méthode HTTP est utilisée.
-
Protection contre la falsification des formulaires - Par défaut, le SecurityComponent empêche les utilisateurs de falsifier les formulaires de manière spécifique. Le SecurityComponent empêchera les choses suivantes -
Les champs inconnus ne peuvent pas être ajoutés au formulaire.
Les champs ne peuvent pas être supprimés du formulaire.
Les valeurs dans les entrées masquées ne peuvent pas être modifiées.
Exiger que SSL soit utilisé ? Toutes les actions pour exiger un SSL sécurisé
Limitation de la communication entre contr?leurs - Nous pouvons restreindre quel contr?leur peut envoyer une demande à ce contr?leur. Nous pouvons également restreindre les actions qui peuvent envoyer une requête à l'action de ce contr?leur.
Exemple
Apportez des modifications au fichier config/routes.php comme indiqué dans le programme suivant.
config/routes.php
<?php use Cake\Http\Middleware\CsrfProtectionMiddleware; use Cake\Routing\Route\DashedRoute; use Cake\Routing\RouteBuilder; $routes->setRouteClass(DashedRoute::class); $routes->scope('/', function (RouteBuilder $builder) { $builder->registerMiddleware('csrf', new CsrfProtectionMiddleware([ 'httpOnly' => true, ])); $builder->applyMiddleware('csrf'); //$builder->connect('/pages', ['controller'=>'Pages','action'=>'display', 'home']); $builder->connect('login',['controller'=>'Logins','action'=>'index']); $builder->fallbacks(); });
Créez un fichier LoginsController.php dans src/Controller/LoginsController.php. Copiez le code suivant dans le fichier du contr?leur.
src/Controller/LoginsController.php
<?php namespace App\Controller; use App\Controller\AppController; class LoginsController extends AppController { public function initialize() : void { parent::initialize(); $this->loadComponent('Security'); } public function index(){ } } ?>
Créez un répertoire Logins dans src/Template et sous ce répertoire, créez un fichier View appelé index.php. Copiez le code suivant dans ce fichier.
src/Template/Logins/index.php
<?php echo $this->Form->create(NULL,array('url'=>'/login')); echo $this->Form->control('username'); echo $this->Form->control('password'); echo $this->Form->button('Submit'); echo $this->Form->end(); ?>
Exécutez l'exemple ci-dessus en visitant l'URL suivante - http://localhost/cakephp4/login
Sortie
Lors de l'exécution, vous recevrez le résultat suivant.

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!

Outils d'IA chauds

Undress AI Tool
Images de déshabillage gratuites

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.

Clothoff.io
Dissolvant de vêtements AI

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

Article chaud

Outils chauds

Bloc-notes++7.3.1
éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

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

Dreamweaver CS6
Outils de développement Web visuel

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

Sujets chauds

La méthode pour obtenir l'ID de session en cours dans PHP est d'utiliser la fonction session_id (), mais vous devez appeler session_start () pour l'obtenir avec succès. 1. Appelez session_start () pour démarrer la session; 2. Utilisez session_id () pour lire l'ID de session et sortir une cha?ne similaire à ABC123DEF456GHI789; 3. Si le retour est vide, vérifiez si session_start () est manquant, si l'utilisateur accède pour la première fois, ou si la session est détruite; 4. L'ID de session peut être utilisé pour l'exploitation forestière, la vérification de la sécurité et la communication croisée, mais la sécurité doit être prêtée attention. Assurez-vous que la session est correctement activée et que l'ID peut être obtenu avec succès.

Pour extraire les sous-cha?nes de cha?nes PHP, vous pouvez utiliser la fonction substr (), qui est Syntax substr (String $ string, int $ start ,? int $ longueur = null), et si la longueur n'est pas spécifiée, elle sera interceptée à la fin; Lors du traitement des caractères multi-octets tels que le chinois, vous devez utiliser la fonction mb_substr () pour éviter le code brouillé; Si vous avez besoin d'intercepter la cha?ne en fonction d'un séparateur spécifique, vous pouvez utiliser exploit () ou combiner strpos () et substr () pour l'implémenter, tels que l'extraction d'extensions de nom de fichier ou de noms de domaine.

UnittestingInphpinvolvesverifierifySindividualCodeUnits like outweethodstocatchbugSearlyAndensureReliveLerefactoring.1) setupphpunitviacomposer, createAtestDirectory, andconfigureAutoloadandphpunit.xml.2)

Dans PHP, la méthode la plus courante consiste à diviser la cha?ne en un tableau à l'aide de la fonction Exploit (). Cette fonction divise la cha?ne en plusieurs parties via le délimiteur spécifié et renvoie un tableau. La syntaxe est Exploit (séparateur, cha?ne, limite), où le séparateur est le séparateur, la cha?ne est la cha?ne d'origine et la limite est un paramètre facultatif pour contr?ler le nombre maximum de segments. Par exemple $ str = "pomme, banane, orange"; $ arr = explosage (",", $ str); Le résultat est ["Apple", "Bana

Les types de données JavaScript sont divisés en types primitifs et types de référence. Les types primitifs incluent la cha?ne, le nombre, le booléen, le nul, un non défini et le symbole. Les valeurs sont immuables et les copies sont copiées lors de l'attribution des valeurs, de sorte qu'elles ne se affectent pas; Les types de référence tels que les objets, les tableaux et les fonctions stockent les adresses de mémoire, et les variables pointant vers le même objet s'afferchent mutuellement. Le typeof et l'instance de OFF peuvent être utilisés pour déterminer les types, mais prêtent attention aux problèmes historiques de typeofnull. Comprendre ces deux types de différences peut aider à écrire un code plus stable et fiable.

STD :: Chrono est utilisé en C pour traiter le temps, y compris l'obtention de l'heure actuelle, la mesure du temps d'exécution, le point de fonctionnement et la durée de l'opération et le temps d'analyse de formatage. 1. Utilisez STD :: Chrono :: System_clock :: Now () pour obtenir l'heure actuelle, qui peut être convertie en une cha?ne lisible, mais l'horloge système peut ne pas être monotone; 2. Utilisez STD :: Chrono :: standard_clock pour mesurer le temps d'exécution pour assurer la monotonie, et la convertir en millisecondes, secondes et autres unités via durée_cast; 3. Point de temps (temps_point) et durée (durée) peut être interopérable, mais l'attention doit être accordée à la compatibilité des unités et à l'époque de l'horloge (époque)

Dans PHP, pour passer une variable de session à une autre page, la clé consiste à démarrer correctement la session et à utiliser le même nom de clé $ _Session. 1. Avant d'utiliser des variables de session pour chaque page, il doit être appelé session_start () et placé à l'avant du script; 2. Définir des variables de session telles que $ _Session ['username'] = 'JohnDoe' sur la première page; 3. Après avoir appelé session_start () sur une autre page, accédez aux variables via le même nom de clé; 4. Assurez-vous que Session_Start () est appelé sur chaque page, évitez la sortie du contenu à l'avance et vérifiez que le chemin de stockage de session sur le serveur est écrivable; 5. Utilisez SES

TOACCESSENSIRONDAMENTVARIBLESSInPHP, useGettenv () Orthe $ _ENVSUPERGLOBAL.1.getenv ('var_name') RetrievesAsaspecificVariable.2. $ _ En V ['var_name'] AccesssaSVariblesifVariables_OrderInphp.iniIncluses "E" .setVariblesVICLIWithVar = ValuePpript.Php, INAPACH
