目錄
ci框架(二),ci框架
php CI 框架怎从数据库中取值(一个二维数组)以表格的形式显示到view层
php CI框架问题?小弟是初学者
首頁 php教程 php手册 ci框架(二),ci框架

ci框架(二),ci框架

Jun 13, 2016 am 09:29 AM
二維數組

ci框架(二),ci框架

自定义SQL语句                                                                            

当提供的API满足不了我们对SQL语句的要求的时候,我们通常是自己来写SQL语句,CI也提供了比较强大了,能够满足我们需求的一般的sql的API。

<span>$res</span>=<span>$this</span>->db->select('id,name'<span>)
    </span>->from('表名'<span>)
    </span>->whrer('id >=',5)<span>//</span><span>注意id后面要有个空格</span>
    ->limit(3,2<span>)<span>//这里与sql的limit是顺序是反的</span>
    </span>->order_by('id desc '<span>)
    </span>->get();<span>//</span><span>翻译成sql语句</span>
<span>var_dump</span>(<span>$res</span>-><span>result());
</span><span>echo</span> <span>$this</span>->db->last_query();<span>//</span><span>先是最近一条SQL</span>
登入後複製

自定义扩展控制器

在application/core中新建MY_Controller.php

<span>class</span> MY_Controller <span>extends</span><span> CI_Controller
{
    </span><span>public</span> <span>function</span><span> __construct()
    {
        parent</span>::<span>__construct();
        </span><span>//</span><span>一定呀先调用父类的构造方法
        //登录验证、权限验证、其他操作。。。</span>
<span>    }
}</span>
登入後複製

同时需要在application/config/config.php中配置一下:

<span>$config</span>['subclass_prefix'] = 'MY_';
登入後複製

自定义扩展模型

在application/models中创建user_model.php

<span>class</span> User_model <span>extends</span><span> CI_Model
{
    </span><span>public</span> <span>function</span><span> getAll()
    {
        </span><span>$res</span> = <span>$this</span>->db->get('表名'<span>);
        </span><span>return</span> <span>$res</span>-><span>result();
    }
}</span>
登入後複製

在控制器中调用自定义模型

application/controllers:

<span>class</span> User <span>extends</span><span> MY_Controller
{
    </span><span>public</span> <span>function</span><span> index()
    {
        </span><span>$this</span>->load->model('User_model');<span>//</span><span>调用以类名为主,而不是文件名</span>
登入後複製
<span>$list</span> = <span>$this</span>->User_model->getAll();<span>//</span><span>调用模型获取数据</span>
登入後複製
<span>$this</span>->load->view('user/index',<span>array</span>('list'=><span>$list</span>));<span>//</span><span>加载视图</span><span>  
    }   
}</span>
登入後複製

加载模型的时候可以给模型取一个名字:

<span>$this</span>->load->model('User_model','user');<span>//</span><span>调用以类名为主,而不是文件名        </span>
<span>$list</span> = <span>$this</span>->user->getAll();<span>//</span><span>调用模型获取数据</span>
登入後複製

Url相关函数

在表单验证的时候,需要把数据传给控制器,怎么准确的而且可扩展的写action呢,调用API:

<span>public</span> <span>function</span><span> addView()
{
    </span><span>$this</span>->load->helper('url');<span>//</span><span>为了不把表单传递的地址写死,用url函数</span>
    <span>$this</span>->load->view('user/add'<span>);
}</span>
登入後複製

在user/add.php视图当中:

<span><</span><span>form </span><span>action</span><span>="<?php echo site_url('user/insert'); ?>"</span><span> method</span><span>="post"</span><span>></span>
<span><!--</span><span> ........</span><span>--></span>
<span></</span><span>form</span><span>></span>
登入後複製

如果是index.php目录的话,用:

base_url();
登入後複製

这个API。

同时,每次加载url很麻烦,也可是设置成自动加载,在config/config.php中修改:

<span>$config</span>['helper'] = <span>array</span>('url');
登入後複製

可能在后面的版本中就没有这个自动加载了。

路由

$route['rouxx/showxx/([\d]+)\.html'] = 'rou/show/$1';//插入这句话

分页

  • 必须知道的一些参数

总共有多少条记录

一页要有多少条记录

总共多少页

当前页前后要显示多少个分页链接

  • 设置一些CI分页类基本参数
<span>//</span><span>总条数</span>
<span>$config</span>['total_rows'<span>]
</span><span>//</span><span>一页显示几条</span>
<span>$config</span>['per_page'<span>]
</span><span>//</span><span>定义当前页的前后各有几个数字链接</span>
<span>$config</span>['num_links'<span>]
</span><span>//</span><span>定义没有分页参数,主URL</span>
<span>$config</span>['base_url']
登入後複製
  • 调用CI的分页类
<span>$this</span>->load->library('pagination');
登入後複製
  • 执行分页方法
<span>$this</span>->pagination->initialize(<span>$config</span>);
登入後複製
  • 输出分页链接
<span>echo</span> <span>$this</span>->pagination->create_links();
登入後複製
  • 查询部分数据(limit)
<span>echo</span> <span>$this</span>->db->limit(<span>$num</span>,<span>$start</span>);  <span>//</span><span>从$start查$num条</span>
登入後複製
<?<span>php 
</span><span>if</span> ( ! <span>defined</span>('BASEPATH')) <span>exit</span>('No direct script access allowed'<span>);

</span><span>class</span> Page <span>extends</span><span> CI_Controller {

    </span><span>public</span> <span>function</span><span> user_add(){
        </span><span>$this</span>->load->model('test_m'<span>);

        </span><span>for</span> (<span>$i</span> = 1;<span>$i</span> <= 100;<span>$i</span>++<span>){
            </span><span>$name</span> = 'u'.<span>$i</span><span>;
            </span><span>$arr</span> = <span>array</span>("usid"=><span>$i</span>,"uname"=><span>$name</span>,"upass"=>123456<span>);
            </span><span>$this</span>->test_m->user_insert(<span>$arr</span><span>);

        }
    }

    </span><span>public</span> <span>function</span><span> pagelist(){
        </span><span>$this</span>->load->model('test_m'<span>);
        </span><span>$user</span> = <span>$this</span>->test_m-><span>user_select_all();
        </span><span>$allnum</span> = <span>count</span>(<span>$user</span><span>);
        </span><span>$pagenum</span> = 20<span>;

        </span><span>$config</span>['total_rows'] = <span>$allnum</span><span>;
        </span><span>$config</span>['per_page'] = <span>$pagenum</span><span>;
        </span><span>$config</span>['num_links'] = 3<span>;
        </span><span>$config</span>['base_url'] = "/CI/index.php/page/pagelist"<span>;
        </span><span>$config</span>['use_page_numbers'] = <span>true</span><span>;

        </span><span>$this</span>->load->library('pagination'<span>);
        </span><span>$this</span>->pagination->initialize(<span>$config</span><span>);

        </span><span>var_dump</span>(<span>$this</span>->pagination-><span>create_links());
        </span><span>echo</span> <span>$this</span>->pagination-><span>create_links();

        </span><span>echo</span> "<br />"<span>;
        </span><span>$id</span> = <span>$this</span>->uri->segment(3);  <span>//</span><span>获得url第三段字符</span>
        <span>$id</span> =<span>$id</span> ? <span>$id</span>:1<span>;
        </span><span>$start</span> = (<span>$id</span> - 1) * <span>$pagenum</span><span>;
        </span><span>$list</span> = <span>$this</span>->test_m->user_select_limit(<span>$start</span>,<span>$pagenum</span><span>);
        </span><span>var_dump</span>(<span>$list</span><span>);
    }
}</span>
登入後複製

上传文件

视图 /views/up.php:

<span><</span><span>html</span><span>></span>
    <span><</span><span>form </span><span>action</span><span>="ci/CodeIgniter_2.2.0/index.php/upload/up"</span><span> method</span><span>="post"</span><span> enctype</span><span>="multipart/form-data"</span><span>></span>
        <span><</span><span>input </span><span>type</span><span>="file"</span><span> name</span><span>="upfile"</span> <span>/></span>
        <span><</span><span>input </span><span>type</span><span>="submit"</span><span> name</span><span>="sub"</span><span> value</span><span>="提交"</span> <span>/></span>
    <span></</span><span>form</span><span>></span>
<span></</span><span>html</span><span>></span>
登入後複製

控制器:

  • 定义一个数组,设置一些与上传相关的参数
<span>$config</span>['upload_path'] = './uploads/'<span>;
</span><span>//</span><span>设置允许上传的类型</span>
<span>$config</span>['allowed_types'] = 'gif|jpg|png'<span>;
</span><span>$config</span>['max_size'] = '100'<span>;
</span><span>//</span><span>如果是图片还可以设置最大高度和宽度</span>
<span>$config</span>['max_height'] = 768<span>;
</span><span>$config</span>['max_width'] = 1024;
登入後複製

