一、MVC
CodeIgniter 采用MVC架构即:控制层、模型层和视图层。
对应Application下面的文件夹 (图1):
所有新建文件以.php结尾
视图层 view 文件夹放入HTML模板
模型层 model 存放对数据库操作的代码
控制层 controllers 存放进行逻辑判断的代码,从模型层取得数据然后输入到视图层,发送给用户。
图1
功能:
1. 模板增加输入表单
2. 控制器增加接收表单数据的代码,并对用户输入进行简单校验。
3. 在表单上方输出标题和正文,以及发布时间。
用到的知识点:CI helper类(url) 和 输入类(input),
以及CI ActiveRecord 和向模板传值。
二、初始配置
1. 链接数据库
修改数据库配置:/application/config/database.php
1
2
3
4
5
6
|
'hostname'
=>
'localhost'
,
'username'
=>
'root'
,
'password'
=>
''
,
'database'
=>
'test'
,
'dbdriver'
=>
'mysqli'
,
'dbprefix'
=>
'ts_'
,
|
2. 修改默认路由
CI框架采用单文件入口的方式,默认必须通过index.php来访问控制层。比如controllers文件夹下有个名为test的class类,test有个叫home的function,
则访问URL为:http://www.example.com/index.php/test/home
三、输出页面
1. 直接输出HTML模板
新建两个文件分别位于controllers文件夹和views文件夹
Test.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
|
defined(
'BASEPATH'
) OR
exit
(
'No direct script access allowed'
);
class
Test
extends
CI_Controller {
public
function
home()
{
$this
->load->view(
'home'
);
}
}
home.php
|
在浏览器打开类似如下地址:http://test.com/index.php/test/home
2. 插入数据库条目
创建数据库表ts_news
Test.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
|
defined(
'BASEPATH'
) OR
exit
(
'No direct script access allowed'
);
class
Test
extends
CI_Controller {
public
function
__construct()
{
parent::__construct();
$this
->load->helper(
'url'
);
$this
->load->model(
'news_model'
);
}
public
function
home()
{
$this
->load->view(
'home'
);
}
public
function
add_news(){
$title
=
$this
->input->get(
'title'
,TRUE);
$content
=
$this
->input->get(
'content'
);
if
( (
strlen
(
$title
) < 20 )
or
(
strlen
(
$content
) < 20 ) ){
echo
'标题或正文内容过短'
;
return
false;
}
$arr
=
array
(
'id'
=>
''
,
'title'
=>
$title
,
'content'
=>
$content
,
'update_time'
=> time(),
'create_time'
=> time()
);
$check
=
$this
->news_model->insert(
$arr
,
'news'
);
if
(
$check
)
{
redirect(
'test/home'
);
}
else
{
echo
'提交失败'
;
}
}
}
home.php
News_model.php
class
News_model
extends
CI_Model {
public
function
__construct()
{
parent::__construct();
$this
->load->database();
}
public
function
insert(
$arr
,
$table
)
{
$this
->db->insert(
$table
,
$arr
);
if
(
$this
->db->affected_rows() > 0)
{
return
$this
->db->insert_id();
}
else
{
return
FALSE;
}
}
}
412ded80-4884-4a2f-ae37-6ba69cdc4278
493498ee-0f5c-4676-9cec-38e5a3f3e6fd
3. 查询数据库并输出
News_model.php增加
public
function
get_all(
$table
)
{
$this
->db->select(
'*'
);
$query
=
$this
->db->get(
$table
);
$query
=
$query
->result_array();
return
$query
;
}
Test.php 的 home修改为:
public
function
home()
{
$news
=
$this
->news_model->get_all(
'news'
);
$data
[
'news'
] =
$news
;
$this
->load->view(
'home'
,
$data
);
}
|
Home模板的body修改为:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
|
foreach
(
$news
as
$key
=>
$value
) {
echo
'
}
?>
|
刷新查看效果: