ci下载的开发包:
 
 
phpstudy的部署:
phpstudy的根目录是:D:\WWW
新建目录 cms 
把ci开发包的application   system index.php  license.txt copy到cms目录下面;
运行phpstudy,php版本选择5.4以上,因为在readme.rst中阅读到,php的版本最好是在5.4以及以上最佳;
 
*******************
Server Requirements
*******************

PHP version 5.4 or newer is recommended.

It should work on 5.2.4 as well, but we strongly advise you NOT to run
such old versions of PHP, because of potential security and performance
issues, as well as missing features.

 
打开phpstudy首页,
 
然后进入选择cms这个项目
看说明,这个页面是在显示的 application/view/welcome_message.php这个页面的内容,然后是被控制器 application/controllers/Welcome.php控制的;
为了验证,我修改一下welcome_message.php,加上一个图片,改变一些文字;
 
先看效果:
 
注意的地方:
页面渲染耗时{elapsed_time}秒 CI版本 <?php echo CI_VERSION ?>  环境 <?php echo ENVIRONMENT ?>
 
变量意义 变量名称
渲染时间 {elapsed_time}
ci的版本 CI_VERSION
环境名称 ENVIRONMENT
 
controller/welcome.php
$this ->load-> view('welcome_message' );
 
加载视图,视图名称是welcome_message,视图的位置是application/view目录下
 
控制器:代理完成某项任务的php类,充当MVC架构程序的粘合剂;
url:http://example.com/[控制器类名]/[控制器方法名]/[所需参数]
 
新建一个控制器
 
namespace:
kind:
file extension:
 
namespace any8 ;

class Pages extends CI_Controller{

public function view ($page = 'home'){ 
    
    }

}

 
CI_Controller这个类对应于system/core/Controller.php,又叫超级对象,可以使用$this来调用它的变量,方法,一些其它的操作;
 
public function view ( $page = 'home' ){

if ( ! file_exists( APPPATH. 'views/pages/' .$page . '.php')) 
    {
        // 页面不存在 
        show_404 () ;
    }

$data [ 'title'] = ucfirst( $page ); // 将title中的第一个字符大写

$this -> load-> view ('templates/head' , $data) ;
    $this -> load-> view ('pages/' . $page, $data ); 
    $this -> load-> view ('templates/foot' , $data) ;

}

 
 
注意的地方:   
file_exists()  查看文件是否存在   APPPATH 应用的路径,对应application目录
ucfirst() 把第一个字母变为大写
view(视图文件位置,视图所需数据)
 
 
这段代码位于  application/config/routes.php   
默认的控制器是welcome 默认的方法是index  
所以浏览器里访问  localhost/cms/访问的是Welcome.php 对应的welcome_message.php的视图
 
 
数据库的配置: application/config/database.php 
 
  • hostname - 数据库的主机名,通常位于本机,可以表示为 "localhost".
  • username - 需要连接到数据库的用户名.
  • password - 登陆数据库的密码.
  • database - 你需要连接的数据库名.
  • dbdriver - 数据库类型。如:mysql、postgres、odbc 等。必须为小写字母。
  • dbprefix - 当运行Active Record查询时数据表的前缀,它允许在一个数据库上安装多个CodeIgniter程序.
  • pconnect - TRUE/FALSE (boolean) - 使用持续连接.
  • db_debug - TRUE/FALSE (boolean) - 显示数据库错误信息.
  • cache_on - TRUE/FALSE (boolean) - 数据库查询缓存是否开启,详情请见数据库缓存类
  • cachedir - 数据库查询缓存目录所在的服务器绝对路径。
  • char_set - 与数据库通信时所使用的字符集。
  • dbcollat - 与数据库通信时所使用的字符规则。

    提示: 就MYSQL或MYSQLi数据库而言,如果服务器运行环境PHP版本小于5.2.3、MYSQL版本小于5.0.7,那么该项设置仅被用来备份(由数据库维护类DB Forge所创建查询)。如果使用多字节字符集并且使用低版本PHP环境中不兼容的mysql_real_escape_string()函数,它将使网站更容易受到SQL注入的危险。

  • swap_pre - 替换默认的dbprefix表前缀,该项设置对于分布式应用是非常有用的,你可以在查询中使用由最终用户定制的表前缀。
  • autoinit - 当数据库类库(database library)被载入的时候是否需要自动连接数据库,如果设置为FALSE,将在首次查询前进行连接。
  • stricton - TRUE/FALSE (boolean) - 是否强制使用 "Strict Mode" 连接, 在开发程序时,使用 strict SQL 是一个好习惯。
  • port - 数据库端口号. 要使用这个值,你应该添加一行代码到数据库配置数组。$db['default']['port'] = 5432;
 
显示的关闭数据库链接  $this->db->close();
重新链接/保持有效连接  $this->db->reconnect();
链接多数据库:
$DB1 = $this->load->database('group_one', TRUE);
$DB2 = $this->load->database('group_two', TRUE);
手动链接数据库:
$this->load->database();

可用的参数

  1. 数据库连接值,用数组或DSN字符串传递。
  2. 是否返回连接ID,TRUE/FALSE (boolean),默认值为FALSE (参阅下面的“连接多数据库”)。
  3. 是否启用 Active Record 类,TRUE/FALSE (boolean),默认值为 NULL。如有疑问,请查看/system/core/Loader.php的database()方法
自动链接:

“自动连接” 功能将在每一个页面加载时被自动实例化数据库类。要启用“自动连接”,可在application/config/autoload.php中的 library 数组里添加 database

$autoload['libraries'] = array('database');

 
模型:模型是专门用来和数据库打交道的PHP类

最基本的模型类必须像这样:

class Model_name extends CI_Model {

function __construct()
    {
        parent::__construct();
    }
}

Model_name 是模型类的名字。 类名的首字母必须大写,其他字母小写。 并且确保你的类继承了基本模型类(Base Model Class)。

文件名应该是模型类名的小写版。
 
写了一个例子:
class Account extends CI_Controller{

public function index (){

$this -> load-> model ('user_model' ) ;
//        $this->load->model('user_model','user_model');//加载模型

$accountList = $this-> user_model ->user_list () ;//调用模型方法

$data [ 'user_list'] = $accountList ;//设置视图数据

$this -> load-> view ('user/user_list' , $data) ; //引导到视图
    }

}

class User_model extends CI_Model
{

function __construct ()
    {
        $this -> load-> database (); 
    }

public  function  user_list ()
     {
          $query =  $this-> db ->query ( "SELECT * FROM dt_account limit 0,30" ); 
          $accountArray = $query-> result (); 
         return $accountArray ;
     }
}

用户列表

<table>
    <tr><td>用户id </td><td> 用户名</td><td> 密码 </td></tr>
    <?php
    foreach
( $user_list as $user )
    {
        echo '<tr><td>' . $user-> id .'</td>' ;
        echo '<td>'. $user ->userName . '</td><td>'. $user ->passWord . '</td>'; 
        echo '</tr>'; 
    }

?>
</table>