还可以设置其他的一些额外参数,详细看用户手册。

  • 调用CI的上传通用类,并执行上传
<span>//</span><span>upload为调用的类名,全小写</span>
<span>$this</span>->load->library('upload',<span>$config</span><span>);
</span><span>//</span><span>如果上传框的name写的是userfile,那就不用传参数了,如果不是,把name的值传进去</span>
<span>$this</span>->upload->do_upload('上传框的name');
登入後複製
  • 接收出错信息或成功信息
<span>//</span><span>出错信息</span>
<span>$error</span> = <span>array</span>('error' => <span>$this</span>->upload-><span>display_error());
</span><span>//</span><span>成功信息</span>
<span>$data</span> = <span>array</span>('upload_data' => <span>$this</span>->upload->data());
登入後複製
<?<span>php 
</span><span>if</span> ( ! <span>defined</span>('BASEPATH')) <span>exit</span>('No direct script access allowed'<span>);

</span><span>class</span> Upload <span>extends</span><span> CI_Controller {
    </span><span>//</span><span>显示带表单的视图</span>
    <span>public</span> <span>function</span><span> index(){
        </span><span>$this</span>->load->view('up'<span>);
    }
    </span><span>//</span><span>显示上传信息</span>
    <span>public</span> <span>function</span><span> up(){
        </span><span>$config</span>['upload_path'] = './uploads/'<span>;
        </span><span>$config</span>['allowed_types'] = 'gif|jpg|png'<span>;
        </span><span>$config</span>['max_size'] = "2000"<span>;
        </span><span>$this</span>->load->library('upload',<span>$config</span><span>);
        </span><span>//</span><span>打印成功或错误的信息</span>
        <span>if</span>(<span>$this</span>->upload->do_upload('upfile'<span>))
        {
            </span><span>$data</span> = <span>array</span>("upload_data" => <span>$this</span>->upload-><span>data());
            </span><span>var_dump</span>(<span>$data</span><span>);
        }
        </span><span>else</span><span>
        {
            </span><span>$error</span> = <span>array</span>("error" => <span>$this</span>->upload-><span>display_errors());
            </span><span>var_dump</span>(<span>$error</span><span>);
        }
    }
}</span>
登入後複製

Session

利用CI类实现session登录

  • 修改配置文件(config.php)
<span>//</span><span>生成一个随机不重复的字符串走位加密的key保存到config.php的encryption_key中</span>
<span>$config</span>['encryption_key']='adb8bf6d0ac4e17b42a80941582497a4';
登入後複製
  • 加载SESSION类
<span>$this</span>->load->library('session');
登入後複製
  • 创建SESSION
<span>$array</span> = <span>array</span>('id'=>3,'name'=>'jack'<span>);
</span><span>$this</span>->session->set_userdata(<span>$array</span>);
登入後複製
  • 查看SESSION
<span>$this</span>->session->userdata(session名);
登入後複製
  • 删除SESSION
<span>$this</span>->session->unset_userdata('SESSION名');
登入後複製

$config['sess_cookie_name'] = 'ci_session'; $config['sess_expiration'] = 7200; $config['sess_expire_on_close'] = FALSE; $config['sess_encrypt_cookie'] = TRUE $config['sess_use_database'] = FALSE; $config['sess_table_name'] = 'ci_sessions'; $config['sess_match_ip'] = FALSE; $config['sess_match_useragent'] = TRUE; $config['sess_time_to_update'] = 300;

  • 一次性数据,只能读取一次
<span>//</span><span>设置</span>
<span>$this</span>->session->set_flashdata('test','aaaaa'<span>);
</span><span>//</span><span>读取</span>
<span>$test</span> = <span>$this</span>->session->flashdata('test');
登入後複製

php CI 框架怎从数据库中取值(一个二维数组)以表格的形式显示到view层

控制层
function test_func(){
//获取model页面需要的两个参数
$competition_id = $_GET["competition_id"];
$report_class = $_GET["report_class"];
$this->load->model("Action"); //引入model
$data["head"] = $this->Action->get_report_item($competition_id, $report_class); //引用model的函数
$this->load->view("test_result",$data); //将结果显示在test_result.php页面中
}
view层:


添加结果显示
//此处选择了循环输出从控制层传输的结果




字段名称(含义) //该td中显示的是你从数据库、即model层中获取到的数据的含义,想显示多少,显示哪个,在这里确认


test; ?>


echo “123”;
}?>

 

php CI框架问题?小弟是初学者

