我正在通过 Zend 框架创建网站,我一直在想这个问题已经有一段时间了......
想象一下,您已经创建了最好的文章模块,并且您通常为每篇文章添加 meta_keywords/meta_description 数据库条目,这样当视图呈现时,它会使用在管理后端输入的数据填充相关元字段。
但是,想象一下动态内容较少的情况,到目前为止,您正在使用 HeadMeta() 视图助手向页面添加元关键字/元描述。
我想有一种方法来配置数据库中每页的元关键字/元描述或其他一些元元素。我一直在摸索什么是最好的解决方案,而不会增加过多的开销(因为您需要对网站中发生的每个操作执行查询)
我最初的想法是将元属性保存在数据库中的索引上,这样对于每个操作,您都可以快速检索所有相关数据。我很快意识到通过 GET/POST 传递的参数可能会改变提供的结果,从而使结果集变得无关紧要。
所以也许我们也可以添加参数,但是您可能希望同时忽略一些参数(因为不需要考虑 ?page=12 参数...)。也许使用序列化参数在索引中添加另一个 varchar 列?
或者添加整个 URL 并执行 REGEXP 选择而不是常规选择?(我猜这可能是最慢的解决方案......)
另请注意,mySQL 对 UTF-8 索引的限制约为 varchar(200)(因此无法保存一个巨大的 URL)
有没有人想到解决这个问题的好方法?