Codeigniter 4馃敟 [16.- guardar formulario en nuestra base de datos]

En este tutorial vamos a color los datos de nuestro formulario en nuestra base de datos
Codigo en github.com: https://github.com/programadornovato/codeigniter4/commit/ffa39c7f4e3898849ba82477de14f568666f5f6b

//app/Controllers/Home.php
<?php namespace App\Controllers;

use CodeIgniter\Controller;
use App\Models\UserModel;

class Home extends BaseController
{
 public function __construct(){
  helper('form');
 }
 public function guarda(){
  $userModel=new UserModel($db);
  $request= \Config\Services::request();
  $data=array(
   'name'=>$request->getPostGet('name'),
   'email'=>$request->getPostGet('email'),
  );
  if($userModel->insert($data)===false){
   var_dump($userModel->errors());
  }
  $users=$userModel->findAll();
  $users=array('users'=>$users);
  $estructura=view('estructura/header').view('estructura/body',$users);
  return $estructura;

 }
 public function formulario(){
  $estructura=view('estructura/header').view('estructura/formulario');
  return $estructura;
 }
 public function index()
 {
  $userModel=new UserModel($db);
  //$users=$userModel->find([1,2]);
  //$users=$userModel->findAll();
  //$users=$userModel->where('name','maria')->findAll();
  //$users=$userModel->findAll(2,3);
  //$users=$userModel->withDeleted()->findAll();
  /*
  $data=[
   'name'=>"programador1",
   'email'=>"programador1@hotmail.com"
  ];
  $userModel->insert($data);
  
  $data=[
   'name'=>"programador2",
   'email'=>"programador2@hotmail.com"
  ];
  $userModel->update(10,$data);
  
  $data=[
   'name'=>"yo"
  ];
  $userModel->update([2,3],$data);
  
  $userModel->whereIn('id',[4,5,10])
  ->set(['name'=>'yo tambien'])
  ->update();
  
  $data=[
   'name'=>"programador11",
   'email'=>"programador11@hotmail.com"
  ];
  $userModel->save($data);
  
  $data=[
   'id'=>"12",
   'name'=>"programador yo tambien",
   'email'=>"programadorto@hotmail.com"
  ];
  $userModel->save($data);
  */  //$userModel->delete([2,4,5]);
  //$userModel->where('id',10)->delete();
  //$userModel->purgeDeleted();
  /*
  $data=[
   'name'=>"programadorvalido nuevo 2",
   'email'=>"programadornuevo2@hotmail.com"
  ];
  if($userModel->save($data)===false){
   var_dump($userModel->errors());
  }
  */  /*
  $users=$userModel->asArray()->where('name','programador11')
  ->orderBy('id','asc')
  ->findAll();
  var_dump($users);
  */  $users=$userModel->findAll();
  
  $users=array('users'=>$users);
  $estructura=view('estructura/header').view('estructura/body',$users);
  return $estructura;
  
 }

 //--------------------------------------------------------------------

}







//app/Models/UserModel.php
<?php namespace App\Models;

use CodeIgniter\Model;

class UserModel extends Model
{
        protected $table      = 'users';
        protected $primaryKey = 'id';

        protected $returnType = 'array';
        protected $useSoftDeletes = true;

        protected $allowedFields = ['name', 'email'];

        protected $useTimestamps = false;
        protected $createdField  = 'created_at';
        protected $updatedField  = 'updated_at';

        protected $validationRules    = [
                'name' => 'required|alpha_numeric_space|min_length[3]',
                'email' =>'required|valid_email|is_unique[users.email]'
        ];
        protected $validationMessages = [
                'email' =>[
                        'is_unique'=>'Lo sentimos. Tu correo ya esta siendo usado por otro usuario'
                ]
        ];
        protected $skipValidation     = false;
        //protected $beforeInsert=['agregaAlgoName'];
        //protected $beforeUpdate=['agregaAlgoName'];
        protected function agregaAlgoName(array $data){
                $data['data']['name']=$data['data']['name']." algo";
                return $data;
        }
}






//app/Views/estructura/formulario.php 
<?php
echo form_open('/home/guarda');
echo form_label('Nombre','name');
echo form_input(array('name'=>'name','placeholder'=>'Nombre'));
echo "<br>";
echo form_label('Email','email');
echo form_input(array('name'=>'email','placeholder'=>'Email'));
echo "<br>";
echo form_submit('guarda','Guardar');

echo form_close();
?>


Guia oficial codeigniter 4: https://codeigniter4.github.io/userguide/models/model.html

Codeigniter 4? [16.- guardar formulario en nuestra base de datos]

Codigo en github.com: https://github.com/programadornovato/codeigniter4/commit/806620237c14a60ccb039eed10ebbbc13a22b749 #Codeigniter4 #php7 #backend #Codeigniter #php .
? Esta lista de reproducci贸n: https://www.youtube.com/playlist?list=PLCTD_CpMeEKTFN5TDeOP-wP_hU0_9VoWg
.
Codigos en gdrive: https://drive.google.com/file/d/1awbG6jI40IO0N68fgjLUwNFpsTC3wIHj/view?usp=sharing .
Gracias por apoyar este canal: https://www.patreon.com/programadornovato?fan_landing=true .
? Facebook: https://facebook.com/ProgramadorNovatoOficial
? Twitter: https://twitter.com/programadornova
? Linkedin: https://www.linkedin.com/in/programadornovato/
? Instagram: https://www.instagram.com/programadornovato/

Eugenio Chaparro

Entradas recientes

馃煝Editar c贸digo de un m贸dulo en Dolibarr [04]

馃煝Editar c贸digo de un m贸dulo en Dolibarr [04]

En este tutorial vamos editar el c贸digo de nuestro m贸dulo personas para poder personalizar algunas…

2 semanas hace
馃煝Crear un sub_m贸dulo en Dolibarr [03]

馃煝Crear un sub_m贸dulo en Dolibarr [03]

En este tutorial vamos a crear un sub m贸dulo llamado seguridad que ser谩 muy parecido…

2 semanas hace
馃煝Modificar un m贸dulo en Dolibarr [02]

馃煝Modificar un m贸dulo en Dolibarr [02]

En este tutorial aprenderemos a editar el objeto personas del modulo persona que creamos en…

2 semanas hace
馃煝Constructor de m贸dulos en Dolibarr

馃煝Constructor de m贸dulos en Dolibarr

Como mencionamos anteriormente Dolibarr es un proyecto realizado sobre la base de una pol铆tica clara:…

2 semanas hace
馃煝Tickets en Dolibarr [19]

馃煝Tickets en Dolibarr [19]

Los ticket en dolibarr nos ayudan a comunicar inconveniente en nuestros productos y servicios dentro…

2 semanas hace
馃煝Agenda en Dolibarr [18]

馃煝Agenda en Dolibarr [18]

Las agendas en dolibarr nos ayudan a ver las actividades realizadas en proceso y por…

2 semanas hace