0

我正在调整StationWagon(FuelPHP 应用程序),到目前为止它运行得非常好。

我已经对其进行了调整(在一些帮助下)以允许将多个图像上传到服务器。这也很好用。

但是,我认为如果我有2 个表会更有意义:1) Articles2) ArticleImages。我会使用外键将图像与文章相关联。因此,在发布文章时,它会将文章数据添加到“Articles”表中,并将每个图像移动到“ArticleImages”中的新行。

所以最终我的“ArticleImages”表可能是:

身份证 | 图片网址 | 文章编号

我的“ articles.php ”控制器的一部分:

<?php       

    public function action_add()
    {
    $val = Model_Article::validate('add_article'); //<-- maybe its just me but i never saw any similar to this in fuelphp sorry about this if im wrong

    // if your form validation is okay than continue with everyhing else
    if ($val->run())
    {
        $article = Model_Article::forge();
        // Custom configuration for this upload
        $config = array(
            'path' => DOCROOT.DS.'images',
            'randomize' => true,
            'ext_whitelist' => array('img', 'jpg', 'jpeg', 'gif', 'png'),
        );

        Upload::process($config);

        // if a valid file is passed than the function will save, or if its not empty
        if (Upload::is_valid())
        {
            // save them according to the config
            Upload::save();

           //if you want to save to tha database lets grab the file name
            $value = Upload::get_files();  

            foreach($value as $files) {
               print_r($files); 
            }
            $article->filename = $value[0]['saved_as'];
         } 

        $status = (Input::post('save_draft') ? 0 : 1);

        if ( ! $val->input('category_id'))
        {
            $category_id = null;
        }
        else
        {
            $category_id = $val->validated('category_id');
        }

             $article->user_id = $this->user_id;
             $article->category_id = $category_id;
             $article->title = $val->validated('title');
             $article->body = $val->validated('body');
             $article->published = $status;


        if ($article->save())
        {
            Session::set_flash('success', 'Article successfully added.');
        }
        else
        {
            Session::set_flash('error', 'Something went wrong, '.
                'please try again!');
        }

        Response::redirect('articles/add');
    }

    $this->template->title = 'Add Article';
    $this->template->content = View::forge('articles/add')
        ->set('categories', Model_Category::find('all'), false)
        ->set('val', Validation::instance('add_article'), false);
    }

/* End of file articles.php */
4

2 回答 2

2

您正在尝试在 Articles 和 ArticleImages 之间建立关系。一个ArticleImage属于一个Article,而一个Article有很多个ArticleImage。FuelPHP 为您想要实现的目标内置了功能。查看有关其 Object Relational Mapper 的 FuelPHP 文档,尤其是 Belongs To 和 Has Many 关系。

于 2012-11-23T13:45:44.777 回答
1

因此,当我几天前为您编写代码时,您只需要一个文件输入。

没有冒犯,但你做错了......

    foreach($value as $files) {
      print_r($files); 
    }
 $article->filename = $value[0]['saved_as'];

应该

foreach($value as $files) {
           $articleimg = Model_Articleimages::forge();
           $articleimg->image_row_name = $files['saved_as']
        }

让你明白

你在这里做了什么,$value = Upload::get_files();是的,这得到了所有的元素,但是因为你需要循环你不需要它的元素

第二

$value[0]['saved_as']仅获取第一个图像名称,只是第一个,并且由于您现在处于循环中,因此您需要引用$files我在上面示例中向您展示的变量,只是一个示例

于 2012-11-27T16:46:40.787 回答