CodeIgniter - Concepts de base

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 «hello».

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

Il peut s'agir d'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 en tant que 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 avoir 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 des 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é comme -

$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 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 dans lequel vous pouvez personnaliser vos règles de routage. La clé dans le tableau $ route 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 chiffres.

  • (: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.