目次
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 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

PHPの二次元配列を一次元配列に変換する方法 PHPの二次元配列を一次元配列に変換する方法 Aug 03, 2023 am 11:14 AM

PHP 配列を 2 次元から 1 次元配列に変換する方法: 1. ループ トラバーサルを使用して 2 次元配列を走査し、各要素を 1 次元配列に追加します; 2. 「array_merge」関数を使用して複数の要素をマージします配列を配列に. 二次元配列を「array_merge」関数にパラメータとして渡して一次元配列に変換; 3. 「array_reduce」関数を使用すると、配列内のすべての値を処理できますコールバック関数を介して、最終的に結果を返します。

PHP で array_sum 関数を使用して 2 次元配列の列の要素の合計を計算する方法 PHP で array_sum 関数を使用して 2 次元配列の列の要素の合計を計算する方法 Jun 26, 2023 pm 12:45 PM

PHP プログラミングにおける array_sum 関数は、配列内のすべての要素の合計を計算できる非常に実用的な関数です。ただし、2 次元配列内の要素の列の合計を計算する必要がある場合、問題が発生する可能性があります。この記事では、PHP の array_sum 関数を使用して、2 次元配列の列の要素の合計を計算する方法を紹介します。まず、2 次元配列の概念を理解する必要があります。 2 次元配列は、複数の配列を含む配列であり、テーブルとみなすことができます。各配列はテーブルを表します

PHPで2次元配列を反転する方法 PHPで2次元配列を反転する方法 Dec 26, 2022 am 09:38 AM

PHP で 2 次元配列を反転する方法: 1. PHP サンプル ファイルを作成する; 2. 2 次元配列を定義する; 3. 「array_reverse($a,true);」関数を使用して配列を反転する; 4. を使用する「print_r」で印刷します。 2次元配列を反転するだけです。

PHPのarray_column関数を使用して2次元配列内の指定された列の値を取得する方法 PHPのarray_column関数を使用して2次元配列内の指定された列の値を取得する方法 Jun 26, 2023 pm 01:32 PM

PHP プログラミングでは、指定された列の値を取得するなど、配列を操作する必要があることがよくあります。 PHP には、2 次元配列内の指定された列の値を迅速に取得するのに役立つ、非常に便利な関数 array_column が用意されています。この記事ではarray_column関数の使い方を紹介します。 array_column 関数の基本的な使用法: array_column(array$array,mixed$column_key[

PHPで2D配列を1D配列に変換する方法 PHPで2D配列を1D配列に変換する方法 Jul 07, 2023 pm 06:42 PM

PHP で 2 次元配列を 1 次元配列に変換する方法 PHP 開発では、2 次元配列を 1 次元配列に変換する必要があるシナリオによく遭遇します。この記事では、このタスクを簡単に完了するための一般的な方法をいくつか紹介します。方法 1: ループ トラバーサルを使用する 最も単純で直接的な方法は、ループを使用して 2 次元配列をトラバースし、各要素を新しい 1 次元配列に追加することです。このメソッドを使用したコード例を次に示します。 function flattenArray($array){$result

PHP 5.5 関数の詳細説明: array_column 関数を使用して 2 次元配列の特定の列を抽出する方法 PHP 5.5 関数の詳細説明: array_column 関数を使用して 2 次元配列の特定の列を抽出する方法 Jul 30, 2023 am 08:45 AM

PHP5.5関数の詳しい解説:array_column関数を使って2次元配列の特定の列を取り出す方法 PHP5.5版ではarray_column関数が導入され、指定した列を取り出すことができる非常に実用的な関数です。 2 次元配列からのデータの列。これは大量のデータを扱うときに便利で、必要なデータをすぐに取得できます。 array_column 関数の基本構文は次のとおりです。 arrayarray_column(array$

phpには二次元配列はありますか? phpには二次元配列はありますか? Aug 03, 2023 pm 02:45 PM

PHP には 2 次元配列があり、これは他の配列を要素として格納できる特別なタイプの配列です。2 次元配列の宣言とアクセスは非常に簡単です。「array」関数を使用すると、2 次元配列を作成できます。配列はその要素として実際のプログラミングに非常に役立ち、さまざまな複雑なデータ構造を処理するために使用できます。

C プログラミングで、実行時に 2D 配列を操作する C プログラミングで、実行時に 2D 配列を操作する Sep 13, 2023 pm 11:29 PM

質問 ランタイム コンパイルを使用して 2 次元配列内のすべての要素の和と積を計算する C プログラムを作成してください。ソリューションのランタイムのコンパイルまたは初期化は、動的割り当てとも呼ばれます。実行時 (ランタイム) にメモリを割り当てることを動的メモリ割り当てと呼びます。関数 calloc() および malloc() は、動的メモリ割り当てをサポートします。関数 calloc() および malloc() は、動的メモリ割り当てをサポートします。 p>このプログラムでは、実行時に 2D 配列のすべての要素の合計とすべての要素の積を計算します。ロジックは、2D 配列内のすべての要素の合計を計算するために使用されます - printf("Sumarrayis:");for(i=0;i<2;i++){&amp

See all articles