CodeIgniter - Guide rapide

CodeIgniter est un framework de développement d'applications, qui peut être utilisé pour développer des sites Web, en utilisant PHP. C'est un framework Open Source. Il dispose d'un ensemble très riche de fonctionnalités, ce qui augmentera la vitesse du travail de développement de sites Web.

Si vous connaissez bien PHP, CodeIgniter vous facilitera la tâche. Il dispose d'un ensemble très riche de bibliothèques et d'aides. En utilisant CodeIgniter, vous économiserez beaucoup de temps si vous développez un site Web à partir de zéro. Non seulement cela, un site Web construit dans CodeIgniter est également sécurisé, car il a la capacité de prévenir diverses attaques qui ont lieu via des sites Web.

Caractéristiques de CodeIgniter

Certaines des fonctionnalités importantes de CodeIgniter sont répertoriées ci-dessous -

  • Système basé sur Model-View-Controller

  • Poids extrêmement léger

  • Classes de base de données complètes avec prise en charge de plusieurs plates-formes.

  • Prise en charge de la base de données Query Builder

  • Validation des formulaires et des données

  • Sécurité et filtrage XSS

  • Gestion de session

  • Classe d'envoi d'e-mails. Prend en charge les pièces jointes, les e-mails HTML / texte, plusieurs protocoles (sendmail, SMTP et Mail) et plus encore.

  • Bibliothèque de manipulation d'images (recadrage, redimensionnement, rotation, etc.). Prend en charge GD, ImageMagick et NetPBM

  • Cours de téléchargement de fichiers

  • Classe FTP

  • Localization

  • Pagination

  • Cryptage des données

  • Benchmarking

  • Mise en cache pleine page

  • Journalisation des erreurs

  • Profilage d'application

  • Classe de calendrier

  • Classe d'agent utilisateur

  • Classe d'encodage Zip

  • Classe de moteur de modèle

  • Classe de rétrolien

  • Bibliothèque XML-RPC

  • Classe de test unitaire

  • URL conviviales pour les moteurs de recherche

  • Routage URI flexible

  • Prise en charge des hooks et des extensions de classe

  • Grande bibliothèque de fonctions «d'assistance»

Il est très facile d'installer CodeIgniter. Suivez simplement les étapes ci-dessous -

  • Step-1- Téléchargez le CodeIgniter à partir du lien CodeIgniter

  • Step-2 - Décompressez le dossier.

  • Step-3 - Téléchargez tous les fichiers et dossiers sur votre serveur.

  • Step-4 - Après avoir téléchargé tous les fichiers sur votre serveur, visitez l'URL de votre serveur, par exemple www.domain-name.com.

En visitant l'URL, vous verrez l'écran suivant -

L'architecture de l'application CodeIgniter est illustrée ci-dessous.

  • Comme le montre la figure, chaque fois qu'une requête arrive à CodeIgniter, elle ira d'abord à index.php page.

  • Dans la deuxième étape, Routing décidera de transmettre cette demande à l'étape 3 pour la mise en cache ou de transmettre cette demande à l'étape 4 pour le contrôle de sécurité.

  • Si la page demandée est déjà dans Caching, puis Routing transmettra la demande à l'étape 3 et la réponse reviendra à l'utilisateur.

  • Si la page demandée n'existe pas dans Caching, puis Routing passera la page demandée à l'étape 4 pour Security chèques.

  • Avant de transmettre la demande à Application Controller, la Securitydes données soumises est vérifiée. Après leSecurity vérifier la Application Controller charges nécessaires Models, Libraries, Helpers, Plugins et Scripts et transmettez-le à View.

  • le View rendra la page avec les données disponibles et la transmettra pendant Caching. Comme la page demandée n'a pas été mise en cache auparavant, cette fois, elle sera mise en cache dansCaching, pour traiter cette page rapidement pour de futures demandes.

Structure du répertoire

L'image ci-dessous montre la structure des répertoires de CodeIgniter.

La structure de répertoires CodeIgniter est divisée en 3 dossiers -

  • Application
  • System
  • User_guide

Application

Comme son nom l'indique, le dossier Application contient tout le code de votre application que vous créez. C'est le dossier dans lequel vous développerez votre projet. Le dossier Application contient plusieurs autres dossiers, qui sont expliqués ci-dessous -

  • Cache- Ce dossier contient toutes les pages mises en cache de votre application. Ces pages mises en cache augmenteront la vitesse globale d'accès aux pages.

  • Config- Ce dossier contient divers fichiers pour configurer l'application. Avec l'aide deconfig.phpfichier, l'utilisateur peut configurer l'application. En utilisantdatabase.php fichier, l'utilisateur peut configurer la base de données de l'application.

  • Controllers- Ce dossier contient les contrôleurs de votre application. C'est la partie de base de votre application.

  • Core - Ce dossier contiendra la classe de base de votre application.

  • Helpers - Dans ce dossier, vous pouvez mettre la classe d'assistance de votre application.

  • Hooks - Les fichiers de ce dossier fournissent un moyen d'exploiter et de modifier le fonctionnement interne du framework sans pirater les fichiers principaux.

  • Language - Ce dossier contient des fichiers liés à la langue.

  • Libraries - Ce dossier contient les fichiers des bibliothèques développées pour votre application.

  • Logs - Ce dossier contient des fichiers liés au journal du système.

  • Models - La connexion à la base de données sera placée dans ce dossier.

  • Third_party - Dans ce dossier, vous pouvez placer tous les plugins, qui seront utilisés pour votre application.

  • Views - Les fichiers HTML de l'application seront placés dans ce dossier.

Système

Ce dossier contient les codes de base de CodeIgniter, des bibliothèques, des aides et d'autres fichiers, qui facilitent le codage. Ces bibliothèques et assistants sont chargés et utilisés dans le développement d'applications Web.

Ce dossier contient tout le code CodeIgniter de conséquence, organisé en différents dossiers -

  • Core- Ce dossier contient la classe principale de CodeIgniter. Ne modifiez rien ici. Tout votre travail se déroulera dans le dossier de l'application. Même si votre intention est d'étendre le noyau de CodeIgniter, vous devez le faire avec des hooks, et des hooks vivent dans le dossier de l'application.

  • Database - Le dossier de base de données contient les pilotes de base de données principaux et d'autres utilitaires de base de données.

  • Fonts - Le dossier des polices contient des informations et des utilitaires relatifs aux polices.

  • Helpers - Le dossier helpers contient des helpers CodeIgniter standard (tels que des helpers de date, de cookie et d'URL).

  • Language- Le dossier de langue contient des fichiers de langue. Vous pouvez l'ignorer pour l'instant.

  • Libraries- Le dossier des bibliothèques contient des bibliothèques CodeIgniter standard (pour vous aider avec les courriers électroniques, les calendriers, les téléchargements de fichiers, etc.). Vous pouvez créer vos propres bibliothèques ou étendre (et même remplacer) celles standard, mais celles-ci seront enregistrées dans leapplication/libraries pour les garder séparés des bibliothèques CodeIgniter standard enregistrées dans ce dossier particulier.

Mode d'emploi

Ceci est votre guide d'utilisation de CodeIgniter. Il s'agit essentiellement de la version hors ligne du guide de l'utilisateur sur le site Web de CodeIgniter. En utilisant cela, on peut apprendre les fonctions de diverses bibliothèques, aides et classes. Il est recommandé de parcourir ce guide de l'utilisateur avant de créer votre première application Web dans CodeIgniter.

À côté de ces trois dossiers, il y a un autre fichier important nommé "index.php». Dans ce fichier, nous pouvons définir l'environnement d'application et le niveau d'erreur et nous pouvons définir le nom du système et du dossier d'application. Il est recommandé de ne pas modifier ces paramètres si vous n'avez pas suffisamment de connaissances sur ce que vous allez faire.

CodeIgniter est basé sur le Model-View-Controller (MVC) development pattern. MVC est une approche logicielle qui sépare la logique d'application de la présentation. En pratique, cela permet à vos pages Web de contenir un minimum de scripts puisque la présentation est distincte du script PHP.

  • le Modelreprésente vos structures de données. En règle générale, vos classes de modèle contiennent des fonctions qui vous aident à récupérer, insérer et mettre à jour des informations dans votre base de données.

  • le Viewest une information présentée à un utilisateur. Une vue sera normalement une page Web, mais dans CodeIgniter, une vue peut également être un fragment de page comme un en-tête ou un pied de page. Il peut également s'agir d'une page RSS ou de tout autre type de «page».

  • le Controller sert d'intermédiaire entre le modèle, la vue et toute autre ressource nécessaire pour traiter la requête HTTP et générer une page Web.

Contrôleurs

Un contrôleur est un simple fichier de classe. Comme son nom l'indique, il contrôle l'ensemble de l'application par URI.

Créer un contrôleur

Tout d'abord, allez à application/controllersdossier. Vous y trouverez deux fichiers,index.html et Welcome.php. Ces fichiers sont fournis avec le CodeIgniter.

Conservez ces fichiers tels quels. Créez un nouveau fichier sous le même chemin nommé "Test.php». Écrivez le code suivant dans ce fichier -

<?php 
   class Test extends CI_Controller {
  
      public function index() { 
         echo "Hello World!"; 
      } 
   } 
?>

le Test class étend une classe intégrée appelée CI_Controller. Cette classe doit être étendue chaque fois que vous souhaitez créer votre propre classe Controller.

Appeler un contrôleur

Le contrôleur ci-dessus peut être appelé par URI comme suit -

http://www.your-domain.com/index.php/test

Notez le mot "test”Dans l'URI ci-dessus après index.php. Cela indique le nom de classe du contrôleur. Comme nous avons donné le nom du contrôleur "Test", nous écrivons "test”Après l'index.php. Le nom de la classe doit commencer paruppercase letter mais nous devons écrire lowercase letterlorsque nous appelons ce contrôleur par URI. La syntaxe générale pour appeler le contrôleur est la suivante -

http://www.your-domain.com/index.php/controller/method-name

Création et appel de la méthode constructeur

Modifions la classe ci-dessus et créons une autre méthode nommée «bonjour».

<?php 
   class Test extends CI_Controller {  
	
      public function index() { 
         echo "This is default function."; 
      } 
  
      public function hello() { 
         echo "This is hello function."; 
      } 
   } 
?>

Nous pouvons exécuter le contrôleur ci-dessus des trois manières suivantes -

  • http://www.your-domain.com/index.php/test
  • http://www.your-domain.com/index.php/test/index
  • http://www.your-domain.com/index.php/test/hello

Après avoir visité le premier URI dans le navigateur, nous obtenons la sortie comme indiqué dans l'image ci-dessous. Comme vous pouvez le voir, nous avons obtenu la sortie de la méthode "index”, Même si nous n'avons pas transmis le nom de la méthode à l'URI. Nous n'avons utilisé que le nom du contrôleur dans l'URI. Dans de telles situations, le CodeIgniter appelle la méthode par défaut "index».

En visitant le deuxième URI dans le navigateur, nous obtenons le même résultat que celui indiqué dans l'image ci-dessus. Ici, nous avons passé le nom de la méthode après le nom du contrôleur dans l'URI. Comme le nom de la méthode est "index», Nous obtenons le même résultat.

En visitant le troisième URI dans le navigateur, nous obtenons la sortie comme indiqué dans l'image ci-dessous. Comme vous pouvez le voir, nous obtenons la sortie de la méthode "hello"Parce que nous avons réussi"hello"Comme nom de la méthode, après le nom du contrôleur"test”Dans l'URI.

Points à retenir

  • Le nom de la classe de contrôleur doit commencer par une lettre majuscule.

  • Le contrôleur doit être appelé avec une lettre minuscule.

  • N'utilisez pas le même nom de méthode que votre classe parent, car il remplacera la fonctionnalité de la classe parent.

Vues

Cela peut être une page Web simple ou complexe, qui peut être appelée par le contrôleur. La page Web peut contenir un en-tête, un pied de page, une barre latérale, etc. La vue ne peut pas être appelée directement. Créons une vue simple. Créez un nouveau fichier sousapplication/views avec nom "test.php»Et copiez le code ci-dessous dans ce fichier.

<!DOCTYPE html> 
<html lang = "en"> 

   <head> 
      <meta charset = "utf-8"> 
      <title>CodeIgniter View Example</title> 
   </head>
	
   <body> 
      CodeIgniter View Example 
   </body>
	
</html>

Changer le code de application/controllers/test.php fichier comme indiqué ci-dessous.

Chargement de la vue

La vue peut être chargée par la syntaxe suivante -

$this->load->view('name');

Où nom est le fichier de vue en cours de rendu. Si vous avez prévu de stocker le fichier de vue dans un répertoire, vous pouvez utiliser la syntaxe suivante -

$this->load->view('directory-name/name');

Il n'est pas nécessaire de spécifier l'extension comme php, sauf si quelque chose d'autre que .php est utilisé.

La méthode index () appelle la méthode view et passe le "test" comme argument à la méthode view () car nous avons stocké le codage html dans "test.php"Fichier sous application/views/test.php.

<?php 
   class Test extends CI_Controller { 
	
      public function index() { 
         $this->load->view('test'); 
      } 
   } 
?>

Voici la sortie du code ci-dessus -

L'organigramme suivant illustre comment tout fonctionne -

Des modèles

Les classes de modèles sont conçues pour fonctionner avec les informations de la base de données. Par exemple, si vous utilisez CodeIgniter pour gérer les utilisateurs dans votre application, vous devez disposer d'une classe de modèle, qui contient des fonctions pour insérer, supprimer, mettre à jour et récupérer les données de vos utilisateurs.

Créer une classe de modèle

Les classes de modèle sont stockées dans application/modelsannuaire. Le code suivant montre comment créer une classe de modèle dans CodeIgniter.

<?php 
   Class Model_name extends CI_Model { 
	
      Public function __construct() { 
         parent::__construct(); 
      } 
   } 
?>

Où Model_name est le nom de la classe de modèle que vous souhaitez donner. Chaque classe de modèle doit hériter de la classe CI_Model de CodeIgniter. La première lettre de la classe modèle doit être en majuscule. Voici le code de la classe de modèle des utilisateurs.

<?php 
   Class User_model extends CI_Model {
	
      Public function __construct() { 
         parent::__construct(); 
      } 
		
   } 
?>

La classe de modèle ci-dessus doit être enregistrée sous User_model.php. Le nom de la classe et le nom du fichier doivent être identiques.

Modèle de chargement

Le modèle peut être appelé dans le contrôleur. Le code suivant peut être utilisé pour charger n'importe quel modèle.

$this->load->model('model_name');

Où model_name est le nom du modèle à charger. Après avoir chargé le modèle, vous pouvez simplement appeler sa méthode comme indiqué ci-dessous.

$this->model_name->method();

Modèles à chargement automatique

Il peut arriver que vous souhaitiez une classe de modèle dans toute votre application. Dans de telles situations, il est préférable de le charger automatiquement.

/*
| ---------------------------------------------------------------
|  Auto-Load Models
| ---------------------------------------------------------------
| Prototype:
|
|   $autoload['model'] = array('first_model', 'second_model');
|
| You can also supply an alternative model name to be assigned
| in the controller:
|  
|   $autoload['model'] = array('first_model' => 'first'); */ $autoload['model'] = array();

Comme indiqué dans la figure ci-dessus, transmettez le nom du modèle dans le tableau que vous souhaitez charger automatiquement et il sera chargé automatiquement, tandis que le système est en état d'initialisation et est accessible dans toute l'application.

Aides

Comme son nom l'indique, il vous aidera à construire votre système. Il est divisé en petites fonctions pour servir différentes fonctionnalités. Un certain nombre d'aides sont disponibles dans CodeIgniter, qui sont répertoriées dans le tableau ci-dessous. Nous pouvons également créer nos propres aides.

Les aides sont généralement stockées dans votre system/helpers, ou application/helpers directory. Les assistants personnalisés sont stockés dansapplication/helpers le répertoire et les assistants système sont stockés dans system/helpersannuaire. CodeIgniter regardera en premier dans votreapplication/helpers directory. Si le répertoire n'existe pas ou si l'assistant spécifié n'est pas localisé, CodeIgniter cherchera à la place dans votre fichier globalsystem/helpers/ directory. Chaque assistant, qu'il soit personnalisé ou assistant système, doit être chargé avant de l'utiliser.

SN Nom et description de l'assistant
1

Array Helper

Le fichier Array Helper contient des fonctions qui facilitent l'utilisation des tableaux.

2

CAPTCHA Helper

Le fichier CAPTCHA Helper contient des fonctions qui aident à créer des images CAPTCHA.

3

Cookie Helper

Le fichier Cookie Helper contient des fonctions qui aident à travailler avec les cookies.

4

Date Helper

Le fichier Date Helper contient des fonctions qui vous aident à travailler avec des dates.

5

Directory Helper

Le fichier Directory Helper contient des fonctions qui facilitent l'utilisation des répertoires.

6

Download Helper

L'assistant de téléchargement vous permet de télécharger des données sur votre bureau.

sept

Email Helper

L'assistant de messagerie fournit des fonctions d'assistance pour travailler avec le courrier électronique. Pour une solution de messagerie plus robuste, consultez la classe de messagerie de CodeIgniter.

8

File Helper

Le fichier File Helper contient des fonctions qui aident à travailler avec les fichiers.

9

Form Helper

Le fichier Form Helper contient des fonctions qui facilitent l'utilisation des formulaires.

dix

HTML Helper

Le fichier HTML Helper contient des fonctions qui aident à travailler avec HTML.

11

Inflector Helper

Le fichier Inflector Helper contient des fonctions qui vous permettent de changer les mots au pluriel, au singulier, en cas de chameau, etc.

12

Language Helper

Le fichier Language Helper contient des fonctions qui aident à travailler avec les fichiers de langue.

13

Number Helper

Le fichier Number Helper contient des fonctions qui vous aident à travailler avec des données numériques.

14

Path Helper

Le fichier Path Helper contient des fonctions qui vous permettent de travailler avec des chemins de fichiers sur le serveur.

15

Security Helper

Le fichier Security Helper contient des fonctions liées à la sécurité.

16

Smiley Helper

Le fichier Smiley Helper contient des fonctions qui vous permettent de gérer les smileys (émoticônes).

17

String Helper

Le fichier String Helper contient des fonctions qui aident à travailler avec des chaînes.

18

Text Helper

Le fichier Text Helper contient des fonctions qui aident à travailler avec du texte.

19

Typography Helper

Le fichier Typography Helper contient des fonctions qui vous aident à formater le texte de manière sémantiquement pertinente.

20

URL Helper

Le fichier URL Helper contient des fonctions qui aident à travailler avec les URL.

21

XML Helper

Le fichier XML Helper contient des fonctions qui aident à travailler avec des données XML.

Chargement d'un assistant

Un assistant peut être chargé comme indiqué ci-dessous -

$this->load->helper('name');

Où nom est le nom de l'assistant. Par exemple, si vous souhaitez charger l'URL Helper, il peut être chargé en tant que -

$this->load->helper('url');

Routage

CodeIgniter a un système de routage URI convivial, de sorte que vous pouvez facilement réacheminer l'URL. En règle générale, il existe une relation univoque entre une chaîne d'URL et sa classe / méthode de contrôleur correspondante. Les segments dans un URI suivent normalement ce modèle -

your-domain.com/class/method/id/
  • le first segment représente la classe de contrôleur qui doit être appelée.

  • le second segment représente la fonction de classe, ou méthode, qui doit être appelée.

  • le third, et tous les segments supplémentaires, représentent l'ID et toutes les variables qui seront transmises au contrôleur.

Dans certaines situations, vous souhaiterez peut-être modifier ce mécanisme de routage par défaut. CodeIgniter fournit une fonction grâce à laquelle vous pouvez définir vos propres règles de routage.

Personnaliser les règles de routage

Il existe un fichier particulier où vous pouvez gérer tout cela. Le fichier se trouve dans application / config / routes.php. Vous trouverez un tableau appelé$route in which you can customize your routing rules. The key in the $route array décidera quoi acheminer et la valeur décidera où acheminer. Il existe trois routes réservées dans CodeIgniter.

SN Itinéraires réservés et description
1

$route['default_controller']

Cette route indique quelle classe de contrôleur doit être chargée, si l'URI ne contient aucune donnée, ce qui sera le cas lorsque les gens chargeront votre URL racine. Vous êtes encouragé à avoir une route par défaut sinon une page 404 apparaîtra, par défaut. Nous pouvons définir la page d'accueil du site Web ici afin qu'elle soit chargée par défaut.

2

$route['404_override']

Cette route indique quelle classe de contrôleur doit être chargée si le contrôleur demandé n'est pas trouvé. Il remplacera la page d'erreur 404 par défaut. Cela n'affectera pas leshow_404() fonction, qui continuera à charger la valeur par défaut error_404.php déposer dans application/views/errors/error_404.php.

3

$route['translate_uri_dashes']

Comme le montre la valeur booléenne, ce n'est pas exactement une route. Cette option vous permet de remplacer automatiquement les tirets ('-') par des traits de soulignement dans les segments URI du contrôleur et de la méthode, vous économisant ainsi des entrées de route supplémentaires si vous devez le faire. Cela est obligatoire car le tiret n'est pas un caractère de classe ou de nom de méthode valide et provoquera une erreur fatale si vous essayez de l'utiliser.

Les itinéraires peuvent être personnalisés par wildcards ou en utilisant regular expressions mais gardez à l'esprit que ces règles personnalisées pour le routage doivent venir après les règles réservées.

Caractères génériques

Nous pouvons utiliser deux caractères génériques comme expliqué ci-dessous -

  • (:num) - Il correspondra à un segment contenant uniquement des nombres.

  • (:any) - Il correspondra à un segment contenant n'importe quel caractère.

Example

$route['product/:num']='catalog/product_lookup';

Dans l'exemple ci-dessus, si le mot littéral "produit" se trouve dans le premier segment de l'URL et qu'un nombre est trouvé dans le deuxième segment, la classe "catalogue" et la méthode "product_lookup" sont utilisées à la place.

Expressions régulières

Comme les jokers, nous pouvons également utiliser des expressions régulières dans $route array keypartie. Si un URI correspond à une expression régulière, il sera acheminé vers la partie valeur définie dans le tableau $ route.

Example

$route['products/([a-z]+)/(\d+)']='$1/id_$2';

Dans l'exemple ci-dessus, un URI similaire à products / shoes / 123 appellerait plutôt "shoes"Classe de contrôleur et le"id_123" méthode.

Après avoir configuré le site, la prochaine chose que nous devons faire est de configurer le site. Le dossier application / config contient un groupe de fichiers qui définissent la configuration de base de votre site.

Configuration de l'URL de base

L'URL de base du site peut être configurée dans le fichier application / config / config.php. C'est l'URL de votre racine CodeIgniter. En règle générale, ce sera votre URL de base, avec une barre oblique à la fin, par exemple

http://example.com/

Si ce n'est pas défini, CodeIgniter essaiera de deviner le protocole, le domaine et le chemin de votre installation. Cependant, vous devez toujours le configurer explicitement et ne jamais compter sur l'autoguessing, en particulier dans les environnements de production. Vous pouvez configurer l'URL de base dans le tableau $ config avec la clé «base_url» comme indiqué ci-dessous -

$config['base_url'] = 'http://your-domain.com';

Configuration de la base de données

La base de données du site peut être configurée dans le fichier application / config / database.php. Souvent, nous devons mettre en place une base de données pour différents environnements tels que le développement et la production. Avec le tableau multidimensionnel fourni dans CodeIgniter, nous pouvons configurer la base de données pour différents environnements. Les paramètres de configuration sont stockés dans la baie comme indiqué ci-dessous -

$db['default'] = array( 
   'dsn'   => '', 
   'hostname' => 'localhost', 
   'username' => 'root', 
   'password' => '', 
   'database' => 'database_name', 
   'dbdriver' => 'mysqli', 
   'dbprefix' => '', 
   'pconnect' => TRUE, 
   'db_debug' => TRUE, 
   'cache_on' => FALSE, 
   'cachedir' => '', 
   'char_set' => 'utf8', 
   'dbcollat' => 'utf8_general_ci',
   'swap_pre' => '', 
   'encrypt' => FALSE, 
   'compress' => FALSE, 
   'stricton' => FALSE, 
   'failover' => array() 
);

Vous pouvez laisser quelques options à leurs valeurs par défaut, à l'exception du nom d'hôte, du nom d'utilisateur, du mot de passe, de la base de données et de dbdriver.

  • hostname - Indiquez ici l'emplacement de votre base de données, par exemple localhost ou adresse IP

  • username - Définissez ici le nom d'utilisateur de votre base de données.

  • password - Définissez ici le mot de passe de votre base de données.

  • database - Définissez ici le nom de la base de données.

  • dbdriver - Définissez le type de base de données que vous utilisez, par exemple MySQL, MySQLi, Postgre SQL, ODBC et MS SQL.

En changeant la clé du tableau $db, vous pouvez définir une autre configuration de base de données comme indiqué ci-dessous. Ici, nous avons défini la clé pour‘test’ pour définir la base de données pour l'environnement de test, en conservant l'autre environnement de base de données tel quel.

$db['test'] = array( 
   'dsn'   => '', 
   'hostname' => 'localhost', 
   'username' => 'root', 
   'password' => '', 
   'database' => 'database_name', 
   'dbdriver' => 'mysqli', 
   'dbprefix' => '', 
   'pconnect' => TRUE, 
   'db_debug' => TRUE, 
   'cache_on' => FALSE, 
   'cachedir' => '', 
   'char_set' => 'utf8', 
   'dbcollat' => 'utf8_general_ci', 
   'swap_pre' => '', 
   'encrypt' => FALSE, 
   'compress' => FALSE, 
   'stricton' => FALSE, 
   'failover' => array()
);

Vous pouvez simplement passer à un environnement différent en modifiant la valeur d'une variable comme indiqué ci-dessous -

$active_group = ‘default’; //This will set the default environment

$active_group = ‘test’; //This will set the test environment

Configuration de chargement automatique

Ce fichier spécifie, par défaut, quels systèmes doivent être chargés. Afin de garder le framework aussi léger que possible, seules les ressources minimales absolues sont chargées par défaut. Il faut charger automatiquement le système fréquemment utilisé, plutôt que de le charger au niveau local, à plusieurs reprises. Voici les éléments que vous pouvez charger automatiquement -

  • Libraries- C'est une liste de bibliothèques, qui devraient être chargées automatiquement. Fournissez une liste de bibliothèques dans un tableau comme indiqué ci-dessous à charger automatiquement par CodeIgniter. Dans cet exemple, nous chargeons automatiquement les bibliothèques de bases de données, d'e-mails et de sessions.

$autoload['libraries'] = array('database', 'email', 'session');
  • Drivers- Ces classes sont situées dans système / bibliothèques / ou dans votre répertoire application / bibliothèques /, mais sont également placées dans leur propre sous-répertoire et elles étendent la classe CI_Driver_Library. Ils offrent plusieurs options de pilotes interchangeables. Voici un exemple de chargement automatique des pilotes de cache.

$autoload['drivers'] = array('cache');
  • Helper files- C'est une liste de fichiers d'aide, à charger automatiquement. Fournissez une liste de bibliothèques dans le tableau, comme indiqué ci-dessous, à charger automatiquement par CodeIgniter. Dans l'exemple donné, nous chargeons automatiquement les URL et les fichiers helpers.

$autoload['helper'] = array('url', 'file');
  • Custom config files- Ces fichiers sont destinés à être utilisés uniquement si vous avez créé des fichiers de configuration personnalisés. Sinon, laissez ce champ vide. Voici un exemple de chargement automatique de plusieurs fichiers de configuration.

$autoload['config'] = array('config1', 'config2');
  • Language files- C'est une liste de fichiers de langue, qui devraient être chargés automatiquement. Regardez l'exemple ci-dessous. Fournissez une liste de langues dans un tableau comme indiqué ci-dessous à charger automatiquement par CodeIgniter. Gardez à l'esprit que n'incluez pas la partie "_lang" de votre fichier. Par exemple, "codeigniter_lang.php" serait référencé comme array ('codeigniter');

  • Models- Il s'agit d'un fichier de liste de modèles, qui doit être chargé automatiquement. Fournissez une liste de modèles dans un tableau comme indiqué ci-dessous à charger automatiquement par CodeIgniter. Voici un exemple de chargement automatique de plusieurs fichiers de modèle.

$autoload['model'] = array('first_model', 'second_model');

Comme tout autre framework, nous devons interagir très souvent avec la base de données et CodeIgniter nous facilite cette tâche. Il fournit un riche ensemble de fonctionnalités pour interagir avec la base de données.

Dans cette section, nous allons comprendre comment les fonctions CRUD (Créer, Lire, Mettre à jour, Supprimer) fonctionnent avec CodeIgniter. Nous utiliseronsstud table pour sélectionner, mettre à jour, supprimer et insérer les données dans stud table.

Nom de la table: goujon
roll_no int (11)
Nom varchar (30)

Connexion à une base de données

Nous pouvons nous connecter à la base de données des deux manières suivantes -

  • Automatic Connecting- La connexion automatique peut être effectuée en utilisant le fichier application / config / autoload.php. La connexion automatique chargera la base de données pour chaque page. Nous avons juste besoin d'ajouter la bibliothèque de base de données comme indiqué ci-dessous -

$autoload['libraries'] = array(‘database’);
  • Manual Connecting- Si vous souhaitez une connectivité de base de données pour certaines pages seulement, nous pouvons opter pour une connexion manuelle. Nous pouvons nous connecter à la base de données manuellement en ajoutant la ligne suivante dans n'importe quelle classe.

$this->load->database();

Ici, nous ne passons aucun argument car tout est défini dans le fichier de configuration de la base de données application / config / database.php

Insérer un enregistrement

Pour insérer un enregistrement dans la base de données, la fonction insert () est utilisée comme indiqué dans le tableau suivant -

Syntax

insert ([ $ table = '' [, $ set = NULL [, $ escape = NULL ]]])

Parameters

  • $table( string ) - Nom de la table

  • $set( array ) - Un tableau associatif de paires champ / valeur

  • $escape( booléen ) - Indique s'il faut échapper les valeurs et les identifiants

Returns

TRUE en cas de succès, FALSE en cas d'échec

Return Type

booléen

L'exemple suivant montre comment insérer un enregistrement dans studtable. Le $ data est un tableau dans lequel nous avons défini les données et insérer ces données dans la tablestud, nous devons juste passer ce tableau à la fonction d'insertion dans le 2 ème argument.

$data = array( 'roll_no' => ‘1’, 'name' => ‘Virat’ ); $this->db->insert("stud", $data);

Mettre à jour un enregistrement

Pour mettre à jour un enregistrement dans la base de données, le update() la fonction est utilisée avec set() et where()fonctions comme indiqué dans les tableaux ci-dessous. leset() La fonction définira les données à mettre à jour.

Syntax

set ( $ key [, $ value = '' [, $ escape = NULL ]])

Parameters

  • $key( mixte ) - Nom de champ, ou un tableau de paires champ / valeur

  • $value( string ) - Valeur du champ, si $ key est un seul champ

  • $escape( booléen ) - Indique s'il faut échapper les valeurs et les identifiants

Returns

Instance CI_DB_query_builder (chaînage de méthodes)

Return Type

CI_DB_query_builder

le where() La fonction décidera quel enregistrement mettre à jour.

Syntax

où ( $ key [, $ value = NULL [, $ escape = NULL ]])

Parameters

  • $key( mixte ) - Nom du champ à comparer ou tableau associatif

  • $value( mixte ) - Si une seule clé, par rapport à cette valeur

  • $escape( booléen ) - Indique s'il faut échapper les valeurs et les identifiants

Returns

Instance DB_query_builder

Return Type

objet

Finalement, le update() La fonction mettra à jour les données dans la base de données.

Syntax

mettre à jour ([ $ table = '' [, $ set = NULL [,$where = NULL[, $limit = NULL ]]]])

Parameters

  • $table( string ) - Nom de la table

  • $set( array ) - Un tableau associatif de paires champ / valeur

  • $where( string ) - La clause WHERE

  • $limit( int ) - La clause LIMIT

Returns

TRUE en cas de succès, FALSE en cas d'échec

Return Type

booléen
$data = array( 'roll_no' => ‘1’, 'name' => ‘Virat’ ); $this->db->set($data); $this->db->where("roll_no", ‘1’); 
$this->db->update("stud", $data);

Supprimer un enregistrement

Pour supprimer un enregistrement dans la base de données, la fonction delete () est utilisée comme indiqué dans le tableau suivant -

Syntax

supprimer ([ $ table = '' [, $ où = '' [,$limit = NULL[, $reset_data = TRUE ]]]])

Parameters

  • $table( mixte ) - Le (s) tableau (s) à supprimer; chaîne ou tableau

  • $where( string ) - La clause WHERE

  • $limit( int ) - La clause LIMIT

  • $reset_data( booléen ) - TRUE pour réinitialiser la clause «write» de la requête

Returns

Instance CI_DB_query_builder (chaînage de méthodes) ou FALSE en cas d'échec

Return Type

mixte

Utilisez le code suivant pour supprimer un enregistrement dans le studtable. Le premier argument indique le nom de la table pour supprimer l'enregistrement et le second argument décide quel enregistrement supprimer.

$this->db->delete("stud", "roll_no = 1");

Sélection d'un enregistrement

Pour sélectionner un enregistrement dans la base de données, le get fonction est utilisée, comme indiqué dans le tableau suivant -

Syntax

get ([ $ table = '' [, $ limit = NULL [, $ offset = NULL ]]])

Parameters

  • $table( string ) - La table à interroger le tableau

  • $limit( int ) - La clause LIMIT

  • $offset( int ) - La clause OFFSET

Returns

Instance CI_DB_result (chaînage de méthodes)

Return Type

CI_DB_result

Utilisez le code suivant pour obtenir tous les enregistrements de la base de données. La première instruction récupère tous les enregistrements de la table «stud» et renvoie l'objet, qui sera stocké dans $ query object. La deuxième déclaration appelle leresult() fonction avec l'objet $ query pour obtenir tous les enregistrements sous forme de tableau.

$query = $this->db->get("stud"); $data['records'] = $query->result();

Fermer une connexion

La connexion à la base de données peut être fermée manuellement, en exécutant le code suivant -

$this->db->close();

Exemple

Créez une classe de contrôleur appelée Stud_controller.php et enregistrez-le à application/controller/Stud_controller.php

Voici un exemple complet, dans lequel toutes les opérations mentionnées ci-dessus sont effectuées. Avant d'exécuter l'exemple suivant, créez une base de données et une table comme indiqué au début de ce chapitre et apportez les modifications nécessaires dans le fichier de configuration de la base de données stocké dansapplication/config/database.php

<?php 
   class Stud_controller extends CI_Controller {
	
      function __construct() { 
         parent::__construct(); 
         $this->load->helper('url'); $this->load->database(); 
      } 
  
      public function index() { 
         $query = $this->db->get("stud"); 
         $data['records'] = $query->result(); 
			
         $this->load->helper('url'); $this->load->view('Stud_view',$data); } public function add_student_view() { $this->load->helper('form'); 
         $this->load->view('Stud_add'); } public function add_student() { $this->load->model('Stud_Model');
			
         $data = array( 'roll_no' => $this->input->post('roll_no'), 
            'name' => $this->input->post('name') ); $this->Stud_Model->insert($data); $query = $this->db->get("stud"); $data['records'] = $query->result(); $this->load->view('Stud_view',$data); } public function update_student_view() { $this->load->helper('form'); 
         $roll_no = $this->uri->segment('3'); 
         $query = $this->db->get_where("stud",array("roll_no"=>$roll_no)); $data['records'] = $query->result(); $data['old_roll_no'] = $roll_no; $this->load->view('Stud_edit',$data); } public function update_student(){ $this->load->model('Stud_Model');
			
         $data = array( 'roll_no' => $this->input->post('roll_no'), 
            'name' => $this->input->post('name') ); $old_roll_no = $this->input->post('old_roll_no'); $this->Stud_Model->update($data,$old_roll_no); 
			
         $query = $this->db->get("stud"); 
         $data['records'] = $query->result(); 
         $this->load->view('Stud_view',$data); 
      } 
  
      public function delete_student() { 
         $this->load->model('Stud_Model'); $roll_no = $this->uri->segment('3'); $this->Stud_Model->delete($roll_no); $query = $this->db->get("stud"); $data['records'] = $query->result(); $this->load->view('Stud_view',$data); 
      } 
   } 
?>

Créez une classe de modèle appelée Stud_Model.php et enregistrez-le dans application/models/Stud_Model.php

<?php 
   class Stud_Model extends CI_Model {
	
      function __construct() { 
         parent::__construct(); 
      } 
   
      public function insert($data) { 
         if ($this->db->insert("stud", $data)) { 
            return true; 
         } 
      } 
   
      public function delete($roll_no) { if ($this->db->delete("stud", "roll_no = ".$roll_no)) { return true; } } public function update($data,$old_roll_no) { $this->db->set($data); $this->db->where("roll_no", $old_roll_no); $this->db->update("stud", $data); 
      } 
   } 
?>

Créez un fichier de vue appelé Stud_add.php et enregistrez-le dans application/views/Stud_add.php

<!DOCTYPE html> 
<html lang = "en">
 
   <head> 
      <meta charset = "utf-8"> 
      <title>Students Example</title> 
   </head> 
	
   <body> 
      <form method = "" action = "">
		
         <?php 
            echo form_open('Stud_controller/add_student');
            echo form_label('Roll No.'); 
            echo form_input(array('id'=>'roll_no','name'=>'roll_no')); 
            echo "<br/>"; 
			
            echo form_label('Name'); 
            echo form_input(array('id'=>'name','name'=>'name')); 
            echo "<br/>"; 
			
            echo form_submit(array('id'=>'submit','value'=>'Add')); 
            echo form_close(); 
         ?> 
		
      </form> 
   </body>
	
</html>

Créez un fichier de vue appelé Stud_edit.php et enregistrez-le dans application/views/Stud_edit.php

<!DOCTYPE html> 
<html lang = "en">
 
   <head> 
      <meta charset = "utf-8"> 
      <title>Students Example</title> 
   </head> 
	
   <body> 
      <form method = "" action = "">
		
         <?php 
            echo form_open('Stud_controller/update_student'); 
            echo form_hidden('old_roll_no',$old_roll_no); 
            echo form_label('Roll No.'); 
            echo form_input(array('id'⇒'roll_no',
               'name'⇒'roll_no','value'⇒$records[0]→roll_no)); echo " "; echo form_label('Name'); echo form_input(array('id'⇒'name','name'⇒'name', 'value'⇒$records[0]→name)); 
            echo "
            "; 

            echo form_submit(array('id'⇒'sub mit','value'⇒'Edit')); 
            echo form_close();
         ?> 
			
      </form> 
   </body>
	
</html>

Créez un fichier de vue appelé Stud_view.php et enregistrez-le dans application/views/Stud_view.php

<!DOCTYPE html> 
<html lang = "en">
 
   <head> 
      <meta charset = "utf-8"> 
      <title>Students Example</title> 
   </head>
	
   <body> 
      <a href = "<?php echo base_url(); ?>
         index.php/stud/add_view">Add</a>
		
      <table border = "1"> 
         <?php 
            $i = 1; echo "<tr>"; echo "<td>Sr#</td>"; echo "<td>Roll No.</td>"; echo "<td>Name</td>"; echo "<td>Edit</td>"; echo "<td>Delete</td>"; echo "<tr>"; foreach($records as $r) { echo "<tr>"; echo "<td>".$i++."</td>"; 
               echo "<td>".$r->roll_no."</td>"; echo "<td>".$r->name."</td>"; 
               echo "<td><a href = '".base_url()."index.php/stud/edit/"
                  .$r->roll_no."'>Edit</a></td>"; echo "<td><a href = '".base_url()."index.php/stud/delete/" .$r->roll_no."'>Delete</a></td>"; 
               echo "<tr>"; 
            } 
         ?>
      </table> 
		
   </body>
	
</html>

Apportez la modification suivante dans le fichier d'itinéraire à application/config/routes.php et ajoutez la ligne suivante à la fin du fichier.

$route['stud'] = "Stud_controller"; $route['stud/add'] = 'Stud_controller/add_student'; 
$route['stud/add_view'] = 'Stud_controller/add_student_view'; $route['stud/edit/(\d+)'] = 'Stud_controller/update_student_view/$1'; $route['stud/delete/(\d+)'] = 'Stud_controller/delete_student/$1';

Maintenant, exécutons cet exemple en visitant l'URL suivante dans le navigateur. Remplacez yoursite.com par votre URL.

http://yoursite.com/index.php/stud

La partie essentielle d'un framework CodeIgniter est ses bibliothèques. Il fournit un riche ensemble de bibliothèques, qui augmentent indirectement la vitesse de développement d'une application. La bibliothèque système se trouve dans système / bibliothèques. Tout ce que nous avons à faire est de charger la bibliothèque que nous voulons utiliser. La bibliothèque peut être chargée comme indiqué ci-dessous -

$this->load->library('class name');

class nameest le nom de la bibliothèque que nous voulons charger. Si nous voulons charger plusieurs bibliothèques, nous pouvons simplement passer un tableau comme argument àlibrary() fonction comme indiqué ci-dessous -

$this->load->library(array('email', 'table'));

Classes de bibliothèque

Les classes de bibliothèque sont situées dans system/libraries. Chaque classe a diverses fonctions pour simplifier le travail de développement. Le tableau suivant montre les noms de la classe de bibliothèque et sa description.

SN Classe de bibliothèque et description
1

Benchmarking Class

La classe de benchmarking est toujours active, permettant de calculer la différence de temps entre deux points marqués.

2

Caching Class

Cette classe mettra en cache les pages, pour accéder rapidement à la vitesse de la page.

3

Calendaring Class

En utilisant cette classe, vous pouvez créer dynamiquement des calendriers.

4

Shopping Cart Class

En utilisant cette classe, vous pouvez ajouter ou supprimer un article du panier. Les éléments sont enregistrés en session et resteront actifs jusqu'à ce que l'utilisateur navigue sur le site.

5

Config Class

Les préférences de configuration peuvent être récupérées à l'aide de cette classe. Cette classe est initialisée automatiquement.

6

Email Class

Cette classe fournit des fonctionnalités liées aux e-mails, telles que l'envoi ou la réponse à un e-mail.

sept

Encryption Class

Cette classe fournit une fonctionnalité de chiffrement de données bidirectionnel.

8

File Uploading Class

Cette classe fournit des fonctionnalités liées au téléchargement de fichiers. Vous pouvez définir diverses préférences telles que le type de fichier à télécharger, la taille des fichiers, etc.

9

Form Validation Class

Cette classe fournit diverses fonctions pour valider le formulaire.

dix

FTP Class

Cette classe fournit diverses fonctions liées au FTP comme le transfert de fichiers pour supprimer le serveur, le déplacement, le changement de nom ou la suppression de fichiers sur le serveur.

11

Image Manipulation Class

La manipulation de l'image comme le redimensionnement, la création de vignettes, le recadrage, la rotation, le filigrane peut être effectuée à l'aide de cette classe.

12

Input Class

Cette classe pré-traite les données d'entrée pour des raisons de sécurité.

13

Language Class

Cette classe est utilisée pour l'internationalisation.

14

Loader Class

Cette classe charge des éléments tels que les fichiers d'affichage, les pilotes, les assistants, les modèles, etc.

15

Migrations Class

Cette classe fournit des fonctionnalités liées aux migrations de bases de données.

16

Output Class

Cette classe envoie la sortie au navigateur et met également en cache cette page Web.

17

Pagination Class

Cette classe ajoute des fonctionnalités de pagination à la page Web.

18

Template Parser Class

La classe d'analyseur de modèle peut effectuer une substitution de texte simple pour les pseudo-variables contenues dans vos fichiers de vue. Il peut analyser des variables simples ou des paires de balises variables.

19

Security Class

Cette classe contient des fonctions liées à la sécurité telles que le filtrage XSS, CSRF, etc.

20

Session Library

Cette classe fournit des fonctionnalités pour maintenir la session de votre application.

21

HTML Table

Cette classe est utilisée pour générer automatiquement des tableaux HTML à partir des résultats d'un tableau ou d'une base de données.

22

Trackback Class

La classe de rétrolien fournit des fonctions qui vous permettent d'envoyer et de recevoir des données de rétrolien.

23

Typography Class

La classe Typography fournit des méthodes qui aident à mettre en forme du texte.

24

Unit Testing Class

Cette classe fournit des fonctionnalités pour tester l'unité de votre application et générer le résultat.

25

URI Class

La classe URI fournit des méthodes qui vous aident à récupérer des informations à partir de vos chaînes URI. Si vous utilisez le routage URI, vous pouvez également récupérer des informations sur les segments réacheminés.

26

User Agent Class

La classe d'agent utilisateur fournit des fonctions qui aident à identifier les informations sur le navigateur, l'appareil mobile ou le robot visitant votre site. De plus, vous pouvez obtenir des informations sur le référent ainsi que des informations sur la langue et les jeux de caractères pris en charge.

27

XML-RPC and XML-RPC Server Classes

Les classes XML-RPC de CodeIgniter vous permettent d'envoyer des requêtes à un autre serveur ou de configurer votre propre serveur XML-RPC pour recevoir des requêtes.

28

Zip Encoding Class

Cette classe est utilisée pour créer des archives zip de vos données.

Création de bibliothèques

CodeIgniter a un riche ensemble de bibliothèques, que vous pouvez trouver dans system/libraries mais CodeIgniter n'est pas seulement limité aux bibliothèques système, vous pouvez également créer vos propres bibliothèques, qui peuvent être stockées dans application/librariesdossier. Vous pouvez créer des bibliothèques de trois manières.

  • Créer une nouvelle bibliothèque
  • Étendre la bibliothèque native
  • Remplacer la bibliothèque native

Créer une nouvelle bibliothèque

Lors de la création d'une nouvelle bibliothèque, il convient de garder à l'esprit les choses suivantes -

  • Le nom du fichier doit commencer par une majuscule, par exemple Mylibrary.php
  • Le nom de la classe doit commencer par une majuscule, par exemple class Mylibrary
  • Le nom de la classe et le nom du fichier doivent correspondre.

Mylibrary.php

<?php if ( ! defined('BASEPATH')) exit('No direct script access allowed');
   
   class Mylibrary {
	
      public function some_function() {
      }
   }
	
/* End of file Mylibrary.php */

Loading the Custom Library

La bibliothèque ci-dessus peut être chargée en exécutant simplement la ligne suivante dans votre contrôleur.

$this->load->library(‘mylibrary’);

mylibrary est le nom de votre bibliothèque et vous pouvez l'écrire aussi bien en minuscules qu'en majuscules. Utilisez le nom de la bibliothèque sans l'extension «.php». Après avoir chargé la bibliothèque, vous pouvez également appeler la fonction de cette classe comme indiqué ci-dessous.

$this->mylibrary->some_function();

Étendre la bibliothèque native

Parfois, vous devrez peut-être ajouter vos propres fonctionnalités à la bibliothèque fournie par CodeIgniter. CodeIgniter fournit des fonctionnalités par lesquelles vous pouvez étendre la bibliothèque native et ajouter vos propres fonctions. Pour ce faire, vous devez étendre la classe de la classe de bibliothèque native. Par exemple, si vous souhaitez étendre la bibliothèque de messagerie, cela peut être fait comme indiqué ci-dessous -

Class MY_Email extends CI_Email { 
}

Ici, dans l'exemple ci-dessus, la classe MY_Email étend la classe de messagerie CI_Email de la bibliothèque native. Cette bibliothèque peut être chargée par la méthode standard de chargement de la bibliothèque de courrier électronique. Enregistrez le code ci-dessus dans le fichier My_Email.php

Remplacer la bibliothèque native

Dans certaines situations, vous ne souhaitez pas utiliser la bibliothèque native comme elle fonctionne et souhaitez la remplacer par votre propre manière. Cela peut être fait en remplaçant la bibliothèque native. Pour ce faire, il vous suffit de donner le même nom de classe que dans la bibliothèque native. Par exemple, si vous souhaitez remplacer leEmail class, puis utilisez le code comme indiqué ci-dessous. Enregistrez votre nom de fichier avecEmail.php et donnez un nom de classe à CI_Email.

Email.php

Class CI_Email { 
}

Plusieurs fois, lors de l'utilisation de l'application, nous rencontrons des erreurs. C'est très ennuyeux pour les utilisateurs si les erreurs ne sont pas gérées correctement. CodeIgniter fournit un mécanisme de gestion des erreurs simple.

Vous souhaitez que les messages s'affichent lorsque l'application est en mode développement plutôt qu'en mode production car les messages d'erreur peuvent être résolus facilement au stade du développement.

L'environnement de votre application peut être modifié en modifiant la ligne ci-dessous de index.phpfichier. Cela peut être défini sur n'importe quoi, mais normalement, trois valeurs (développement, test, production) sont utilisées à cette fin.

define('ENVIRONMENT', isset($_SERVER['CI_ENV']) ? $_SERVER['CI_ENV'] : 'development');

Un environnement différent nécessitera différents niveaux de rapport d'erreur. Par défaut, le mode développement affichera les erreurs et les tests et le mode direct les masqueront. CodeIgniter fournit trois fonctions comme indiqué ci-dessous pour gérer les erreurs.

  • show_error() La fonction affiche les erreurs au format HTML en haut de l'écran.

Syntax

show_error ( $ message,$status_code, $header = 'Une erreur a été rencontrée' )

Parameters

  • $message( mixte ) - Message d'erreur

  • $status_code( int ) - Code d'état de la réponse HTTP

  • $heading( string ) - En-tête de page d'erreur

Return Type

mixte
  • show_404() La fonction affiche une erreur si vous essayez d'accéder à une page qui n'existe pas.

Syntax

show_404 ( $ page = '', $ log_error = TRUE )

Parameters

  • $page( string ) - chaîne URI

  • $log_error( booléen ) - S'il faut enregistrer l'erreur

Return Type

néant
  • log_message()La fonction est utilisée pour écrire des messages de journal. Ceci est utile lorsque vous souhaitez rédiger des messages personnalisés.

Syntax

log_message ( $ level,$message, $php_error = FALSE )

Parameters

  • $level( chaîne ) - Niveau de journalisation: 'erreur', 'débogage' ou 'info'

  • $message( string ) - Message à enregistrer

  • $php_error( booléen ) - Si nous enregistrons un message d'erreur PHP natif

Return Type

néant

La journalisation peut être activée dans application/config/config.phpfichier. Ci-dessous, la capture d'écran du fichier config.php, où vous pouvez définir la valeur de seuil.

/*
|--------------------------------------------------------------------------------
|   Error Logging Threshold
|--------------------------------------------------------------------------------
| You can enable error logging by setting a threshold over zero. The 
| threshold determines what gets logged. Threshold options are:
|
|   0 = Disable logging, Error logging TURNED OFF
|   1 = Error Message (including PHP errors)
|   2 = Debug Message
|   3 = Informational Messages
|   4 = All Messages
|
| You can also pass an array with threshold levels to show individual error types
|
|   array(2) = Debug Message, without Error Messages
| For a live site you'll usually only enable Errors (1) to be logged otherwise 
| your log files will fill up very fast.
|
*/
$config['log_threshold'] = 0;

Vous pouvez trouver les messages du journal dans application/log/. Assurez-vous que ce répertoire est accessible en écriture avant d'activer les fichiers journaux.

Différents modèles de messages d'erreur sont disponibles dans application/views/errors/cli ou application/views/errors/html.

En utilisant la classe File Uploading, nous pouvons télécharger des fichiers et nous pouvons également restreindre le type et la taille du fichier à télécharger. Suivez les étapes indiquées dans l'exemple donné pour comprendre le processus de téléchargement de fichiers dans CodeIgniter.

Exemple

Copiez le code suivant et stockez-le dans application/view/Upload_form.php.

<html>
 
   <head> 
      <title>Upload Form</title> 
   </head>
	
   <body> 
      <?php echo $error;?> 
      <?php echo form_open_multipart('upload/do_upload');?> 
		
      <form action = "" method = "">
         <input type = "file" name = "userfile" size = "20" /> 
         <br /><br /> 
         <input type = "submit" value = "upload" /> 
      </form> 
		
   </body>
	
</html>

Copiez le code ci-dessous et stockez-le sur application/view/Upload_success.php

<html>
 
   <head> 
      <title>Upload Form</title> 
   </head>
	
   <body>  
      <h3>Your file was successfully uploaded!</h3>  
		
      <ul> 
         <?phpforeach ($upload_data as $item => $value):?> 
         <li><?php echo $item;?>: <?php echo $value;?></li> 
         <?phpendforeach; ?>
      </ul>  
		
      <p><?php echo anchor('upload', 'Upload Another File!'); ?></p>  
   </body>
	
</html>

Copiez le code ci-dessous et stockez-le sur application/controllers/Upload.php. Créer "uploads»À la racine de CodeIgniter c'est-à-dire dans le répertoire parent du dossier de l'application.

<?php
  
   class Upload extends CI_Controller {
	
      public function __construct() { 
         parent::__construct(); 
         $this->load->helper(array('form', 'url')); } public function index() { $this->load->view('upload_form', array('error' => ' ' )); 
      } 
		
      public function do_upload() { 
         $config['upload_path'] = './uploads/'; $config['allowed_types'] = 'gif|jpg|png'; 
         $config['max_size'] = 100; $config['max_width']     = 1024; 
         $config['max_height'] = 768; $this->load->library('upload', $config); if ( ! $this->upload->do_upload('userfile')) {
            $error = array('error' => $this->upload->display_errors()); 
            $this->load->view('upload_form', $error); 
         }
			
         else { 
            $data = array('upload_data' => $this->upload->data()); 
            $this->load->view('upload_success', $data); 
         } 
      } 
   } 
?>

Apportez la modification suivante au fichier d'itinéraire dans application/config/routes.php et ajoutez la ligne suivante à la fin du fichier.

$route['upload'] = 'Upload';

Maintenant, exécutons cet exemple en visitant l'URL suivante dans le navigateur. Remplacez yoursite.com par votre URL.

http://yoursite.com/index.php/upload

Il produira l'écran suivant -

Après avoir téléchargé un fichier avec succès, vous verrez l'écran suivant -

L'envoi d'e-mails dans CodeIgniter est beaucoup plus facile. Vous configurez également les préférences concernant les e-mails dans CodeIgniter. CodeIgniter fournit les fonctionnalités suivantes pour l'envoi d'e-mails -

  • Protocoles multiples - Mail, Sendmail et SMTP
  • Chiffrement TLS et SSL pour SMTP
  • Plusieurs destinataires
  • CC et BCC
  • E-mail HTML ou texte en clair
  • Attachments
  • Habillage de mots
  • Priorities
  • Mode BCC Batch, permettant de diviser de grandes listes de diffusion en petits lots BCC.
  • Outils de débogage des e-mails

La classe Email a les fonctions suivantes pour simplifier le travail d'envoi d'e-mails.

SN Syntaxe Paramètres Revenir Type de retour
1 from ( $ from [, $ name = '' [, $ return_path = NULL ]])

$from( chaîne ) - Adresse e-mail «De»

$name( chaîne ) - Nom d'affichage «De»

$return_path( chaîne ) - Adresse e-mail facultative vers laquelle rediriger les e-mails non livrés

Instance CI_Email (chaînage de méthodes) CI_Email
2 reply_to ( $ replyto [, $ name = '' ])

$replyto( string ) - Adresse e-mail pour les réponses

$name( string ) - Nom d'affichage de l'adresse e-mail de réponse

Instance CI_Email (chaînage de méthodes) CI_Email
2 à ( $ à )

$to( mixte ) - Chaîne délimitée par des virgules ou un tableau d'adresses e-mail

Instance CI_Email (chaînage de méthodes) CI_Email
3 cc ( $ cc )

$cc( mixte ) - Chaîne délimitée par des virgules ou un tableau d'adresses e-mail

Instance CI_Email (chaînage de méthodes) CI_Email
4 cci ( $ bcc [, $ limite = '' ])

$bcc( mixte ) - Chaîne délimitée par des virgules ou un tableau d'adresses e-mail

$limit( int ) - Nombre maximum d'e-mails à envoyer par lot

Instance CI_Email (chaînage de méthodes) CI_Email
5 sujet ( $ sujet )

$subject( string ) - Ligne d'objet de l'e-mail

Instance CI_Email (chaînage de méthodes) CI_Email
6 message ( $ body )

$body( string ) - Corps du message électronique

Instance CI_Email (chaînage de méthodes) CI_Email
sept set_alt_message ( $ str )

$str( string ) - Autre corps du message électronique

Instance CI_Email (chaînage de méthodes) CI_Email
8 set_header ( $ header, $ value )

$header( string ) - Nom de l'en-tête

$value( string ) - Valeur d'en-tête

Instance CI_Email (chaînage de méthodes) CI_Email
9 clear ([ $ clear_attachments = FALSE ])

$clear_attachments( booléen ) - Effacer ou non les pièces jointes

Instance CI_Email (chaînage de méthodes) CI_Email
dix envoyer ([ $ auto_clear = TRUE ])

$auto_clear( booléen ) - Indique s'il faut effacer automatiquement les données du message

Instance CI_Email (chaînage de méthodes) CI_Email
11 attach ($ filename [, $disposition = ''[, $nouveau nom = NULL [, $ mime = '']]])

$filename( string ) - Nom du fichier

$disposition( chaîne ) - 'disposition' de la pièce jointe. La plupart des clients de messagerie prennent leur propre décision, quelle que soit la spécification MIME utilisée ici. iana

$newname( string ) - Nom de fichier personnalisé à utiliser dans l'e-mail

$mime( chaîne ) - type MIME à utiliser (utile pour les données tamponnées)

Instance CI_Email (chaînage de méthodes) CI_Email
12 attachment_cid ( $ filename )

$filename( chaîne ) - Nom du fichier de pièce jointe existant

ID de contenu de la pièce jointe ou FALSE si non trouvé chaîne

Envoi d'un e-mail

Pour envoyer un e-mail à l'aide de CodeIgniter, vous devez d'abord charger la bibliothèque d'e-mails en utilisant ce qui suit -

$this->load->library('email');

Après avoir chargé la bibliothèque, exécutez simplement les fonctions suivantes pour définir les éléments nécessaires à l'envoi d'un e-mail. lefrom() La fonction est utilisée pour définir - à partir de l'endroit où l'e-mail est envoyé et to()est utilisée - à qui l'e-mail est envoyé. lesubject() et message() La fonction est utilisée pour définir l'objet et le message de l'e-mail.

$this->email->from('your@example.com', 'Your Name'); $this->email->to('someone@example.com');
 
$this->email->subject('Email Test'); $this->email->message('Testing the email class.');

Après cela, exécutez le send() comme indiqué ci-dessous pour envoyer un e-mail.

$this->email->send();

Exemple

Créer un fichier de contrôleur Email_controller.php et enregistrez-le dans application/controller/Email_controller.php.

<?php 
   class Email_controller extends CI_Controller { 
 
      function __construct() { 
         parent::__construct(); 
         $this->load->library('session'); 
         $this->load->helper('form'); } public function index() { $this->load->helper('form'); 
         $this->load->view('email_form'); } public function send_mail() { $from_email = "your@example.com"; 
         $to_email = $this->input->post('email'); 
   
         //Load email library 
         $this->load->library('email'); $this->email->from($from_email, 'Your Name'); $this->email->to($to_email); $this->email->subject('Email Test'); 
         $this->email->message('Testing the email class.'); //Send mail if($this->email->send()) 
         $this->session->set_flashdata("email_sent","Email sent successfully."); else $this->session->set_flashdata("email_sent","Error in sending Email."); 
         $this->load->view('email_form'); 
      } 
   } 
?>

Créez un fichier de vue appelé email_form.php et enregistrez-le à application/views/email_form.php

<!DOCTYPE html> 
<html lang = "en"> 

   <head> 
      <meta charset = "utf-8"> 
      <title>CodeIgniter Email Example</title> 
   </head>
	
   <body> 
      <?php 
         echo $this->session->flashdata('email_sent'); 
         echo form_open('/Email_controller/send_mail'); 
      ?> 
		
      <input type = "email" name = "email" required /> 
      <input type = "submit" value = "SEND MAIL"> 
		
      <?php 
         echo form_close(); 
      ?> 
   </body>
	
</html>

Apportez les modifications dans le routes.php déposer dans application/config/routes.php et ajoutez la ligne suivante à la fin du fichier.

$route['email'] = 'Email_Controller';

Exécutez l'exemple ci-dessus en visitant le lien suivant. Remplacez yoursite.com par l'URL de votre site.

http://yoursite.com/index.php/email

La validation est un processus important lors de la création d'une application Web. Cela garantit que les données que nous obtenons sont correctes et valides à stocker ou à traiter. CodeIgniter a rendu cette tâche très facile. Comprenons ce processus avec un exemple simple.

Exemple

Créer un fichier de vue myform.php et enregistrez le code ci-dessous dans application/views/myform.php. Cette page affichera un formulaire où l'utilisateur peut soumettre son nom et nous validerons cette page pour nous assurer qu'elle ne doit pas être vide lors de la soumission.

<html>
 
   <head> 
      <title>My Form</title> 
   </head>
	
   <body>
      <form action = "" method = "">
         <?php echo validation_errors(); ?>  
         <?php echo form_open('form'); ?>  
         <h5>Name</h5> 
         <input type = "text" name = "name" value = "" size = "50" />  
         <div><input type = "submit" value = "Submit" /></div>  
      </form>  
   </body>
	
</html>

Créer un fichier de vue formsuccess.php et enregistrez-le dans application/views/formsuccess.php. Cette page s'affichera si le formulaire est validé avec succès.

<html>
 
   <head> 
      <title>My Form</title>
   </head> 
	
   <body>  
      <h3>Your form was successfully submitted!</h3>  
      <p><?php echo anchor('form', 'Try it again!'); ?></p>  
   </body>
	
</html>

Créer un fichier de contrôleur Form.php et enregistrez-le dans application/controller/Form.php. Ce formulaire affichera des erreurs s'il n'est pas correctement validé ou redirigé versformsuccess.php page.

<?php
  
   class Form extends CI_Controller { 
	
      public function index() { 
         /* Load form helper */ 
         $this->load->helper(array('form'));
			
         /* Load form validation library */ 
         $this->load->library('form_validation'); /* Set validation rule for name field in the form */ $this->form_validation->set_rules('name', 'Name', 'required'); 
			
         if ($this->form_validation->run() == FALSE) { $this->load->view('myform'); 
         } 
         else { 
            $this->load->view('formsuccess'); 
         } 
      }
   }
?>

Ajoutez la ligne suivante dans application/config/routes.php.

$route['validation'] = 'Form';

Exécutons cet exemple en visitant l'URL suivante dans le navigateur. Cette URL peut être différente en fonction de votre site.

http://yoursite.com/index.php/validation

Il produira l'écran suivant -

Nous avons ajouté une validation dans le contrôleur - Nameest un champ obligatoire avant de soumettre le formulaire. Ainsi, si vous cliquez sur le bouton Soumettre sans rien entrer dans le champ du nom, il vous sera demandé de saisir le nom avant de soumettre comme indiqué dans l'écran ci-dessous.

Après avoir entré le nom avec succès, vous serez redirigé vers l'écran comme indiqué ci-dessous.

Dans l'exemple ci-dessus, nous avons utilisé le paramètre de règle requis. Il existe de nombreuses règles disponibles dans CodeIgniter, qui sont décrites ci-dessous.

Référence de règle de validation

Ce qui suit est une liste de toutes les règles natives disponibles à l’utilisation -

Règle Paramètre La description Exemple

required

Non Renvoie FALSE si l'élément de formulaire est vide.

matches

Oui Renvoie FALSE si l'élément de formulaire ne correspond pas à celui du paramètre. correspond à [form_item]

regex_match

Oui Renvoie FALSE si l'élément de formulaire ne correspond pas à l'expression régulière. regex_match [/ regex /]

differs

Oui Renvoie FALSE si l'élément de formulaire ne diffère pas de celui du paramètre. diffère [form_item]

is_unique

Oui Renvoie FALSE si l'élément de formulaire n'est pas unique au nom de la table et du champ dans le paramètre. Remarque - Cette règle nécessite l'activation de Query Builder pour fonctionner. is_unique [table.field]

min_length

Oui Renvoie FALSE si l'élément de formulaire est plus court que la valeur du paramètre. min_length [3]

max_length

Oui Renvoie FALSE si l'élément de formulaire est plus long que la valeur du paramètre. max_length [12]

exact_length

Oui Renvoie FALSE si l'élément de formulaire n'est pas exactement la valeur du paramètre. exact_length [8]

greater_than

Oui Renvoie FALSE si l'élément de formulaire est inférieur ou égal à la valeur du paramètre ou non numérique. plus grand que [8]

greater_than_equal_to

Oui Renvoie FALSE si l'élément de formulaire est inférieur à la valeur du paramètre ou n'est pas numérique. Greater_than_equal_to [8]

less_than

Oui Renvoie FALSE si l'élément de formulaire est supérieur ou égal à la valeur du paramètre ou non numérique. less_than [8]

less_than_equal_to

Oui Renvoie FALSE si l'élément de formulaire est supérieur à la valeur du paramètre, ou non numérique. less_than_equal_to [8]

in_list

Oui Renvoie FALSE si l'élément de formulaire n'est pas dans une liste prédéterminée. in_list [rouge, bleu, vert]

alpha

Non Renvoie FALSE si l'élément de formulaire contient autre chose que des caractères alphabétiques.

alpha_numeric

Non Renvoie FALSE si l'élément de formulaire contient autre chose que des caractères alphanumériques.

alpha_numeric_spaces

Non Renvoie FALSE si l'élément de formulaire contient autre chose que des caractères alphanumériques ou des espaces. Doit être utilisé après la coupe pour éviter les espaces au début ou à la fin

alpha_dash

Non Renvoie FALSE si l'élément de formulaire contient autre chose que des caractères alphanumériques, des traits de soulignement ou des tirets.

numeric

Non Renvoie FALSE si l'élément de formulaire contient autre chose que des caractères numériques.

integer

Non Renvoie FALSE si l'élément de formulaire contient autre chose qu'un entier.

decimal

Non Renvoie FALSE si l'élément de formulaire contient autre chose qu'un nombre décimal.

is_natural

Non Renvoie FALSE si l'élément de formulaire contient autre chose qu'un nombre naturel - 0, 1, 2, 3, etc.

is_natural_no_zero

Non Renvoie FALSE si l'élément de formulaire contient autre chose qu'un nombre naturel, mais pas zéro - 1, 2, 3, etc.

valid_url

Non Renvoie FALSE si l'élément de formulaire ne contient pas d'URL valide.

valid_email

Non Renvoie FALSE si l'élément de formulaire ne contient pas d'adresse e-mail valide.

valid_emails

Non Renvoie FALSE si une valeur fournie dans une liste séparée par des virgules n'est pas un e-mail valide.

valid_ip

Non Renvoie FALSE si l'adresse IP fournie n'est pas valide. Accepte un paramètre facultatif «ipv4» ou «ipv6» pour spécifier un format IP.

valid_base64

Non Renvoie FALSE si la chaîne fournie contient autre chose que des caractères Base64 valides.

Lors de la création de sites Web, nous devons souvent suivre l'activité et l'état de l'utilisateur et, à cette fin, nous devons utiliser session. CodeIgniter a une classe de session à cet effet.

Initialiser une session

Les données des sessions sont disponibles dans le monde entier via le site, mais pour utiliser ces données, nous devons d'abord initialiser la session. Nous pouvons le faire en exécutant la ligne suivante dans le constructeur.

$this->load->library('session');

Après avoir chargé la bibliothèque de session, vous pouvez simplement utiliser l'objet de session comme indiqué ci-dessous.

$this->session

Ajouter des données de session

En PHP, nous utilisons simplement $_SESSION array pour définir les données de la session comme indiqué ci-dessous.

$_SESSION[‘key’] = value;

Où 'key'est la clé du tableau et value est attribué sur le côté droit du signe égal à.

La même chose peut être faite dans CodeIgniter comme indiqué ci-dessous.

$this->session->set_userdata('some_name', 'some_value');

set_userdata()La fonction prend deux arguments. Le premier argument,some_name, est le nom de la variable de session sous laquelle, some_value sera stocké.

set_userdata() La fonction prend également en charge une autre syntaxe dans laquelle vous pouvez transmettre un tableau pour stocker des valeurs comme indiqué ci-dessous.

$newdata = array( 
   'username'  => 'johndoe', 
   'email'     => 'johndoe@some-site.com', 
   'logged_in' => TRUE
);  

$this->session->set_userdata($newdata);

Supprimer les données de session

En PHP, nous pouvons supprimer les données stockées en session en utilisant le unset() fonction comme indiqué ci-dessous.

unset($_SESSION[‘some_name’]);

La suppression des données de session dans CodeIgniter est très simple, comme indiqué ci-dessous. La version ci-dessous deunset_userdata() La fonction ne supprimera qu'une seule variable de la session.

$this->session->unset_userdata('some_name');

Si vous souhaitez supprimer plus de valeurs de la session ou supprimer un tableau entier, vous pouvez utiliser la version ci-dessous de unset_userdata() fonction.

$this->session->unset_userdata($array_items);

Récupérer les données de session

Après avoir défini les données en session, nous pouvons également récupérer ces données comme indiqué ci-dessous. Userdata()La fonction sera utilisée à cet effet. Cette fonction retourneraNULL si les données auxquelles vous essayez d'accéder ne sont pas disponibles.

$name = $this->session->userdata('name');

Exemple

Créez une classe de contrôleur appelée Session_controller.php et enregistrez-le dans application/controller/Session_controller.php.

<?php 
   class Session_controller extends CI_Controller {
	
      public function index() { 
         //loading session library 
         $this->load->library('session'); //adding data to session $this->session->set_userdata('name','virat');
			
         $this->load->view('session_view'); } public function unset_session_data() { //loading session library $this->load->library('session');
			
         //removing session data 
         $this->session->unset_userdata('name'); $this->load->view('session_view'); 
      } 
		
   } 
?>

Créez un fichier de vue appelé session_view.php et enregistrez-le dans application/views/session_view.php

<!DOCTYPE html> 
<html lang = "en">
 
   <head> 
      <meta charset = "utf-8"> 
      <title>CodeIgniter Session Example</title> 
   </head>
	
   <body> 
      Welcome <?php echo $this->session->userdata('name'); ?> 
      <br> 
      <a href = 'http://localhost:85/CodeIgniter-3.0.1/CodeIgniter3.0.1/index.php/sessionex/unset'>
         Click Here</a> to unset session data. 
   </body>
	
</html>

Apportez les modifications dans le routes.php déposer dans application/config/routes.php et ajoutez la ligne suivante à la fin du fichier.

$route['sessionex'] = 'Session_Controller';

Exécutez l'exemple ci-dessus en utilisant l'adresse suivante. Remplaceryoursite.com avec l'URL de votre site.

http://yoursite.com/index.php/sessionex

Lors de la création d'une application Web, nous ne devons stocker certaines données qu'une seule fois, puis nous souhaitons supprimer ces données. Par exemple, pour afficher un message d'erreur ou un message d'information. En PHP, nous devons le faire manuellement mais CodeIgniter a simplifié ce travail pour nous. Dans CodeIgniter, les données flash ne seront disponibles que jusqu'à la prochaine requête et seront supprimées automatiquement.

Ajouter des données Flash

Nous pouvons simplement stocker des données flash comme indiqué ci-dessous.

$this->session->mark_as_flash('item');
  • mark_as_flash()fonction est utilisée à cet effet, qui ne prend qu'un seul argument de la valeur à stocker. Nous pouvons également passer un tableau pour stocker plusieurs valeurs.

  • set_flashdata()peut également être utilisée, qui prend deux arguments, nom et valeur, comme indiqué ci-dessous. Nous pouvons également passer un tableau.

$this->session->set_flashdata('item','value');

Récupérer les données Flash

Les données Flash peuvent être récupérées à l'aide de la fonction flashdata () qui prend un argument de l'élément à récupérer comme indiqué ci-dessous. La fonction flashdata () s'assure que vous n'obtenez que des données flash et pas d'autres données.

$this->session->flashdata('item');

Si vous ne passez aucun argument, vous pouvez obtenir un tableau avec la même fonction.

Exemple

Créez une classe appelée FlashData_Controller.php et enregistrez-le à application/controller/FlashData_Controller.php.

<?php 
   class FlashData_Controller extends CI_Controller {
	
      public function index() { 
         //Load session library 
         $this->load->library('session');
			
         //redirect to home page 
         $this->load->view('flashdata_home'); } public function add() { //Load session library $this->load->library('session'); 
         $this->load->helper('url'); //add flash data $this->session->set_flashdata('item','item-value'); 
   
         //redirect to home page 
         redirect('flashdata'); 
      } 
   } 
?>

Créez un fichier de vue appelé flashdata_home.php et enregistrez-le dans application/views/ flashdata_home.php

<!DOCTYPE html> 
<html lang = "en">
 
   <head> 
      <meta charset = "utf-8"> 
      <title>CodeIgniter Flashdata Example</title> 
   </head>
	
   <body> 
      Flash Data Example 
      <h2><?php echo $this->session->flashdata('item'); ?></h2> 
      <a href = 'flashdata/add'>Click Here</a> to add flash data. 
   </body>
	
</html>

Apportez les modifications dans le routes.php déposer dans application/config/routes.php et ajoutez la ligne suivante à la fin du fichier.

$route['flashdata'] = 'FlashData_Controller'; 
$route['flashdata/add'] = 'FlashData_Controller/add';

Exécutez l'exemple ci-dessus en visitant le lien suivant. Remplacez yoursite.com par l'URL de votre site.

http://yoursite.com/index.php/flashdata

Après avoir visité l'URL ci-dessus, vous verrez un écran comme indiqué ci-dessous.

Cliquer sur "Click Here”Et vous verrez un écran comme indiqué ci-dessous. Ici, dans cet écran, vous verrez une valeur de variable de données flash. Actualisez à nouveau la page et vous verrez un écran comme ci-dessus et la variable de données flash sera supprimée automatiquement.

Dans certaines situations, lorsque vous souhaitez supprimer des données stockées dans la session après une période spécifique, cela peut être fait en utilisant tempdata fonctionnalité dans CodeIgniter.

Ajouter des données temporaires

Pour ajouter des données comme tempdata, nous devons utiliser mark_as_tempdata()fonction. Cette fonction prend deux éléments d'argument ou éléments à stocker commetempdata et le délai d'expiration de ces articles est indiqué ci-dessous.

// 'item' will be erased after 300 seconds(5 minutes) 
$this->session->mark_as_temp('item',300);

Vous pouvez également transmettre un tableau pour stocker plusieurs données. Tous les éléments stockés ci-dessous expireront après 300 secondes.

$this->session->mark_as_temp(array('item','item2'),300);

Vous pouvez également définir une heure d'expiration différente pour chaque élément, comme indiqué ci-dessous.

// 'item' will be erased after 300 seconds, while 'item2' 
// will do so after only 240 seconds 

$this->session->mark_as_temp(array( 
   'item'=>300, 
   'item2'=>240 
));

Récupérer les données temporaires

Nous pouvons récupérer les données temporaires en utilisant tempdata()fonction. Cette fonction garantit que vous n'obtenez que des données temporaires et pas d'autres données. Regardez l'exemple ci-dessous pour voir comment récupérer des données temp.tempdata() La fonction prendra un argument de l'élément à récupérer.

$this->session->tempdata('item');

Si vous omettez l'argument, vous pouvez récupérer toutes les données temporaires existantes.

Supprimer les données temporaires

Tempdata est supprimé automatiquement après son expiration, mais si vous souhaitez supprimer tempdata avant cela, vous pouvez faire comme indiqué ci-dessous en utilisant le unset_tempdata() fonction, qui prend un argument de l'élément à supprimer.

$this->session->unset_tempdata('item');

Exemple

Créez une classe appelée Tempdata_controller.php et enregistrez-le dans application/controller/Tempdata_controller.php.

<?php 
   class Tempdata_controller extends CI_Controller {
	
      public function index() { 
         $this->load->library('session'); $this->load->view('tempdata_view'); 
      } 
  
      public function add() { 
         $this->load->library('session'); $this->load->helper('url'); 
   
         //tempdata will be removed after 5 seconds 
         $this->session->set_tempdata('item','item-value',5); 
   
         redirect('tempdata'); 
      } 
   } 
?>

Créez un fichier appelé tempdata_view.php et enregistrez-le dans application/views/tempdata_view.php

<!DOCTYPE html> 
<html lang = "en">
 
   <head> 
      <meta charset = "utf-8"> 
      <title>CodeIgniter Tempdata Example</title> 
   </head>
	
   <body> 
      Temp Data Example 
      <h2><?php echo $this->session->tempdata('item'); ?></h2>
      <a href = 'tempdata/add'>Click Here</a> to add temp data. 
   </body>
	
</html>

Apportez les modifications dans le routes.php dans application / config / routes.php et ajoutez la ligne suivante à la fin du fichier.

$route['tempdata'] = "Tempdata_controller"; $route['tempdata/add'] = "Tempdata_controller/add";

Exécutez l'exemple ci-dessus en visitant le lien suivant. Remplacez yoursite.com par l'URL de votre site.

http://yoursite.com/index.php/tempdata

Après avoir visité l'URL ci-dessus, vous verrez un écran comme indiqué ci-dessous.

Cliquer sur “Click Here” lien et vous verrez un écran comme indiqué ci-dessous.

Ici, dans cet écran, vous verrez une valeur de variable de données temporaires. Actualisez à nouveau la même page après cinq secondes car nous avons défini les données temporaires pendant cinq secondes et vous verrez un écran comme ci-dessus et la variable de données temporaires sera supprimée automatiquement après cinq secondes. Si vous actualisez la même page avant 5 secondes, les données temporaires ne seront pas supprimées, car la période n'est pas terminée.

Détruire une session

En PHP, nous utilisons le session_destroy() fonction pour détruire la session et dans CodeIgniter, nous pouvons détruire la fonction comme indiqué ci-dessous.

$this->session->sess_destroy();

Après avoir appelé cette fonction, toutes les données de session, y compris flashdata et tempdata sera supprimé définitivement et ne pourra pas être récupéré.

Le cookie est un petit morceau de données envoyé depuis le serveur Web pour stocker sur l'ordinateur du client. CodeIgniter a un assistant appelé «Cookie Helper» pour la gestion des cookies.

Syntax

set_cookie ( $ name [, $ value = '' [, $ expire = '' [, $ domain = '' [, $ path = '/' [, $ prefix = '' [, $ secure = FALSE [, $ httponly = FALSE ]]]]]]]])

Parameters

  • $name( mixte ) - Nom du cookie ou tableau associatif de tous les paramètres disponibles pour cette fonction

  • $value( string ) - Valeur du cookie

  • $expire( int ) - Nombre de secondes jusqu'à l'expiration

  • $domain( chaîne ) - Domaine du cookie (généralement: .votredomaine.com)

  • $path( string ) - Chemin du cookie

  • $prefix( string ) - Préfixe du nom du cookie

  • $secure( booléen ) - Indique s'il faut envoyer uniquement le cookie via HTTPS

  • $httponly( booléen ) - Indique s'il faut masquer le cookie de JavaScript

Return Type

néant

dans le set_cookie()fonction, nous pouvons transmettre toutes les valeurs de deux manières. Dans le premier cas, seul le tableau peut être transmis et dans le second, des paramètres individuels peuvent également être passés.

Syntax

get_cookie ( $ index [, $ xss_clean = NULL ]])

Parameters

  • $index( string ) - Nom du cookie

  • $xss_clean( booléen ) - Indique s'il faut appliquer le filtrage XSS à la valeur renvoyée

Return

La valeur du cookie ou NULL si non trouvé

Return Type

mixte

le get_cookie() La fonction est utilisée pour obtenir le cookie qui a été défini à l'aide de la fonction set_cookie ().

