Recherche…


Introduction

CodeIgniter fournit une classe de sortie auto-initialisée très utile pour créer des API et différents types de documents tels que .pdf, .csv, .image, etc.

REMARQUE: - Le type de document par défaut de Codeigniter est que HTML le transforme en application / json, l’API doit être de type json requis

créer le nouveau contrôleur avec le nom API

<?php

defined('BASEPATH') OR exit('No direct script access allowed');

class Api extends CI_Controller {
  //default value
  private $login_credential;

  function __construct() {
    parent::__construct();
    //for user authentication
    $this->load->library('session');

    //set page header type Json as default
    $this->output->set_content_type('application/json');
    //default credentials for user login
    $this->login_credential = array(
        'username'=>'admin',
        'password'=>'test@123',
        'email'=> '[email protected]'
      );
  }
}
?>

Récupérer des données de l'API Ajouter la fonction suivante dans le contrôleur API

/*****************************
@return all events
****************************/
public function getallevents(){
  //get data from model
  $events = array(
    array('Event 1', '2015-04-03'),
    array('Event 2', '2015-04-03'),
    array('Event 3', '2015-06-16'),
    array('Event 4', '2015-06-29'),
    array('Event 5', '2015-07-04'),
    array('Event 6', '2015-12-25'),
    array('Event 7', '2016-01-01')
  );
  $this->output->set_output(json_encode(array('status'=>true,'events'=>$events)));
}

Vue du facteur entrer la description de l'image ici

se connecter à l'API utilisateur pour permettre l'accès à certaines données privées pour un utilisateur particulier

/*****************************
login user
@required : username and password via post method only
@return user data if login successfull otherwise error message
****************************/
public function login(){
  $username=$this->input->post('username');
  $password=$this->input->post('password');
  if($username && $password){
    //check username and password
    if($this->login_credential['username']==$username && $this->login_credential['password']==$password){
      //set user data to store in session
      $userdata = array(
        'username'  => $this->login_credential['username'],
        'email'     => $this->login_credential['email'],
        'logged_in' => true
      );
      //set session
      $this->session->set_userdata($userdata);
      //display log in successfull msg
      $this->output->set_output(json_encode(array('status'=>true,'msg'=>'log in successfully','data'=>$userdata))); 
    }else{
      //wrong username or password
      $this->output->set_output(json_encode(array('status'=>false,'msg'=>'invalid Username or password'))); 
    }
  }else{
    //when username and password not set
    $this->output->set_output(json_encode(array('status'=>false,'msg'=>'provide Username and password')));
  }
}

entrer la description de l'image ici

l'utilisateur déconnecte api pour détruire la session de l'utilisateur connecté

/***************************
log out user
***************************/
public function logout(){
  //delete all session
  session_destroy();
  $this->output->set_output(json_encode(array('status'=>true,'msg'=>'log Out successfully')));
}

entrer la description de l'image ici

créer des api protégés

Cette API n'est pas accessible à l'utilisateur public, l'authentification est requise

/***************************
this is protected api this is not accessible if you are not loged in
***************************/
public function protectedapi(){
  if($this->session->userdata('logged_in')){
    //this section only accessible when user loged in
    $this->output->set_output(json_encode(array('status'=>true,'msg'=>'Access allowed')));
  }else{
    $this->output->set_output(json_encode(array('status'=>true,'msg'=>'Access denied')));
  }
}

entrer la description de l'image ici



Modified text is an extract of the original Stack Overflow Documentation
Sous licence CC BY-SA 3.0
Non affilié à Stack Overflow