doufei2662 2010-07-20 20:22
浏览 37
已采纳

存储网站偏好的最佳方法是什么?

I'm currently working on a massive revamp of my CMS, and was wondering, what would be the best way to store site preferences...

Currently my pereference setup is within database, full of structure fields (each representing it's own preference), but only id 1 is used. And... I somehow don't like this solution. Now I'm thinking of setting preferences within php file, but then there are problems with editing preferences. Well, not problems, but using files as storage is just bad in my opinion.

With site preferences I mean "Site title", "Site slogan", "Meta keywords", "Meta description" etc., not database info or other totally static values.

So... Are there any other solutions you guys could share?

Thanks in advance!

  • 写回答

3条回答 默认 最新

  • douyin2962 2010-07-20 20:53
    关注

    Well, there's no easy answer to this question. As @Redlab asked, are the preferences frequently changing? If so, then the DB seems like the "better" alternative. But there is a lot more to it than that...

    Are there a lot of these preferences? If so, then storing it in the filesystem may make sense with namespaced files and hiearchial storage. So for example:

    In site.php

    return array(
        'title' => 'This is my page title',
        'meta' => array(
            'description' => 'My Meta Description',
            'keywords' => 'key1, key2, key3',
        ),
    );
    

    Basically, create a file for each "namespace" to group things together.

    The advantage to doing it this way is performance and managability. You can lazy-load the config on a per-namespace basis as needed. You could mimic the effect in the database by adding a field called namespace, and then lazy-loading those fields, but it's going to be significantly slower since every access requires a query. If you have a lot of settings, then loading it from the db on every page hit (even once) is not going to be optimal either...

    What I do is use dot notation. So from the above example, to get the meta keywords would be site.meta.keywords. It's actually reasonably easy to do:

    class Config {
        protected $data = array();
    
        public function get($name, $default = null) {
            $parts = explode('.', $name);
            $ns = array_shift($parts);
            if (!isset($this->data[$ns])) {
                $this->loadNS($ns);
            }
            $search = $this->data[$ns];
            foreach ($parts as $part) {
                if (is_array($search) && isset($search[$part])) {
                    $search = $search[$part];
                } else {
                    return $default;
                }
            }
            return $search;
        }
    
        protected loadNS($name) {
            $path = PATH_TO_CONFIG . $name . '.php';
            if (is_file($path)) {
                $this->data[$name] = include($path);
            } else {
                $this->data[$name] = array();
            }
        }
    }
    

    You can add a set and a save method just as easy.

    To save the files:

    public function saveToFile($ns) {
        if (!isset($this->data[$ns])) {
            $this->loadNS($ns);
        }
        $out = '<?php return '.var_export($this->data[$ns], true).';';
        $path = PATH_TO_CONFIG . $ns . '.php'
        file_put_contents($path, $out);
    }
    

    What results is a very easy to maintain (since it's only ever writing to the filesystem) and easy to modify by hand (since it's all just php code) system for storing and retrieving information.

    And best of all, since it can take advantage of opcode caches, it's VERY efficient and won't slow your page down at all...

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 删除虚拟显示器驱动 删除所有 Xorg 配置文件 删除显示器缓存文件 重启系统 可是依旧无法退出虚拟显示器
  • ¥15 vscode程序一直报同样的错,如何解决?
  • ¥15 关于使用unity中遇到的问题
  • ¥15 开放世界如何写线性关卡的用例(类似原神)
  • ¥15 关于并联谐振电磁感应加热
  • ¥60 请查询全国几个煤炭大省近十年的煤炭铁路及公路的货物周转量
  • ¥15 请帮我看看我这道c语言题到底漏了哪种情况吧!
  • ¥66 如何制作支付宝扫码跳转到发红包界面
  • ¥15 pnpm 下载element-plus
  • ¥15 解决编写PyDracula时遇到的问题