Syntax

delete_cookie ( $ name [, $ domain = '' [, $ path = '/' [, $ prefix = '' ]]]])

Parameters

  • $name( string ) - Nom du cookie

  • $domain( chaîne ) - Domaine du cookie (généralement: .votredomaine.com)

  • $path( string ) - Chemin du cookie

  • $prefix( string ) - Préfixe du nom du cookie

Return Type

néant

le delete_cookie() La fonction est utilisée pour supprimer le cookie ().

Exemple

Créez un contrôleur appelé Cookie_controller.php et enregistrez-le à application/controller/Cookie_controller.php

<?php 
   class Cookie_controller extends CI_Controller { 
	
      function __construct() { 
         parent::__construct(); 
         $this->load->helper(array('cookie', 'url')); 
      } 
  
      public function index() { 
         set_cookie('cookie_name','cookie_value','3600'); 
         $this->load->view('Cookie_view'); } public function display_cookie() { echo get_cookie('cookie_name'); $this->load->view('Cookie_view');
      } 
  
      public function deletecookie() { 
         delete_cookie('cookie_name'); 
         redirect('cookie/display'); 
      } 
		
   } 
?>

Créez un fichier de vue appelé Cookie_view.php et enregistrez-le à application/views/Cookie_view.php

<!DOCTYPE html> 
<html lang = "en">
 
   <head> 
      <meta charset = "utf-8"> 
      <title>CodeIgniter View Example</title> 
   </head> 
	
   <body> 
      <a href = 'display'>Click Here</a> to view the cookie.<br> 
      <a href = 'delete'>Click Here</a> to delete the cookie. 
   </body>
	
</html>

Modifiez le fichier routes.php dans application / config / routes.php pour ajouter une route pour le contrôleur ci-dessus et ajoutez la ligne suivante à la fin du fichier.

$route['cookie'] = "Cookie_controller"; $route['cookie/display'] = "Cookie_controller/display_cookie"; 
$route['cookie/delete'] = "Cookie_controller/deletecookie";

Après cela, vous pouvez exécuter l'URL suivante dans le navigateur pour exécuter l'exemple.

http://yoursite.com/index.php/cookie

Il produira une sortie comme indiqué dans la capture d'écran suivante.

Les fonctions de la bibliothèque CodeIgniter et les fonctions d'assistance doivent être initialisées avant d'être utilisées, mais il existe certaines fonctions communes qui n'ont pas besoin d'être initialisées.

Ces fonctions communes et leurs descriptions sont données ci-dessous.

Syntaxe is_php ( $ version )
Paramètres

$version( string ) - Numéro de version

Revenir TRUE si la version PHP en cours d'exécution est au moins celle spécifiée ou FALSE sinon
Type de retour néant
La description Détermine si la version PHP utilisée est supérieure au numéro de version fourni.
Syntaxe is_really_writable ( $ fichier )
Paramètres

$file( string ) - Chemin du fichier

Revenir TRUE si le chemin est accessible en écriture, FALSE sinon
Type de retour booléen
La description vérifie si le fichier est accessible en écriture ou non.
Syntaxe config_item ( $ clé )
Paramètres

$key( string ) - Clé d'élément de configuration

Revenir Valeur de la clé de configuration ou NULL si non trouvée
Type de retour mixte
La description Cette fonction est utilisée pour récupérer l'élément de configuration
Syntaxe set_status_header ( $ code [, $ text = '' ])
Paramètres

$code( int ) - Code d'état de la réponse HTTP

$text( string ) - Un message personnalisé à définir avec le code d'état

Revenir
Type de retour néant
La description Cette fonction vous permet de définir manuellement un en-tête d'état du serveur.
Syntaxe remove_invisible_characters ( $ str [, $ url_encoded = TRUE ])
Paramètres

$str( string ) - Chaîne d'entrée

$url_encoded( booléen ) - S'il faut également supprimer les caractères encodés en URL

Revenir Chaîne désinfectée
Type de retour chaîne
La description Cette fonction empêche l'insertion de caractères NULL entre les caractères ASCII
Syntaxe html_escape ( $ var )
Paramètres

$var( mixte ) - Variable à échapper (chaîne ou tableau)

Revenir Chaîne (s) d'échappement HTML
Type de retour mixte
La description Cette fonction agit comme une fonction native PHP htmlspecialchars ().
Syntaxe get_mimes ()
Revenir Un tableau associatif de types de fichiers
Type de retour tableau
La description Cette fonction renvoie une référence au tableau MIME depuis application / config / mimes.php .
Syntaxe is_https ()

