[转]Cake 指南:建立一个简单的Blog

本文是使用Cake框架搭建简单Blog的指南。介绍了默认Cake目录结构,指导下载框架、创建数据库、配置数据库设置,还说明了创建模型类、控制器助手类、控制器类和视图的方法。此外,还讲述了添加新帖子、进行数据有效性检验、删除和编辑帖子等功能的实现。
 
 
注意!
本指南针对cake_0.9.1_dev 发布版不是SVN的版本。请不要把指南的代码改成于SVN一样。

Cake 指南:建立一个简单的Blog

这是一个还在不断变化的一个应用框架的指南。文章中的东西可能可以运行,但是如果有些东西无法运行,请您先仔细阅读 API 文档。错误报告对我们很有价值,所以,请报告任何影响您使用的地方。

注意:命名方法的约定已经从下划线_风格变成了骆驼回归法则。所以,在我们目前的发布版中link_to()已经变成linkTo()

默认Cake目录结构一览

在本篇指南中,我们将一起使用Cake来创建一个简单的Blog应用。我假设你对PHP十分了解,可以在你的系统中游刃有余(包括从命令行中运行程序),同时已经有一个配置好的开发服务器环境,例如运行PHP的 XAMPP

下载

下载最新的Cake 包并解压缩到你的Web服务器的DOCUMENT_ROOT下(因为本文是指南的缘故,我假设他可以从http://localhost/cake/ 下访问)。你可以看到基本的目录结构。

创建数据库

创建一个用来存放Blog帖子的表格,并且初始化一些数据。以下是SQL语句:

CREATE TABLE posts (
    id INT UNSIGNED AUTO_INCREMENT PRIMARY KEY,
    title VARCHAR(50),
    body TEXT,
    created DATETIME DEFAULT NULL,
    updated DATETIME DEFAULT NULL
);

INSERT INTO posts (title,body,created) 
    VALUES ('The title', 'This is the post body.', NOW());
INSERT INTO posts (title,body,created) 
    VALUES ('A title once again', 'And the post body follows.', NOW());
INSERT INTO posts (title,body,created) 
    VALUES ('Title strikes back', 'This is really exciting! Not.', NOW());

注意表名称是复数形式, 这是Cake使用的所有表格的默认形式。还有,idcreatedupdated字段是有特殊含义的,等一会儿你就会发现。也就是说现在你不应该更改他们的名字

配置Cake的数据库设置

若要配置数据库访问,我们编辑 config/database.php.default (他应该是自己包含说明的), 并将它保存为config/database.php. 如果config/database.php 不存在,Cake仍会运行,并且不使用数据库访问。

创建一个模型类 (MVC中的Model)

现在给帖子表格posts创建一个模型类,新建 app/models/post.php包含以下内容 :

app/models/post.php

<?php

class Post extends AppModel
{
}

?>


这已经足以使Cake来关注这个模型了,载入、并把它和数据库表格连接在一起。注意:模型类的类名是单数形式。坚持命名约定十分重要,因为如果不这样,Cake就不会自动运行。默认情况下,模型类和数据库表使用同一个单词而前者以单数形式,后者是复数形式。

建立一个控制器助手类

新建一个控制器助手类。把下面的内容放在 app/helpers/posts_helper.php中:

app/helpers/posts_helper.php

<?php

class PostsHelper extends AppController 
{
}

?>

创建一个控制器类 (Controller)

新建一个控制器类. 把下面的内容放在 app/controllers/posts_controller.php中:

app/controllers/posts_controller.php

<?php

class PostsController extends PostsHelper 
{
}

?>

控制器已经准备好了,这是我们需要在他里面添上行为(Action)来对存储的数据进行操作。添加一个方法到 PostsController 类中 :

app/controllers/posts_controller.php

<?php

class PostsController extends PostsHelper
{
        function index()
        {
        }
}

?>

PostsController::index() 不需要其他内容了,除了需要一个模版(在Cake中称之为视图“View”)。

建立一个视图 (View)

把下面的代码放入 app/views/posts/index.thtml:

<h1>Blog posts</h1>
<table>
        <tr>
                <th>Id</th>
                <th>Title</th>
                <th>Created</th>
        </tr>
        <?php foreach ($this->models['post']->findAll() as $post): ?>
        <tr>
                <td><?php echo $post['id']?></td>
                <td>
                        <?php echo $html->linkTo($post['title'], "/posts/view/{$post['id']}")?>
                </td>
                <td><?php echo $post['created']?></td>
        </tr>
        <?php endforeach; ?>
</table>

这应该可以正确运行,我们来测试一下。我假设你可以通过浏览http://localhost/cake/ 来得到Cake目录,这样测试一下我们的新控制器,它指向http://localhost/cake/posts/index 。你会(希望如此)看到类似于下面的一些东西:

Blog posts

ID  	Title  	                Created
1 	The title 	        2005-07-03 10:52:21
2 	A title once again 	2005-07-03 10:52:34
3 	Title strikes back 	2005-07-03 10:52:43

为什么我没看到呢?

如果你遇到了一个页面,上面说“not Found: The requested URL /posts/index was not found on this server,”你可能要使用 http://localhost/cake/index.php?url=posts 来访问 . 很明显,这很不美观。如果你遇到了一个页面上说“Fatal error: Call to a member function on a non-object ...”那么你可能要检查一下你的配置内容,有没有把config/database.php.default 改名为config/database.php. 参见 Blog指南中的故障及解决方法

我们现在做了些什么?

让我们回顾一下。我们创建了数据库表posts,一个模型类Post,一个控制器PostsController 和他的index()方法,还有一个视图文件app/views/posts/index.thtml。我觉得他一点也不困难。让我们继续吧。

帖子标题是连接到/cake/posts/view/[post_id]的. 让我们点击它。

Missing action

You are seeing this error because the action is not defined in controller Posts
Notice: this error is being rendered by the app/views/errors/missing_action.thtml view file,
a user-customizable error page for handling invalid action dispatches.
Error: Unable to execute action on Posts

噢~,对了,我们忘记添加PostsController::view()行为了。让我们现在完成它:

app/controllers/posts_controller.php

<?php

class PostsController extends PostsHelper
{
        function index()
        {
        }

        function view($id)
        {
                $this->models['post']->setId($id);
                $this->set('data', $this->models['post']->read());
        }
}

?>

还有视图文件:

app/views/posts/view.thtml

<h1><?php echo $data['title']?></h1>
<p><small>Created: <?php echo $data['created']?></small></p>
<p><?php echo $data['body']?></p>

回到浏览器,刷新,看到:

The title

Created: 2005-07-04 03:31:47

This is the post body.

成功了!

添加功能

在指南的第一部分之后,我们有了一个帖子的列表,同时我们可以查看帖子了。当我们完成了第二部分,我们可以:

  • 添加一个新的帖子。
  • 删除不要的帖子。
  • 编辑存在的帖子。

添加一个新的帖子

添加一个新的帖子:

app/controllers/posts_controller.php

<?php

class PostsController extends PostsHelper
{
        function index()
        {
        }

        function view($id)
        {
                $this->models['post']->setId($id);
                $this->set('data', $this->models['post']->read());
        }

        function add()
        {
                if (empty($this->params['data']))
                {
                        $this->render();
                }
                else
                {
                        if ($this->models['post']->save($this->params['data']))
                        {
                                $this->flash('Your post has been saved.','/posts');
                        }
                        else
                        {
                                $this->set('data', $this->params['data']);
                                $this->validateErrors($this->models['post']);
                                $this->render();
                        }
                }
        }
}

?>


同时行为的模版文件是:

app/views/posts/add.thtml

<h1>Add post to blog</h1>
<?php echo $html->formTag('/posts/add')?>
        <p>Title: <?php echo $html->inputTag('post/title', 40)?> <?php echo $html->tagErrorMsg('post/title', 'Title is required.') ?></p>
        <p>Body:  <?php echo $html->areaTag('body') ?> <?php echo $html->tagErrorMsg('post/body', 'Body is required.') ?></p>
        <p><?php echo $html->submitTag('Save') ?></p>
</form>

现在你可以通过地址"/cake/posts/add"来访问 add 页面page at the address "/cake/posts/add", 或者,我们可以在索引页面的底部放上一个快捷的“Add new post”连接:

app/views/posts/index.thtml

<h1>Blog posts</h1>
<table>
        <tr>
                <th>Id</th>
                <th>Title</th>
                <th>Created</th>
        </tr>
        <?php foreach ($this->post->findAll() as $post): ?>
        <tr>
                <td><?php echo $post['id']?></td>
                <td>
                        <?php echo $html->linkTo($post['title'], "/posts/view/{$post['id']}")?>
                </td>
                <td><?php echo $post['created']?></td>
        </tr>
        <?php endforeach; ?>
</table>

<?php echo $html->linkTo('Add new post', '/posts/add') ?>

现在让我们试试添加一些帖子。

像我这样没规矩的,添加了一个没有标题的帖子。当然,我们可以通过数据有效性检验(Data Validation)来避免这种不正确的行为。

数据有效性

数据有效性规则是放在数据模型中的。

app/models/post.php


<?php

class Post extends AppModel
{
        var $validate = array(
                'title'=>VALID_NOT_EMPTY,
                'body'=>VALID_NOT_EMPTY);
}

?>


了解API文档中更多关于有效检验器的内容。

删除一个帖子

app/controllers/posts_controller.php


<?php

class PostsController extends PostsHelper
{
        function index()
        {
        }

        function view($id)
        {
                $this->models['post']->setId($id);
                $this->set('data', $this->models['post']->read());
        }

        function add()
        {
                if (empty($this->params['data']))
                {
                        $this->render();
                }
                else
                {
                        if ($this->models['post']->save($this->params['data']))
                        {
                                $this->flash('Your post has been saved.','/posts');
                        }
                        else
                        {
                                $this->set('data', $this->params['data']);
                                $this->validateErrors($this->models['post']);
                                $this->render();
                        }
                }
        }

        function delete($id)
        {
                if ($this->models['post']->del($id))
                {
                        $this->flash('The post with id: '.$id.' has been deleted.', '/posts');
                }
        }
}

?>


delete 行为没有模版。在成功删除之后,我们只要显示一个快捷消息(所谓的“flash”),然后转回索引页面。

现在我们添加一个删除行为的连接到每一个blog帖子的视图中:

app/views/posts/index.thtml

<h1>Blog posts</h1>
<table>
        <tr>
                <th>Id</th>
                <th>Title</th>
                <th>Created</th>
        </tr>
        <?php foreach ($this->post->findAll() as $post): ?>
        <tr>
                <td><?php echo $post['id']?></td>
                <td>
                        <?php echo $html->linkTo($post['title'], "/posts/view/{$post['id']}")?>
                        <?php echo $html->linkTo('Delete',"/posts/delete/{$post['id']}", null, "Are you sure you want to delete post entitled \'{$post['title']}\'?")?>
                </td>
                <td><?php echo $post['created']?></td>
        </tr>
        <?php endforeach; ?>
</table>

<?php echo $html->linkTo('Add new post', '/posts/add') ?>

在完成它之后,我们就可以删除那些空白标题的帖子了。

编辑帖子

app/controllers/posts_controller.php


<?php

class PostsController extends PostsHelper
{
        function index()
        {
        }

        function view($id)
        {
                $this->models['post']->setId($id);
                $this->set('data', $this->models['post']->read());
        }

        function add()
        {
                if (empty($this->params['data']))
                {
                        $this->render();
                }
                else
                {
                        if ($this->models['post']->save($this->params['data']))
                        {
                                $this->flash('Your post has been saved.','/posts');
                        }
                        else
                        {
                                $this->set('data', $this->params['data']);
                                $this->validateErrors($this->models['post']);
                                $this->render();
                        }
                }
        }

        function delete($id)
        {
                if ($this->models['post']->del($id))
                {
                        $this->flash('The post with id: '.$id.' has been deleted.', '/posts');
                }
        }

        function edit($id=null)
        {
                if (empty($this->params['data']))
                {
                        $this->models['post']->setId($id);
                        $this->params['data']= $this->models['post']->read();
                        $this->render();
                }
                else
                {
                        $this->models['post']->set($this->params['data']);
                        if ( $this->models['post']->save())
                        {
                                $this->flash('Your post has been updat
内容概要:本文是一份针对2025年中国企业品牌传播环境撰写的《全网媒体发稿白皮书》,聚焦企业媒体发稿的策略制定、渠道选择与效果评估难题。通过分析当前企业面临的资源分散、内容同质、效果难量化等核心痛点,系统性地介绍了新闻媒体、央媒、地方官媒和自媒体四大渠道的特点与适用场景,并深度融合“传声港”AI驱动的新媒体平台能力,提出“策略+工具+落地”的一体化解决方案。白皮书详细阐述了传声港在资源整合、AI智能匹配、舆情监测、合规审核及全链路效果追踪方面的技术优势,构建了涵盖曝光、互动、化与品牌影响力的多维评估体系,并通过快消、科技、零售等行业的实战案例验证其有效性。最后,提出了按企业发展阶段和营销节点定制的媒体组合策略,强调本土化传播与政府关系协同的重要性,助力企业实现品牌声量与实际化的双重增长。; 适合人群:企业市场部负责人、品牌方管理者、公关传播从业者及从事数字营销的相关人员,尤其适用于初创期至成熟期不同发展阶段的企业决策者。; 使用场景及目标:①帮助企业科学制定媒体发稿策略,优化预算分配;②解决渠道对接繁琐、投放不精准、效果不可衡量等问题;③指导企业在重大营销节点(如春节、双11)开展高效传播;④提升品牌权威性、区域渗透力与危机应对能力; 阅读建议:建议结合自身企业所处阶段和发展目标,参考文中提供的“传声港服务组合”与“预算分配建议”进行策略匹配,同时重视AI工具在投放、监测与优化中的实际应用,定期复盘数据以实现持续迭代。
先展示下效果 https://pan.quark.cn/s/987bb7a43dd9 VeighNa - By Traders, For Traders, AI-Powered. Want to read this in english ? Go here VeighNa是一套基于Python的开源量化交易系统开发框架,在开源社区持续不断的贡献下一步步成长为多功能量化交易平台,自发布以来已经积累了众多来自金融机构或相关领域的用户,包括私募基金、证券公司、期货公司等。 在使用VeighNa进行二次开发(策略、模块等)的过程中有任何疑问,请查看VeighNa项目文档,如果无法解决请前往官方社区论坛的【提问求助】板块寻求帮助,也欢迎在【经验分享】板块分享你的使用心得! 想要获取更多关于VeighNa的资讯信息? 请扫描下方二维码添加小助手加入【VeighNa社区交流微信群】: AI-Powered VeighNa发布十周年之际正式推出4.0版本,重磅新增面向AI量化策略的vnpy.alpha模块,为专业量化交易员提供一站式多因子机器学习(ML)策略开发、投研和实盘交易解决方案: :bar_chart: dataset:因子特征工程 * 专为ML算法训练优化设计,支持高效批量特征计算与处理 * 内置丰富的因子特征表达式计算引擎,实现快速一键生成训练数据 * Alpha 158:源于微软Qlib项目的股票市场特征集合,涵盖K线形态、价格趋势、时序波动等多维度量化因子 :bulb: model:预测模型训练 * 提供标准化的ML模型开发模板,大幅简化模型构建与训练流程 * 统一API接口设计,支持无缝切换不同算法进行性能对比测试 * 集成多种主流机器学习算法: * Lass...
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值