国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

Table des matières
Cryptage et Décryptage
CSRF
Composant de sécurité
Exemple
Sortie

Sécurité CakePHP

Sep 10, 2024 pm 05:26 PM
php cakephp PHP framework

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.

Submit Login

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

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

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.

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

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?!

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)

Comment obtenir l'ID de session en cours dans PHP? Comment obtenir l'ID de session en cours dans PHP? Jul 13, 2025 am 03:02 AM

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.

Php obtient une sous-cha?ne à partir d'une cha?ne Php obtient une sous-cha?ne à partir d'une cha?ne Jul 13, 2025 am 02:59 AM

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.

Comment effectuez-vous des tests unitaires pour le code PHP? Comment effectuez-vous des tests unitaires pour le code PHP? Jul 13, 2025 am 02:54 AM

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

Comment diviser une cha?ne en un tableau en php Comment diviser une cha?ne en un tableau en php Jul 13, 2025 am 02:59 AM

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

Types de données JavaScript: référence primitive vs Types de données JavaScript: référence primitive vs Jul 13, 2025 am 02:43 AM

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.

Utilisation de STD :: Chrono en C Utilisation de STD :: Chrono en C Jul 15, 2025 am 01:30 AM

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)

Comment passer une variable de session à une autre page de PHP? Comment passer une variable de session à une autre page de PHP? Jul 13, 2025 am 02:39 AM

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

Comment PHP gère-t-il les variables d'environnement? Comment PHP gère-t-il les variables d'environnement? Jul 14, 2025 am 03:01 AM

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

See all articles