Revenir TRUE si vous utilisez actuellement HTTP sur SSL, FALSE sinon
Type de retour booléen
La description Renvoie TRUE si une connexion sécurisée (HTTPS) est utilisée et FALSE dans tous les autres cas (y compris les requêtes non HTTP).
Syntaxe is_cli ()
Revenir TRUE si en cours d'exécution sous CLI, FALSE sinon
Type de retour booléen
La description Renvoie TRUE si l'application est exécutée via la ligne de commande et FALSE sinon.
Syntaxe function_usable ( $ nom_fonction )
Paramètres

$function_name( string ) - Nom de la fonction

Type de retour booléen
La description Renvoie TRUE si une fonction existe et est utilisable, FALSE sinon.

Ci-dessous est un exemple, qui montre toutes les fonctions ci-dessus.

Exemple

Ici, nous n'avons créé qu'un seul contrôleur dans lequel nous utiliserons les fonctions ci-dessus. Copiez le code ci-dessous et enregistrez-le sur application/controller/CommonFun_Controller.php.

<?php 
   class CommonFun_Controller extends CI_Controller { 
	
      public function index() {
         set_status_header(200); 
         echo is_php('5.3')."<br>"; 
         var_dump(is_really_writable('./Form.php')); 
			
         echo config_item('language')."<br>"; 
         echo remove_invisible_characters('This is a ‌test','UTF8')."<br>"; 
			
         $str = '< This > is \' a " test & string'; 
         echo html_escape($str)."<br>"; 
         echo "is_https():".var_dump(is_https())."<br>"; 
         echo "is_cli():".var_dump(is_cli())."<br>"; 
			
         var_dump(function_usable('test'))."<br>"; 
         echo "get_mimes():".print_r(get_mimes())."<br>"; 
      } 
  
      public function test() { 
         echo "Test function"; 
      } 
		
   } 
?>

Changer la routes.php fichier à application / config / routes.php pour ajouter une route pour le contrôleur ci-dessus et ajouter la ligne suivante à la fin du fichier.

$route['commonfunctions'] = 'CommonFun_Controller';

Tapez l'URL suivante dans la barre d'adresse de votre navigateur pour exécuter l'exemple.

http://yoursite.com/index.php/commonfunctions

La mise en cache d'une page améliorera la vitesse de chargement de la page. Si la page est mise en cache, elle sera stockée dans son état entièrement rendu. La prochaine fois, lorsque le serveur recevra une demande pour la page mise en cache, elle sera directement envoyée au navigateur demandé.

Les fichiers mis en cache sont stockés dans application/cachedossier. La mise en cache peut être activée par page. Lors de l'activation du cache, nous devons définir l'heure jusqu'à laquelle il doit rester dans le dossier en cache et après cette période, il sera supprimé automatiquement.

Activer la mise en cache

La mise en cache peut être activée en exécutant la ligne suivante dans n'importe quelle méthode du contrôleur.

$this->output->cache($n);

$n est le nombre de minutes, vous souhaitez que la page reste en cache entre les actualisations.

Désactiver la mise en cache

Le fichier de cache est supprimé lorsqu'il expire, mais lorsque vous souhaitez le supprimer manuellement, vous devez le désactiver. Vous pouvez désactiver la mise en cache en exécutant la ligne suivante.

// Deletes cache for the currently requested URI 
$this->output->delete_cache();
  
// Deletes cache for /foo/bar 
$this->output->delete_cache('/foo/bar');

Exemple

Créez un contrôleur appelé Cache_controller.php et enregistrez-le dans application/controller/Cache_controller.php

<?php 
   class Cache_controller extends CI_Controller { 
	
      public function index() { 
         $this->output->cache(1); 
         $this->load->view('test'); } public function delete_file_cache() { $this->output->delete_cache('cachecontroller'); 
      } 
   } 
?>

Créez un fichier de vue appelé test.php et enregistrez-le dans application/views/test.php

<!DOCTYPE html> 
<html lang = "en">
 
   <head> 
      <meta charset = "utf-8"> 
      <title>CodeIgniter View Example</title> 
   </head>
	
   <body> 
      CodeIgniter View Example 
   </body>
	
</html>

Changer la routes.php déposer dans application/config/routes.php pour ajouter une route pour le contrôleur ci-dessus et ajouter la ligne suivante à la fin du fichier.

$route['cachecontroller'] = 'Cache_controller'; $route['cachecontroller/delete'] = 'Cache_controller/delete_file_cache';

Tapez l'URL suivante dans le navigateur pour exécuter l'exemple.

http://yoursite.com/index.php/cachecontroller

Après avoir visité l'URL ci-dessus, vous verrez qu'un fichier cache sera créé dans application/cachedossier. Pour supprimer le fichier, visitez l'URL suivante.

http://yoursite.com/index.php/cachecontroller/delete

Lors de la création d'une application Web, nous devons souvent rediriger l'utilisateur d'une page vers une autre. CodeIgniter nous facilite cette tâche. leredirect() La fonction est utilisée à cet effet.

Syntax

réorienter($uri = '', $method = 'auto', $ code = NULL )

Parameters

  • $uri( string ) - chaîne URI

  • $method( string ) - Méthode de redirection ('auto', 'location' ou 'refresh')

  • $code( chaîne ) - Code de réponse HTTP (généralement 302 ou 303)

Return type

néant

Le premier argument peut avoir deux types d'URI. Nous pouvons transmettre l'URL complète du site ou les segments URI au contrôleur que vous souhaitez diriger.

Le deuxième paramètre facultatif peut avoir l'une des trois valeurs d'auto, d'emplacement ou d'actualisation. La valeur par défaut est auto.

Le troisième paramètre facultatif n'est disponible qu'avec les redirections d'emplacement et il vous permet d'envoyer un code de réponse HTTP spécifique.

Exemple

Créez un contrôleur appelé Redirect_controller.php et enregistrez-le dans application/controller/Redirect_controller.php

<?php 
   class Redirect_controller extends CI_Controller { 
	
      public function index() { 
         /*Load the URL helper*/ 
         $this->load->helper('url'); /*Redirect the user to some site*/ redirect('http://www.tutorialspoint.com'); } public function computer_graphics() { /*Load the URL helper*/ $this->load->helper('url'); 
         redirect('http://www.tutorialspoint.com/computer_graphics/index.htm'); 
      } 
  
      public function version2() { 
         /*Load the URL helper*/ 
         $this->load->helper('url'); 
   
         /*Redirect the user to some internal controller’s method*/ 
         redirect('redirect/computer_graphics'); 
      } 
		
   } 
?>

Changer la routes.php déposer dans application/config/routes.php pour ajouter une route pour le contrôleur ci-dessus et ajouter la ligne suivante à la fin du fichier.

$route['redirect'] = 'Redirect_controller'; 
$route['redirect/version2'] = 'Redirect_controller/version2'; $route['redirect/computer_graphics'] = 'Redirect_controller/computer_graphics';

Tapez l'URL suivante dans le navigateur pour exécuter l'exemple.

http://yoursite.com/index.php/redirect

L'URL ci-dessus vous redirigera vers le site Web tutorialspoint.com et si vous visitez l'URL suivante, elle vous redirigera vers le didacticiel d'infographie sur tutorialspoint.com.

http://yoursite.com/index.php/redirect/computer_graphics

Lors de la création d'une application Web, nous sommes très préoccupés par les performances du site Web en termes de temps d'exécution du contrôleur et de quantité de mémoire utilisée. Non seulement les performances, mais nous devons également voir les informations sur les données telles que les données POST, les données des requêtes de base de données, les données de session, etc. à des fins de débogage lors du développement d'une application. CodeIgniter nous a facilité ce travail en profilant une application.

Activer le profilage

Pour activer le profilage de votre application, exécutez simplement la commande donnée ci-dessous dans l'une des méthodes de votre contrôleur.

$this->output->enable_profiler(TRUE);

Le rapport du profilage est visible en bas de page après l'avoir activé.

Désactiver le profilage

Pour désactiver le profilage de votre application, exécutez simplement la commande donnée ci-dessous dans l'une des méthodes de votre contrôleur.

$this->output->enable_profiler(FALSE);

Activer / désactiver la section Profiler

Le profilage peut être effectué par section. Vous pouvez activer ou désactiver le profilage d'une section en définissant une valeur booléenne TRUE ou FALSE. Si vous souhaitez définir le profilage sur l'application, vous pouvez le faire dans un fichier situé dansapplication/config/profiler.php

Par exemple, la commande suivante activera les requêtes de profilage pour l'ensemble de l'application.

$config['queries'] = TRUE;

Dans le tableau suivant, la clé est le paramètre, qui peut être défini dans le tableau de configuration pour activer ou désactiver un profil particulier.

Clé La description Défaut

benchmarks

Temps écoulé des points de référence et temps total d'exécution VRAI

config

Variables CodeIgniterConfig VRAI

controller_info

La classe et la méthode Controller demandées VRAI

get

Toutes les données GET transmises dans la demande VRAI

http_headers

Les en-têtes HTTP de la requête actuelle VRAI

memory_usage

Quantité de mémoire consommée par la demande en cours, en octets VRAI

post

Toutes les données POST transmises dans la demande VRAI

queries

Liste de toutes les requêtes de base de données exécutées, y compris l'heure d'exécution VRAI

uri_string

L'URI de la requête actuelle VRAI

session_data

Données stockées dans la session en cours VRAI

query_toggle_count

Nombre de requêtes après lequel le bloc de requête sera masqué par défaut. 25

Le profileur défini dans le fichier dans application/config/profiler.php peut être remplacé en utilisant le set_profiler_sections() fonction dans les contrôleurs comme indiqué ci-dessous.

$sections = array( 
   'config'  => TRUE, 
   'queries' => TRUE 
); 
 
$this->output->set_profiler_sections($sections);

Définition des points de référence

Si vous souhaitez mesurer le temps nécessaire à l'exécution d'un ensemble de lignes ou à l'utilisation de la mémoire, vous pouvez le calculer à l'aide des points d'analyse comparative dans CodeIgniter. Il y a un "Benchmarking”À cet effet dans CodeIgniter.

Cette classe est chargée automatiquement; vous n'avez pas à le charger. Il peut être utilisé n'importe où dans vos classes de contrôleur, de vue et de modèle. Tout ce que vous avez à faire est de marquer un point de départ et un point final, puis d'exécuter leelapsed_time() fonction entre ces deux points marqués et vous pouvez obtenir le temps qu'il a fallu pour exécuter ce code comme indiqué ci-dessous.

<?php 
   $this->benchmark->mark('code_start'); // Some code happens here $this->benchmark->mark('code_end');
  
   echo $this->benchmark->elapsed_time('code_start', 'code_end'); 
?>

Pour afficher l'utilisation de la mémoire, utilisez la fonction memory_usage() comme indiqué dans le code suivant.

<?php 
   echo $this->benchmark->memory_usage(); 
?>

Exemple

Créez un contrôleur appelé Profiler_controller.php et enregistrez-le dans application/controller/Profiler_controller.php

<?php 
   class Profiler_controller extends CI_Controller {
  
      public function index() {
	
         //enable profiler
         $this->output->enable_profiler(TRUE); $this->load->view('test'); 
      } 
  
      public function disable() {
	
         //disable profiler 
         $this->output->enable_profiler(FALSE); $this->load->view('test'); 
      }
		
   } 
?>

Créez un fichier de vue appelé test.php et enregistrez-le à application/views/test.php

<!DOCTYPE html> 
<html lang = "en">
 
   <head> 
      <meta charset = "utf-8"> 
      <title>CodeIgniter View Example</title> 
   </head>
	
   <body> 
      CodeIgniter View Example 
   </body>
	
</html>

Modifiez le fichier routes.php à application/config/routes.php pour ajouter une route pour le contrôleur ci-dessus et ajouter la ligne suivante à la fin du fichier.

$route['profiler'] = "Profiler_controller"; $route['profiler/disable'] = "Profiler_controller/disable"

Après cela, vous pouvez taper l'URL suivante dans la barre d'adresse de votre navigateur pour exécuter l'exemple.