在view文件里可以直接用$title了
是 CI 根据$data里的每一个可以声明了一个变量 到view中可以直接调用
CI 架构就是这么干活的 具体怎么去声明的 没太细看
 

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

php數組二維怎麼轉一維數組 php數組二維怎麼轉一維數組 Aug 03, 2023 am 11:14 AM

php數組二維轉一維數組的方法:1、使用循環遍歷,使用循環遍歷二維數組,將每個元素添加到一維數組中;2、使用“array_merge”函數,可以將多個數字組合併為一個數組,將二維數組當作參數傳遞給“array_merge”函數,將其轉換為一維數組;3、使用“array_reduce”函數,可以將數組中的所有值通過一個回調函數來處理,並最後返回一個結果。

如何使用PHP中的array_sum函數計算二維數組中某一列元素的總和 如何使用PHP中的array_sum函數計算二維數組中某一列元素的總和 Jun 26, 2023 pm 12:45 PM

在PHP程式設計中,array_sum函數是一個非常實用的函數,它可以計算陣列中所有元素的總和。然而,當我們需要計算二維數組中某一列元素的總和時,可能會遇到些許麻煩。本文將介紹如何使用PHP中的array_sum函數計算二維陣列中某一列元素的總和。首先,我們需要了解二維數組的概念。二維數組就是一個包含了多個數組的數組,可以把它看成是一張表格。每個數組都代表了表格

php 二維數組怎麼反轉 php 二維數組怎麼反轉 Dec 26, 2022 am 09:38 AM

php反轉二維數組的方法:1、建立一個php範例檔;2、定義一個二維數組;3、透過「array_reverse($a,true);」函數反轉數組;4、使用「print_r」列印反轉後的二維數組即可。

如何使用PHP中的array_column函數取得二維數組中指定列的值 如何使用PHP中的array_column函數取得二維數組中指定列的值 Jun 26, 2023 pm 01:32 PM

在PHP程式設計中,我們常常需要對陣列進行操作,包括取得指定列的值。而PHP提供了一個非常方便的函數-array_column,可以幫助我們快速取得一個二維陣列中指定列的值。本文將會介紹如何使用array_column函數。 array_column函數的基本用法:array_column(array$array,mixed$column_key[

如何在PHP中將二維數組轉換為一維數組 如何在PHP中將二維數組轉換為一維數組 Jul 07, 2023 pm 06:42 PM

如何在PHP中將二維數組轉換為一維數組在PHP開發中,經常會遇到需要將二維數組轉換為一維數組的場景。本文將介紹幾種常見的方法,幫助你輕鬆完成這個任務。方法一:使用循環遍歷最簡單直接的方法是使用循環遍歷二維數組,並將每個元素加入新的一維數組。以下是使用此方法的程式碼範例:functionflattenArray($array){$result

PHP 5.5函數詳解:如何使用array_column函數提取二維數組中的某一列 PHP 5.5函數詳解:如何使用array_column函數提取二維數組中的某一列 Jul 30, 2023 am 08:45 AM

PHP5.5函數詳解:如何使用array_column函數提取二維數組中的某一列在PHP5.5版本中,引入了array_column函數,它是一個非常實用的函數,能夠從二維數組中提取指定的一列資料。這在處理大量數據時非常方便,讓我們能夠快速獲得我們需要的數據。 array_column函數的基本語法如下:arrayarray_column(array$

php有二維數組嗎 php有二維數組嗎 Aug 03, 2023 pm 02:45 PM

php有二維數組,是一種特殊類型的數組,可以儲存其他數組作為元素,二維數組的聲明和存取都非常簡單,可以使用“array”函數來創建一個二維數組,並使用索引或關聯數組作為其元素,在實際編程中非常有用,可以用於處理各種複雜的資料結構。

在C程式設計中,在運行時使用二維數組進行工作 在C程式設計中,在運行時使用二維數組進行工作 Sep 13, 2023 pm 11:29 PM

問題寫一個C程序,使用運行時編譯來計算二維數組中所有元素的和與積。解決方案運行時編譯或初始化也稱為動態分配。在執行時(運行時)分配記憶體稱為動態記憶體分配。函數calloc()和malloc()支援動態記憶體分配。函數calloc()和malloc()支援動態記憶體分配。 p>在這個程式中,我們將在運行時計算二維數組所有元素的總和以及所有元素的乘積。邏輯用於計算二維數組中所有元素的總和-printf("Sumarrayis:");for(i=0;i<2;i++){&amp

See all articles