CI 笔记一
CodeIgniter
说明
CodeIgniter 是为PHP 开发人员提供的一套Web 应用程序工具包。它的目标是能
够让你比从零开始更加快速的完成项目,它提供了一套丰富的的类库来满足我们日常
的任务需求,并且提供了一个简单的接口和逻辑结构来调用这些库
安装
- 解压缩安装包
- 将CodeIgniter 文件夹及里面的文件上传到服务器,通常index.php 文件将位于
网站的根目录; - 使用文本编辑器打开application/config/config.php 文件设置你网站的根URL,
如果你想使用加密或会话,在这里设置上你的加密密钥; - 如果你打算使用数据库,打开application/config/database.php 文件设置数据库
参数。 - 主目录下index.php的$system_path,$application_folder,$view_folder分别表示系统路径,
应用路劲及视图路径,默认为system,application及application/views
流程
- index.php 文件作为前端控制器,初始化运行CodeIgniter 所需的基本资源;
- Router 检查HTTP 请求,以确定如何处理该请求;
- 如果存在缓存文件,将直接输出到浏览器,不用走下面正常的系统流程;
- 在加载应用程序控制器之前,对HTTP 请求以及任何用户提交的数据进行安全
检查; - 控制器加载模型、核心类库、辅助函数以及其他所有处理请求所需的资源;
- 最后一步,渲染视图并发送至浏览器,如果开启了缓存,视图被会先缓存起来用
于后续的请求。
MVC
示例 访问如下路由
http://example.com/Home/Index
Control
在 application/controllers 下创建一个文件Home.php,代码如下:
<?php
defined('BASEPATH') OR exit('No direct script access allowed');
//类名称必须大写
class Home extends CI_Controller {
public function index()
{
$this->load->view('index.php');
}
}
?>
VIEW
在 application/views 下创建一个文件index.php,代码如下:
<!DOCTYPE html>
<html>
<head>
<title>demo</title>
</head>
<body>
<p>demo</p>
</body>
</html>
MODEL
通过视图加载方法的第二个参数可以从控制器中动态的向视图传入数据,这个参数
可以是一个数组或者一个对象,利用$data传递"hello world"字符串到视图中,修改代码如下
controler:
<?php
defined('BASEPATH') OR exit('No direct script access allowed');
class Home extends CI_Controller {
public function index()
{
$data['str'] = 'hello world';
$this->load->view('index.php',$data);
}
}
?>
view:
<!DOCTYPE html>
<html>
<head>
<title>demo</title>
</head>
<body>
<p><?php echo $str;?></</p>
</body>
</html>
路由
基本路由格式
http://example.com/[controller-class]/[controller-method]/[arguments]
1. 第一段表示要调用的控制器类;
2. 第二段表示要调用的类中的函数或方法;
3. 第三段以及后面的段代表传给控制器的参数,如ID 或其他任何变量;
修改路由配置文件(application/config/routes.php),可以创建新的路由规则,例如
$route['news/(:any)'] = 'news/view/$1';
$route['news'] = 'news';
$route['(:any)'] = 'pages/view/$1';
$route['default_controller'] = 'pages/view';
CI 笔记一的更多相关文章
- CI 笔记,借鉴的4个辅助自定义函数
在System的core的common.php中,借鉴的4个自定义函数, 摘自后盾网的CI教程 /** * 格式化打印函数 * @param [type] $arr [数组] * @return [t ...
- CI笔记6 json 传值
CI3.x 使用json,配合easyui, 其实很简单,走了很多的弯路, 首先在ci的控制器重,建立2个方法,一个用于显示加载view,一个用于echo json,就可以了. 需要注意的是,在ci的 ...
- CI 笔记,使用 json的参考文档(废弃)
Json的处理转换, Json转换步骤, a) 先设置json为空字符串, b) While循环,遍历, While(!!$row = mysql_fetch_arra ...
- 第一天的CI笔记
1 CI不区分大小写2. http://xxx.com/index/[控制器名称]/[控制器里面方法的确名称]/[传入方法的参数 ]/ 3. 控制器及控制器类名称与文件名称一致, 继承 CI_Cont ...
- CI 笔记5 (CI3.0 默认控制器,多目录)
在ci3.x中,不支持多级子目录的默认控制器设置, 解决方法如下: 在index.php中,添加 $routing['directory'] = 'admin';然后在默认的router.php的默 ...
- CI 笔记2,(命令规范等)
调试模式开启,$this->output->enable_profiler(TRUE); 保留字,不能和控制器重名,有3个,CI_Controller ,Default, index.这三 ...
- CI 笔记(1)
1. 下载CI,官方网站,目前3.x版本已经更新,2.2.6版本为2.x版本的最后的一个版本.为了和视频教材一致,使用CI 2.x版本 2. 目录结构,从application里面的,controll ...
- ci 笔记
一.CI的HelloWorld! 注意:CI禁止直接通过文件目录来访问控制器. ./application/controllers/hello.php 1 <?php 2 //放止用户直接通过路 ...
- 常用的CI笔记
1. thinkphp 封装好的$this->success(),就直接实现成功跳转,$this->error(),错误跳转.CI有show_error(),但是却不能直接实现跳转,所以需 ...
随机推荐
- 基于Batcher比较器的双调排序网络
1. Batcher比较器 Batcher比较器是指如果在两个输入端给定输入x,y,再在两个输出端输出最大值max{x,y}和最小值min{x,y}.如图1所示,我们规定Batcher比较器的上输出端 ...
- js和jquery如何获取图片真实的宽度和高度
按照插入的图片的尺寸来判断图片是横图还是竖图.然后判断过后给予不同的展示方式,下面为大家介绍下js和jquery如何获取图片真实的宽度和高度 1.什么时候需要获取图片真实的宽度和高度 在做pc网页 ...
- animate支持的css属性
支持下列CSS 样式 * backgroundPosition * borderWidth * borderBottomWidth * borderLeftWidth * borderRightWid ...
- .Net JIT
.Net JIT(转) JIT
- Learning to rank 特征抽取
http://blog.csdn.net/puqutogether/article/details/42124491 http://www.microsoft.com/en-us/research/p ...
- SQL联合查询(内联、左联、右联、全联)的语法(转)
最近在做一个比较复杂的业务,涉及的表较多,于是在网上找了一些sql联合查询的例子进行研究使用. 概述: 联合查询效率较高,举例子来说明联合查询:内联inner join .左联left outer j ...
- VMware安装Centos7,已将该虚拟机配置为使用64为,却无法执行64位操作
在新建虚拟机之后,相信很多人都遇到了这个问题,这个问题的本质就是电脑是否支持虚拟化,虽然不是很清楚这是什么 解决方案就是,重启电脑(这边的电脑不是虚拟机而是主机),进入BIOS界面(不同电脑进入BIO ...
- jquery 实现类似于弹幕效果
在别人网站中看到一个类似于弹幕的效果,闲来无事用jquery写了个备用~~ <!DOCTYPE html> <meta charset="utf-8"> & ...
- android开发之线程
线程(android) 在java中我们学习了线程,线程,是进程的一个单位,在程序要运行时,会开启线程,运行程序,我们要创建线程就需要我们去继承接口Thread或者实现Runabl ...
- js获取Html元素的实际宽度高度
第一种情况就是宽高都写在样式表里,就比如#div1{width:120px;}.这中情况通过#div1.style.width拿不到宽度,而通过#div1.offsetWidth才可以获取到宽度. 第 ...