http://yoursite.com/index.php/profiler

L'URL ci-dessus activera le profileur et produira une sortie comme indiqué dans la capture d'écran suivante.

Pour désactiver le profilage, exécutez l'URL suivante.

http://yoursite.com/index.php/profiler/disable

L'ajout de fichiers JavaScript et CSS (feuille de style en cascade) dans CodeIgniter est très simple. Vous devez créer un dossier JS et CSS dans le répertoire racine et copier tous les fichiers .js dans le dossier JS et les fichiers .css dans le dossier CSS comme indiqué sur la figure.

Par exemple, supposons que vous ayez créé un fichier JavaScript sample.js et un fichier CSS style.css. Maintenant, pour ajouter ces fichiers dans vos vues, chargez l'assistant d'URL dans votre contrôleur comme indiqué ci-dessous.

$this->load->helper('url');

Après avoir chargé l'assistant d'URL dans le contrôleur, ajoutez simplement les lignes ci-dessous dans le fichier de vue, pour charger le fichier sample.js et style.css dans la vue comme indiqué ci-dessous.

<link rel = "stylesheet" type = "text/css" 
   href = "<?php echo base_url(); ?>css/style.css">

<script type = 'text/javascript' src = "<?php echo base_url(); 
   ?>js/sample.js"></script>

Exemple

Créez un contrôleur appelé Test.php et enregistrez-le dans application/controller/Test.php

<?php 
   class Test extends CI_Controller {
	
      public function index() { 
         $this->load->helper('url'); 
         $this->load->view('test'); 
      } 
   } 
?>

Créez un fichier de vue appelé test.php et enregistrez-le à application/views/test.php

<!DOCTYPE html> 
<html lang = "en">
 
   <head> 
      <meta charset = "utf-8"> 
      <title>CodeIgniter View Example</title> 
      <link rel = "stylesheet" type = "text/css" 
         href = "<?php echo base_url(); ?>css/style.css"> 
      <script type = 'text/javascript' src = "<?php echo base_url(); 
         ?>js/sample.js"></script> 
   </head>
	
   <body> 
      <a href = 'javascript:test()'>Click Here</a> to execute the javascript function. 
   </body>
	
</html>

Créez un fichier CSS appelé style.css et enregistrez-le à css/style.css

body { 
   background:#000; 
   color:#FFF; 
}

Créez un fichier JS appelé sample.js et enregistrez-le à js/sample.js

function test() { 
   alert('test'); 
}

Changer la routes.php déposer dans application/config/routes.php pour ajouter une route pour le contrôleur ci-dessus et ajouter la ligne suivante à la fin du fichier.

$route['profiler'] = "Profiler_controller"; 
$route['profiler/disable'] = "Profiler_controller/disable"

Utilisez l'URL suivante dans le navigateur pour exécuter l'exemple ci-dessus.

http://yoursite.com/index.php/test

La classe de langue de CodeIgniter fournit un moyen simple de prendre en charge plusieurs langues pour l'internationalisation. Dans une certaine mesure, nous pouvons utiliser des fichiers de langue différents pour afficher du texte dans de nombreuses langues différentes.

Nous pouvons mettre différents fichiers de langue dans le répertoire application / langue. Les fichiers de langue système se trouvent dans le répertoire système / langue, mais pour ajouter votre propre langue à votre application, vous devez créer un dossier distinct pour chaque langue dans le répertoire application / langue.

Création de fichiers Langue

Pour créer un fichier de langue, vous devez le terminer par _lang.php. Par exemple, vous souhaitez créer un fichier de langue pour la langue française, puis vous devez l'enregistrer avecfrench_lang.php. Dans ce fichier, vous pouvez stocker tous vos textes de langue en combinaison clé / valeur dans$lang tableau comme indiqué ci-dessous.

$lang[‘key’] = ‘val’;

Chargement du fichier de langue

Pour utiliser l'une des langues de votre application, vous devez d'abord charger le fichier de cette langue particulière pour récupérer divers textes stockés dans ce fichier. Vous pouvez utiliser le code suivant pour charger le fichier de langue.

$this->lang->load('filename', 'language');
  • filename- C'est le nom du fichier que vous souhaitez charger. N'utilisez pas l'extension du fichier ici mais uniquement le nom du fichier.

  • Language - C'est le jeu de langues qui le contient.

Récupération du texte de la langue

Pour récupérer une ligne dans le fichier de langue, exécutez simplement le code suivant.

$this->lang->line('language_key');

language_key est le paramètre clé utilisé pour récupérer la valeur de la clé dans le fichier de langue chargé.

Chargement automatique des langues

Si vous avez besoin d'une langue dans le monde, vous pouvez la charger automatiquement dans application/config/autoload.php fichier comme indiqué ci-dessous.

| -----------------------------------------------------------------------
|  Auto-load Language files
| -----------------------------------------------------------------------
| Prototype:
|   $autoload['config'] = array('config1', 'config2');
|
| NOTE: Do not include the "_lang" part of your file. For example
| "codeigniter_lang.php" would be referenced as array('codeigniter');
|
*/
$autoload['language'] = array();

Simplement, passez les différentes langues à charger automatiquement par CodeIgniter.

Exemple

Créez un contrôleur appelé Lang_controller.php et enregistrez-le dans application/controller/Lang_controller.php

<?php
   class Lang_controller extends CI_Controller {

      public function index(){
         //Load form helper
         $this->load->helper('form');

         //Get the selected language
         $language = $this->input->post('language');
		
         //Choose language file according to selected lanaguage
         if($language == "french") $this->lang->load('french_lang','french');
         else if($language == "german") $this->lang->load('german_lang','german');
         else
         $this->lang->load('english_lang','english'); //Fetch the message from language file. $data['msg'] = $this->lang->line('msg'); $data['language'] = $language; //Load the view file $this->load->view('lang_view',$data);
      }
   }
?>

Créez un fichier de vue appelé lang_view.php et enregistrez-le à application/views/ lang_view.php

<!DOCTYPE html>
<html lang = "en"> 

   <head>
      <meta charset = "utf-8">
      <title>CodeIgniter Internationalization Example</title>
   </head>
	
   <body>
      <?php
         echo form_open('/lang');
      ?>
		
      <select name = "language" onchange = "javascript:this.form.submit();">
         <?php
            $lang = array('english'=>"English",'french'=>"French",'german'=>"German");
				
            foreach($lang as $key=>$val) { if($key == $language) echo "<option value = '".$key."' selected>".$val."</option>"; else echo "<option value = '".$key."'>".$val."</option>"; } ?> </select> <br> <?php form_close(); echo $msg;
      ?>
		
   </body>
	
</html>

Créez trois dossiers appelés anglais, français et allemand en application/language comme indiqué dans la figure ci-dessous.

Copiez le code ci-dessous et enregistrez-le dans english_lang.php déposer dans application/language/english dossier.

<?php
   $lang['msg'] = "CodeIgniter Internationalization example.";
?>

Copiez le code ci-dessous et enregistrez-le dans french_lang.php déposer dans application/language/French dossier.

<?php
   $lang['msg'] = "Exemple CodeIgniter internationalisation.";
?>

Copiez le code ci-dessous et enregistrez-le dans german_lang.php déposer dans application/language/german dossier.

<?php
   $lang['msg'] = "CodeIgniter Internationalisierung Beispiel.";
?>

Changer la routes.php déposer dans application/config/routes.php pour ajouter une route pour le contrôleur ci-dessus et ajouter la ligne suivante à la fin du fichier.

$route['lang'] = "Lang_controller";

Exécutez l'URL suivante dans le navigateur pour exécuter l'exemple ci-dessus.

http://yoursite.com/index.php/lang

Il produira une sortie comme indiqué dans la capture d'écran suivante. Si vous changez la langue dans la liste déroulante, la langue de la phrase écrite sous la liste déroulante changera également en conséquence.

Prévention XSS

XSS signifie script intersite. CodeIgniter est livré avec la sécurité de filtrage XSS. Ce filtre empêchera tout code JavaScript malveillant ou tout autre code qui tente de détourner des cookies et d'effectuer des activités malveillantes. Pour filtrer les données via le filtre XSS, utilisez lexss_clean() méthode comme indiqué ci-dessous.

$data = $this->security->xss_clean($data);

Vous ne devez utiliser cette fonction que lorsque vous soumettez des données. Le deuxième paramètre booléen facultatif peut également être utilisé pour vérifier le fichier image pour l'attaque XSS. Ceci est utile pour la fonction de téléchargement de fichiers. Si sa valeur est true, cela signifie que l'image est sûre et pas autrement.

Prévention des injections SQL

L'injection SQL est une attaque effectuée sur une requête de base de données. En PHP, nous utilisonsmysql_real_escape_string() fonction pour éviter cela avec d'autres techniques, mais CodeIgniter fournit des fonctions et des bibliothèques intégrées pour éviter cela.

Nous pouvons empêcher l'injection SQL dans CodeIgniter des trois manières suivantes -

  • Échapper aux requêtes
  • Enchère de requête
  • Classe d'enregistrement actif

Échapper aux requêtes

<?php
   $username = $this->input->post('username'); $query = 'SELECT * FROM subscribers_tbl WHERE user_name = '.
      $this->db->escape($email);
   $this->db->query($query);
?>

$this->db->escape() La fonction ajoute automatiquement des guillemets simples autour des données et détermine le type de données afin qu'il ne puisse échapper qu'aux données de chaîne.

Enchère de requête

<?php
   $sql = "SELECT * FROM some_table WHERE id = ? AND status = ? AND author = ?";
   $this->db->query($sql, array(3, 'live', 'Rick'));
?>

Dans l'exemple ci-dessus, le point d'interrogation (?) Sera remplacé par le tableau dans le deuxième paramètre de la fonction query (). Le principal avantage de créer une requête de cette manière est que les valeurs sont automatiquement échappées, ce qui produit des requêtes sûres. Le moteur CodeIgniter le fait automatiquement pour vous, vous n'avez donc pas à vous en souvenir.

Classe d'enregistrement actif

<?php
   $this->db->get_where('subscribers_tbl',array
      ('status'=> active','email' => 'info@arjun.net.in'));
?>

À l'aide d'enregistrements actifs, la syntaxe de requête est générée par chaque adaptateur de base de données. Il permet également des requêtes plus sûres, car les valeurs s'échappent automatiquement.

Masquer les erreurs PHP

Dans l'environnement de production, nous ne souhaitons souvent pas afficher de message d'erreur aux utilisateurs. C'est bien s'il est activé dans l'environnement de développement à des fins de débogage. Ces messages d'erreur peuvent contenir des informations que nous ne devons pas montrer aux utilisateurs du site pour des raisons de sécurité.

Il existe trois fichiers CodeIgniter liés aux erreurs.

Niveau de rapport d'erreur PHP

Un environnement différent nécessite différents niveaux de rapport d'erreur. Par défaut, le développement affichera les erreurs, mais les tests et le live les masqueront. Il existe un fichier appeléindex.phpdans le répertoire racine de CodeIgniter, qui est utilisé à cet effet. Si nous passons zéro comme argument àerror_reporting() fonction alors qui cachera toutes les erreurs.

Erreur de la base de données

Même si vous avez désactivé les erreurs PHP, les erreurs MySQL sont toujours ouvertes. Vous pouvez désactiver cette option dansapplication/config/database.php. Met ledb_debug option dans $db tableau à FALSE comme indiqué ci-dessous.

$db['default']['db_debug'] = FALSE;

Journal des erreurs

Une autre méthode consiste à transférer les erreurs dans les fichiers journaux. Ainsi, il ne sera pas affiché aux utilisateurs sur le site. Réglez simplement lelog_threshold valeur en $config tableau à 1 po application/cofig/config.php fichier comme indiqué ci-dessous.

$config['log_threshold'] = 1;

Prévention CSRF

CSRF signifie falsification de demandes intersites. Vous pouvez empêcher cette attaque en l'activant dans leapplication/config/config.php fichier comme indiqué ci-dessous.

$config['csrf_protection'] = TRUE;

Lorsque vous créez un formulaire en utilisant form_open()fonction, il insérera automatiquement un CSRF comme champ caché. Vous pouvez également ajouter manuellement le CSRF à l'aide duget_csrf_token_name() et get_csrf_hash()fonction. leget_csrf_token_name() la fonction retournera le nom du CSRF et get_csrf_hash() renverra la valeur de hachage de CSRF.

Le jeton CSRF peut être régénéré à chaque fois pour la soumission ou vous pouvez également le conserver tout au long de la vie du cookie CSRF. En définissant la valeurTRUE, dans le tableau de configuration avec la clé ‘csrf_regenerate’ régénérera le jeton comme indiqué ci-dessous.

$config['csrf_regenerate'] = TRUE;

Vous pouvez également mettre en liste blanche les URL de la protection CSRF en le définissant dans le tableau de configuration à l'aide de la clé ‘csrf_exclude_uris’comme indiqué ci-dessous. Vous pouvez également utiliser une expression régulière.

$config['csrf_exclude_uris'] = array('api/person/add');

Gestion des mots de passe

De nombreux développeurs ne savent pas comment gérer les mots de passe dans les applications Web, ce qui explique probablement pourquoi de nombreux pirates informatiques trouvent si facile de s'introduire dans les systèmes. Il faut garder à l'esprit les points suivants lors de la gestion des mots de passe -

  • NE stockez PAS les mots de passe au format texte brut.

  • Hachez toujours vos mots de passe.

  • N'UTILISEZ PAS Base64 ou un encodage similaire pour stocker les mots de passe.

  • N'utilisez PAS d'algorithmes de hachage faibles ou cassés comme MD5 ou SHA1. N'utilisez que des algorithmes de hachage de mot de passe forts comme BCrypt, qui est utilisé dans les propres fonctions de hachage de mot de passe de PHP.

  • NE JAMAIS afficher ni envoyer de mot de passe au format texte brut.

  • NE mettez PAS de limites inutiles sur les mots de passe de vos utilisateurs.