本文实例讲述了Codeigniter的Setting增强配置类。分享给大家供大家参考,具体如下:
该增强配置类适用配置项要求比较灵活的项目。可实现预加载配置、组配置、单项调取、增、删、改配置,无需在改动config文档。
使用:
在需要的地方
对于预加载项可以使用
进行获取
对于临时调取项可以使用
进行获取
首先,创建数据表
1
2
3
4
5
6
7
8
9
10
|
CREATE TABLE `system_settings` ( `id` int (11) unsigned NOT NULL AUTO_INCREMENT, ` key ` varchar (64) NOT NULL DEFAULT '' , `value` mediumtext NOT NULL , ` group ` varchar (55) NOT NULL DEFAULT 'site' , `autoload` enum( 'no' , 'yes' ) NOT NULL DEFAULT 'yes' , PRIMARY KEY (`id`,` key `), KEY ` name ` (` key `), KEY `autoload` (`autoload`) ) ENGINE=MyISAM AUTO_INCREMENT=11 DEFAULT CHARSET=utf8; |
然后,在application/libraries目录下创建setting.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
|
<?php if (!defined( 'BASEPATH' )) exit ( 'No direct script access allowed' ); class Setting { private $_ci ; private $settings_autoloaded ; private $settings = array (); private $settings_group = array (); private $settings_db ; public function __construct() { $this ->_ci = &get_instance(); $this ->settings_db = $this ->_ci->config->item( 'settings_table' ); $this ->autoload(); } // ------------------------------------------------------------------------ // 华丽的分割线 正式开始 // ------------------------------------------------------------------------ /** * 从数据库获取所有自动加载的设置 */ public function autoload() { //如果存在则直接返回 if (! empty ( $this ->settings)) { return $this ->settings; } //如果系统不存在数据表则返回false if (! $this ->_ci->db->table_exists( $this ->settings_db)) { return FALSE; } //查询标记为自动加载的项 $this ->_ci->db->select( 'key,value' )->from( $this ->settings_db)->where( 'autoload' , 'yes' ); $query = $this ->_ci->db->get(); if ( $query ->num_rows() == 0) { return FALSE; } //循环写入系统配置 foreach ( $query ->result() as $k => $row ) { $this ->settings[ $row ->key] = $row ->value; $this ->_ci->config->set_item( $row ->key, $row ->value); } //标记会话,避免重复读库 //$this->_ci->session->set_userdata('settings_autoloaded', TRUE); return $this ->settings; } // ------------------------------------------------------------------------ /** * 获取单个设定 * * <code> * <?php $this->settings->get('config_item'); ?> * </code> */ public function item( $key ) { if (! $key ) { return FALSE; } //首先检查是否系统已经自动加载 if (isset( $this ->settings[ $key ])) { return $this ->settings[ $key ]; } //查询数据库 $this ->_ci->db->select( 'value' )->from( $this ->settings_db)->where( 'key' , $key ); $query = $this ->_ci->db->get(); if ( $query ->num_rows() > 0) { $row = $query ->row(); $this ->settings[ $key ] = $row ->value; return $row ->value; } // 查询不到结果则查找系统config,返回值或者false return $this ->_ci->config->item( $key ); } // ------------------------------------------------------------------------ /** * 获取组配置 */ public function group( $group = '' ) { if (! $group ) { return FALSE; } $this ->_ci->db->select( 'key,value' )->from( $this ->settings_db)->where( 'group' , $group ); $query = $this ->_ci->db->get(); if ( $query ->num_rows() == 0) { return FALSE; } foreach ( $query ->result() as $k => $row ) { $this ->settings[ $row ->key] = $row ->value; $arr [ $row ->key] = $row ->value; } return $arr ; } // ------------------------------------------------------------------------ /** * 更改设置 */ public function edit( $key , $value ) { $this ->_ci->db->where( 'key' , $key ); $this ->_ci->db->update( $this ->settings_db, array ( 'value' => $value )); if ( $this ->_ci->db->affected_rows() == 0) { return FALSE; } return TRUE; } // ------------------------------------------------------------------------ /** * 新增设置 */ public function insert( $key , $value = '' , $group = 'addon' , $autoload = 'no' ) { // 检查是否已经被添加的设置 $this ->_ci->db->select( 'value' )->from( $this ->settings_db)->where( 'key' , $key ); $query = $this ->_ci->db->get(); if ( $query ->num_rows() > 0) { return $this ->edit( $key , $value ); } $data = array ( 'key' => $key , 'value' => $value , 'group' => $group , 'autoload' => $autoload , ); $this ->_ci->db->insert( $this ->settings_db, $data ); if ( $this ->_ci->db->affected_rows() == 0) { return FALSE; } return TRUE; } // ------------------------------------------------------------------------ /** * 删除设置 */ public function delete ( $key ) { $this ->_ci->db-> delete ( $this ->settings_db, array ( 'key' => $key )); if ( $this ->_ci->db->affected_rows() == 0) { return FALSE; } return TRUE; } // ------------------------------------------------------------------------ /** * 删除设置组及成员配置 */ public function delete_group( $group ) { $this ->_ci->db-> delete ( $this ->settings_db, array ( 'group' => $group )); if ( $this ->_ci->db->affected_rows() == 0) { return FALSE; } return TRUE; } } /* End of file Setting.php */ /* Location: ./application/libraries/Setting.php */ |
最后,打开application/config/config.php,新增
1
2
3
4
|
/** * 系统配置表名 */ $config [ 'settings_table' ] = "system_settings" ; |
希望本文所述对大家基于Codeigniter框架的PHP程序设计有所帮助。