ThinkPHP--网站基本信息的设置F方法版

在一些成熟的CMS系统中,后台一般都包含一个配置中心(如织梦后台中系统设置),以方便站长在后台修改配置文件;那么这个功能是如果实现的呢?在ThinkPHP中有没有捷径可走呢?答案肯定是有的。下面大概说一下这个功能实现步骤:

读取原始配置项到表单中,完成表单的呈现;以便管理员修改配置
在管理员更改配置表单值后,点击提交;程序接收到对应的值进行永久存储(如数据库存储、文件存储)
下面我们就按以上的步骤,来完成数据库配置文件的读取和重写。在完成以下代码的时候,请在项目配置文件目录中新建一个db_config.php文件,并在其中写入数据库的配置项(如下):

复制

<?php
/*
*  数据库配置文件
*/

return array(
    //数据库配置
    'DB_HOST' => '127.0.0.1',
    'DB_PORT' => '3306',
    'DB_USER' => 'root',
    'DB_PWD'  => '',
    'DB_NAME' => 'dbname',
    'DB_PREFIX' => 'ly_'
);
?>

接着在项目的主配置文件config.php加入'LOAD_EXT_CONFIG' => 'db_config'项,以便载入当前数据库配置文件。

下面管理员操作进行配置的页面视图,代码如下:

复制

<form action="{:U(GROUP_NAME.'/DbConfig/updateDbconfig')}" method="post">
    <table>
        <tr>
            <th rowspan="2">数据库配置</th>
        </tr>
        <tr>
            <td align="right">数据库服务器地址:</td>
            <td><input type="text" name="DB_HOST" value="{$Think.config.DB_HOST}"/></td>
        </tr>
        <tr>
            <td align="right">数据库服务器端口:</td>
            <td><input type="text" name="DB_PORT" value="{$Think.config.DB_PORT}"/></td>
        </tr>
        <tr>
            <td align="right">数据库用户名:</td>
            <td><input type="text" name="DB_USER" value="{$Think.config.DB_USER}"/></td>
        </tr>
        <tr>
            <td align="right">数据库密码:</td>
            <td><input type="text" name="DB_PWD" value="{$Think.config.DB_PWD}"/></td>
        </tr>
        <tr>
            <td align="right">数据库名称:</td>
            <td><input type="text" name="DB_NAME"  value="{$Think.config.DB_NAME}"/></td>
        </tr>
        <tr>
            <td align="right">数据库表前缀:</td>
            <td><input type="text" name="DB_PREFIX"  value="{$Think.config.DB_PREFIX}"/></td>
        </tr>
        <tr>
            <td align="center" colspan="2"><input type="submit" value="保存" "/></td>
        </tr>
    </table>
</form>

对应的DbConfigAction.class.php控制器代码如下:

复制

<?php
/**
 * Created by PhpStorm.
 * User: LiuYang
 * Date: 14-10-11
 * Time: 下午10:37
 * Description: 数据库配置控制器
 */

class DbConfigAction extends Action {

    //更改配置视图
    public function dbConfig(){
        $this->display();
    }

    //重写配置文件表单处理
    public function updateDbconfig(){

        if(!IS_POST) halt("您访问的页面不存在,请稍后再试!");

        if (F('db_config',$_POST,CONF_PATH)){
            $this->success('修改成功', U(GROUP_NAME.'/DbConfig/dbConfig'));
        } else {
            $this->error('修改失败,请修改'.CONF_PATH.'db_config.php文件权限');
        }
    }
}

实现配置文件的重写也就是这么简单,下面就其中相关内容加以简单说明:

{$Think.config.DB_HOST}:在ThinkPhp中获取对应项的的原始值值,当然也可以像这样写{:C('DB_HOST')}
F('db_config',$_POST,CONF_PATH):F函数(位于ThinkPHP的Common目录下的functions.php文件中)是Thinkphp中写缓存文件的一个函数,在这个使用F函数也是同样适用的。传入的三个参数分别是:文件名(默认后缀.php)、写入的数据、文件位置。以上CONF_PATH是ThinkPHP中的常量,表示主配置文件的位置。
也就这么多了,动动你的小手,实践一下吧!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值