Heim  >  Artikel  >  Backend-Entwicklung  >  Analyse häufig verwendeter Operationsklassen im CI-Framework

Analyse häufig verwendeter Operationsklassen im CI-Framework

不言
不言Original
2018-06-14 14:37:151362Durchsuche

这篇文章主要介绍了CI框架常用经典操作类,结合实例形式总结分析了CI框架URL、路由、伪静态、分页、session、验证码等相关操作类与使用技巧,需要的朋友可以参考下

本文实例总结了CI框架常用经典操作类。分享给大家供大家参考,具体如下:

1. 超级对象中的URI

CI_URI类的解析url的相关信息

直接使用$this->uri可以使用它的相关属性

system/core/URI.php文件中

部分常用属性:

(1) 分段获取url相关信息

$this->uri->segment(4);
//获取url中pathinfo
//的第四段的值

入口文件.php/控制器/动作/参数1/参数2/...

(2) 通过方法中的形参传参

需要设默认值和顺序要注意

index.php/user/index/3/zhangsan

public function index($id=0,$name=''){
  echo $id,$name;
}

2.CI控制器的扩展

在application/core/文件夹下面

添加自己的扩展控制器

class MY_Controller extends CI_Controller{
  public function __construct(){
   parent::__construct
  }
}

配置模型前缀

$config['subclass_prefix']='MY_';//默认值

3.模型的相关操作

文件名全小写,类名首字母大写

建议类名加上 _model后缀

在控制器中加载模型:

在construct中加入:

$this->load->model('User_model');
$this->User_model->get();

为模型起别名

$this->load->model('User_model','user');
$this->user->get();

4.url中的常用函数

(1)帮助我们生成控制器

$this->load->helper('url');
site_url('控制器/方法');

(2)图片路径的使用

$this->load->helper('url');

<img src="<?php echo base_url();?>upload/a.jpg" />

可以在autoload.php中配置自动加载

$autoload['helper']加入url

5. CI中的路由与伪静态

(1) 路由伪静态

$router[&#39;show/([\d]+)\.html&#39;]=&#39;article/show/$1&#39;;
article/show/5.html => article/show/5;

(2) 隐藏入口文件

#开启apache的rewrite模块
#在根目录中放入.htaccess文件进行重写
RewriteEngine on
RewriteCond %{REQUEST_FILENAME} !-d
RewriteCond %{REQUEST_FILENAME} !-f
RewriteRule ^(.*)$ index.php/$1 [QSA,PT,L]

6. CI中的分页

//模型中操作
//装载分页类文件
$this->load->library(&#39;pagination&#39;);
$this->load->helper(url);
//分页链接
$config[&#39;base_url&#39;] = site_url(&#39;user/test&#39;);
//总记录条数
$config[&#39;total_rows&#39;] = 100;
//每页显示10条数据
$config[&#39;per_page&#39;] = 10;
//偏移量
$offset_limit = intval($this->uri->segment(3));
$this->pagination->initialize($config);
echo $this->pagination->create_links();

分页中按钮的定制(注意在初始化之前配置好)

$config[&#39;first_link&#39;] = &#39;首页&#39;;
...
$config[&#39;uri_segment&#39;] =3;//分页数据查询偏移量

在url的哪一段上,对应上面的$offset

默认是3,否则需要修改对应值

7. CI 中session的使用

//加载session库
$this->load->library(&#39;session&#39;);

(1)获取系统session

//比如获取客户端的ip地址
$this->session->userdata(&#39;ip_address&#39;);

(2) 添加自定义session

//添加
$this->session->set_userdata(&#39;some_name&#39;, &#39;some_value&#39;);
//获取
$this->session->userdata(&#39;some_name&#39;);
//删除
$this->session->unset_userdata(&#39;some_name&#39;);

(3)闪出数据 (取出一次后失效)

//添加
$this->session->set_flashdata(&#39;item&#39;, &#39;value&#39;);
//获取
$this->session->flashdata(&#39;item&#39;);

登录数据中 返回登录前的那一个页面的url可以记录下来,

注意:一次性的数据,读取一次后会自动销毁。

为了确保安全,在config.php生成随机加密的字符串中加入

$config[&#39;encryption_key&#39;]="fjkdsffjkhjd#kjh";

是否要将cookie加密

$config[&#39;sess_encrypt_cookie&#39;] =TRUE;

8. CI中的文件上传

<form action="<?php echo site_url(&#39;user/upload&#39;);?>" enctype="multipart/form-data">
 <input type="file" name="pic"/>
 <input type="submit" value="submit">
</form>

上传处理:

$config[&#39;upload_path&#39;]="./upload";
$config[&#39;allowed_types&#39;]=&#39;gif|jpeg|jpg&#39;;
$this->load->library(&#39;upload&#39;,$config);
$this->upload->do_upload(&#39;pic&#39;);

文件上传的数据

$filedata = $this->upload->data();

9. CI中的验证码

//生成验证码
$this->load->helper('captcha');
$this->load->helper(&#39;url&#39;);
$vals = array(
  'word'=>rand(1000,9999),
  'img_path'=>'./captcha/',
  'img_url'=>base_url().'/captcha/'
  'img_width'=>'150',
  'img_height'=>'100',
  'expiration'=>7200
);
$cap = create_captcha($vals);
echo $cap['image'];
//将验证码获取的数字放在session中
session_start();
$_SESSION['cap'] = $cap['word'];

以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

相关推荐:

关于CI框架无限级分类和递归的实现

如何使用CodeIgniter开发实现支付宝接口调用

如何使用CI框架实现文件上传的优化以及多文件上传

Das obige ist der detaillierte Inhalt vonAnalyse häufig verwendeter Operationsklassen im CI-Framework. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn