CodeIgniter学习笔记一:基本结构、控制器、视图、超级对象、数据库

Stella981
• 阅读 679

一、基本结构

CodeIgniter3.0.0解压后有8个文件,分别是:

  • application:项目文件
  • system:系统(框架)文件,为方便升级,不建议修改
  • user_guid:用户手册,不需要加入项目
  • composer.json:composer配置文件,不需要加入项目
  • contributing.md:如何参与项目贡献代码,不需要加入项目
  • index.php:项目入口文件
  • license.txt:许可文件,不需要加入项目
  • readme.rst:说明文件,不需要加入项目

二、控制器Controller

控制器在application文件夹中的controllers文件夹中,默认控制器为welcome,有4小点需要注意:

1、控制器类名不需要加后缀

2、控制器文件名建议小写

3、控制器要直接或间接继承自CI_Controller类

4、可访问的action方法名不能以下划线开头,且访问权限要是public的

三、视图View

视图在application文件夹中的views文件夹中,几个tips:

1、在控制器中用如下代码加载views中的视图:

//加载views文件夹中的user_index.php视图文件
$this -> load -> view('user_index');

//加载views/user文件夹中的index.php视图文件
$this -> load -> view('user/index');

2、在视图中,可以直接使用原生的php代码

3、在控制器中可以通过以下方式向视图中输出变量:

<?php
    class User extends CI_Controller {
        public function index() {
            $data = array(
                'username' => 'jim',
                'books' => array(
                    'a', 'b', 'c', 'd'
                )
            );

            $head = array(
                'title' => 'TITLE',
                'subtitle' => 'SUB TITLE'
            );

            $this -> load -> vars('data', $data);
            //公共部分
            $this -> load -> view('header');
            $this -> load -> view('user/index', $head);
        }
    }
?>

在视图中用如下方式获取变量:

<!DOCTYPE html>
<html>
<head>
    <title>User</title>
</head>
<body>
    <h1>User</h1>
    <?php var_dump($data); ?>
    <?php var_dump($title); ?>
</body>
</html>

四、CI的超级对象

CI中的超级对象即为当前的控制器对象。在视图中也可以直接使用$this访问超级对象。

超级对象提供了很多属性:

1、$this -> load ,装载器,主要提供了如下方法:

  • view:装载视图
  • vars:分配变量到视图
  • database:装载数据库操作对象
  • model:装载模型
  • helper:加载帮助文件

2、$this -> uri,解析URL相关内容,主要提供如下方法:

  segment:按索引(控制器为1)获取分段url值(类pathinfo没有key的模式:入口.php/控制器/动作/参数1/参数2。。。),示例如下

  •   <?php
          class User extends CI_Controller {
        
              ///index.php/user/index/id/abc/name/god
              public function index($param1, $param2) {
                  $param3 = $this -> uri -> segment(5);
                  var_dump(array(
                      'param1' => $param1,
                      'param2' => $param2,
                      'param3' => $param3
                  ));
                  /*
                  array (size=3)
                    'param1' => string 'id' (length=2)
                    'param2' => string 'abc' (length=3)
                    'param3' => string 'name' (length=4)
                  */
                  $this -> load -> view('user/index');
              }
          }
      ?>
    

3、$this -> input,主要用于取post和server数据,使用方法如下:

<?php
    class User extends CI_Controller {
        public function index() {
            $username = $this -> input -> post('username');
            $ip = $this -> input -> server('REMOTE_ADDR');
            echo $ip;//127.0.0.1
            $this -> load -> view('user/index');
        }
    }
?>

五、数据库操作

数据配置文件在 application/config/database.php 中。

1、查询示例

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

        public function showusers() {
            $this -> load -> database();
            $sql = 'select * from ci_test';
            $res = $this -> db -> query($sql);
            $users = $res -> result();
            var_dump($users);
            /*
            array (size=1)
              0 =>
                object(stdClass)[18]
                  public 'id' => string '1' (length=1)
                  public 'name' => string 'jim' (length=5)
                  public 'title' => string 'ci learn' (length=8)
            */

            $users2 = $res -> result_array();
            /*
            array (size=1)
              0 =>
                array (size=3)
                  'id' => string '1' (length=1)
                  'name' => string 'atwal' (length=5)
                  'title' => string 'ci learn' (length=8)
            */
            var_dump($users2);

            $firstUser = $res -> row();
            var_dump($firstUser);
            /*
            object(stdClass)[18]
              public 'id' => string '1' (length=1)
              public 'name' => string 'atwal' (length=5)
              public 'title' => string 'ci learn' (length=8)
            */
            $this -> load -> view('user/show');
        }
    }
?>

要先调用 $this -> load -> database()进行装载数据库,然后才能使用 $this -> db 对象。

2、插入示例

public function add() {
  $this -> load -> database();
  $sql = "insert into swap_test(name,title) values ('jim', 'jim learn ci')";
  $bool = $this -> db -> query($sql);
  if ($bool) {
    //受影响行数
    echo $this -> db -> affected_rows();

    //自增id
    echo $this -> db -> insert_id();
  }
}

3、参数绑定示例

为了安全,阻止SQL注入,建议用参数绑定的形式操作数据库。

public function addsafe() {
  //配置自动加载db
  //application\config\autoload.php
  //$autoload['libraries'] = array('database');
  //$this -> load -> database();

  $data[0] = 'lili';
  $data[1] = 'lili';
  $sql = "insert into swap_test(name,title) values (?,?)";
  $bool = $this -> db -> query($sql, $data);
  if ($bool) {
    //受影响行数
    echo $this -> db -> affected_rows();

    //自增id
    echo $this -> db -> insert_id();
  }
}

4、表前缀

为了应对数据库表前缀变化,CI数据库配置(application\config\database.php)中有下面两项:

$db['default'] = array(
    'dbprefix' => 'ci_',
    'swap_pre' => 'swap_',
);

swap_pre的作用是,在代码中用swap_pre来替换dbprefix,可以达到换数据库表前缀不改代码的目地(即在代码中表前缀用swap_pre值就好)。

5、自动加载db对象

在每次数据库操作前都要加载database才可以使用db对象,显得比较麻烦,可以用CI中的自动加载能力简化这一步:

//配置自动加载db
//application\config\autoload.php
//$autoload['libraries'] = array('database');

配置完后,就可以直接使用$this -> db 对象了。

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
3个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
3年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Stella981 Stella981
3年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
为什么mysql不推荐使用雪花ID作为主键
作者:毛辰飞背景在mysql中设计表的时候,mysql官方推荐不要使用uuid或者不连续不重复的雪花id(long形且唯一),而是推荐连续自增的主键id,官方的推荐是auto_increment,那么为什么不建议采用uuid,使用uuid究
Python进阶者 Python进阶者
9个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这