php:ci学习笔记1的更多相关文章

  1. PHP与CI学习笔记

    CodeIgniter框架学习 安装 下载好包后,解压复制 system 和 application 目录到网站目录下 配置 配置目录 打开index.php设置好 $system_path . $a ...

  2. CI 学习笔记、记录

    [ci框架]ci框架目录结构分析 分类: [CodeIgniter深入研究]2013-05-09 00:24 7420人阅读 评论(5) 收藏 举报 [php] view plaincopy mysh ...

  3. 0025 Java学习笔记-面向对象-final修饰符、不可变类

    final关键字可以用于何处 修饰类:该类不可被继承 修饰变量:该变量一经初始化就不能被重新赋值,即使该值跟初始化的值相同或者指向同一个对象,也不可以 类变量: 实例变量: 形参: 注意可以修饰形参 ...

  4. BZOJ 1061: [Noi2008]志愿者招募 [单纯形法]【学习笔记】

    1061: [Noi2008]志愿者招募 Time Limit: 20 Sec  Memory Limit: 162 MBSubmit: 3975  Solved: 2421[Submit][Stat ...

  5. 毕业设计 之 二 PHP学习笔记(一)

    毕业设计 之 二 PHP学习笔记(一) 作者:20135216 平台:windows10 软件:XAMPP,DreamWeaver 一.环境搭建 1.XAMPP下载安装 XAMPP是PHP.MySQL ...

  6. Android学习笔记(三)——初探Intent

    //此系列博文是<第一行Android代码>的学习笔记,如有错漏,欢迎指正! Intent 是 Android 程序中各组件之间进行交互的一种重要方式,它不仅可以指明当前组件想要执行的动作 ...

  7. C++Primer第5版学习笔记(一)

    C++Primer第5版学习笔记(一) 第一.二章的重难点内容        这个笔记本主要记录了我在学习C++Primer(第5版,中文版)的过程中遇到的重难点及其分析.因为第一.二章都比较简单,因 ...

  8. C++学习笔记——大杂烩

    C++学习笔记--大杂烩                                                         by方阳 版权声明:本文为博主原创文章,转载请指明转载地址 h ...

  9. python数据分析入门学习笔记

    学习利用python进行数据分析的笔记&下星期二内部交流会要讲的内容,一并分享给大家.博主粗心大意,有什么不对的地方欢迎指正~还有许多尚待完善的地方,待我一边学习一边完善~ 前言:各种和数据分 ...

随机推荐

  1. 玩转spring boot——结合AngularJs和JDBC

    参考官方例子:http://spring.io/guides/gs/relational-data-access/ 一.项目准备 在建立mysql数据库后新建表“t_order” ; -- ----- ...

  2. 原生js+css3实现图片自动切换,图片轮播

    运用CSS3transition及opacity属性 制作图片轮播动画 自己这两天根据用js来控制触发CSS3中transition属性,从而写出来的以CSS3动画为基础,js控制过程的图片轮播 运用 ...

  3. RIFF和WAVE音频文件格式

    RIFF file format RIFF全称为资源互换文件格式(Resources Interchange File Format),是Windows下大部分多媒体文件遵循的一种文件结构.RIFF文 ...

  4. [原] KVM 虚拟化原理探究(6)— 块设备IO虚拟化

    KVM 虚拟化原理探究(6)- 块设备IO虚拟化 标签(空格分隔): KVM [toc] 块设备IO虚拟化简介 上一篇文章讲到了网络IO虚拟化,作为另外一个重要的虚拟化资源,块设备IO的虚拟化也是同样 ...

  5. java8中lambda表达式的应用,以及一些泛型相关

    语法部分就不写了,我们直接抛出一个实际问题,看看java8的这些新特性究竟能给我们带来哪些便利 顺带用到一些泛型编程,一切都是为了简化代码 场景: 一个数据类,用于记录职工信息 public clas ...

  6. 总结30个CSS3选择器

    或许大家平时总是在用的选择器都是:#id  .class  以及标签选择器.可是这些还远远不够,为了在开发中更加得心应手,本文总结了30个CSS3选择器,希望对大家有所帮助. 1 *:通用选择器 ;; ...

  7. SharePoint 2013: A feature with ID has already been installed in this farm

    使用Visual Studio 2013创建一个可视web 部件,当右击项目选择"部署"时报错: "Error occurred in deployment step ' ...

  8. 【干货分享】流程DEMO-请休假

    流程名: 请假申请  流程相关文件: 流程包.xml WebService业务服务.xml WebService.asmx WebService.cs  流程说明: 流程中集成了webservice服 ...

  9. 超千个节点OpenStack私有云案例(1):CERN 5000+ 计算节点私有云

    CERN:欧洲核子研究组织 本文根据以下几篇文章整理而来: https://www.openstack.org/summit/tokyo-2015/videos/presentation/unveil ...

  10. 我的MYSQL学习心得(九) 索引

    我的MYSQL学习心得(九) 索引 我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得(四) 数据类 ...