CakePHP 2.X:带有书签/标签的HABTM,从同一表格中保存

时间:2013-05-05 00:38:41

标签: php cakephp cakephp-appmodel

我正在尝试构建一个简单的书签网站,作为学习一些CakePHP的项目,但是在找出如何为书签/标签做HABTM(或者我可能需要的任何东西)方面遇到了很大的麻烦。

我有一个简单的表单,其中包含'Title','Url','Tags'字段,用于创建新书签。

我的表格设置如下:

bookmarks: id (primary), uid, title, url, private (boolean), time
tags: id (primary), tag
bookmarks_tags: id (primary), bookmark_id, tag_id

还有一个用户表。

我的书签模型(Bookmark.php)到目前为止非常简单,如下所示:

class Bookmark extends AppModel {
public $name = "Bookmark";
public $displayField = 'name';
public $hasAndBelongsToMany = array(
    'Tag' => array(
            'className' => 'Tag',
            'joinTable' => 'bookmarks_tags',
            'foreignKey' => 'bookmark_id',
            'associationForeignKey' => 'tag_id',
            'unique' => 'keepExisting',
    )
);

然后进行一些验证。

标签模型如下所示:

class Tag extends AppModel {
public $name='Tag';
public $displayField = 'name';
public $hasAndBelongsToMany = array(
    'Bookmark' => array(
            'className' => 'Bookmark',
            'joinTable' => 'bookmarks_tags',
            'foreignKey' => 'tag_id',
            'associationForeignKey' => 'bookmark_id',
            'unique' => 'keepExisting',
    )
    );

到目前为止,前端的表格看起来像这样:

<div id="addBookmark" class="card">
            <div id="addBookmarkTopSpan" class="topSpan">add new bookmark</div>
            <?php echo $this->Form->create(null, array('url' => array('controller' => 'bookmarks', 'action' => 'add'))); ?>
            <fieldset>
                <?php echo $this->Form->input('Bookmark.title');
                    echo $this->Form->input('Bookmark.url');
                    echo $this->Form->input('Bookmark.private', array('type' => 'checkbox'));
                    echo $this->Form->input('Bookmark.uid', array('type' => 'hidden', 'value' => $user['User']['id']));
                    echo $this->Form->input('Bookmark.Tag');
                    ?>
            </fieldset>
            <?php echo $this->Form->end(__('Submit')); ?>
    </div>

正如我所说,我对Cake很新,所以我不确定这里发生了什么......目前如果我将数据输入到该表单并点击提交,则书签创建得很好但是没有任何事情发生在标签。如何将数据保存到关联的连接表和标签表?

1 个答案:

答案 0 :(得分:1)

在您的视图中更改

echo $this->Form->input('Bookmark.Tag');

echo $this->Form->input('Tag.id');

echo $this->Form->input('Tag.0.id');
echo $this->Form->input('Tag.1.id');
echo $this->Form->input('Tag.2.id');
...

关于代码的几个附注......

由于您遵循CakePHP约定,因此无需指定关系的参数;

public $hasAndBelongsToMany = array('Tag');

public $hasAndBelongsToMany = array('Bookmark');

就够了。

不是在表单中设置可修改的用户ID,而是在控制器中设置它:

BookmarksController.php

public function add() {
    if ($this->request->is('post')) {
        $this->request->data['Bookmark']['uid'] = $this->Auth->user('id');
        if ($this->Note->save($this->request->data)) {
            ...