使用codeigniter进行更新

时间:2014-09-10 15:59:29

标签: php mysql codeigniter

我完成了在codeigniter user_guide上制作新闻应用程序的教程。我现在正在尝试扩展教程网站,以便将文本加载到textarea中,该文本区域可以重新输入并用于更新条目。我希望视图文章页面是同一页面进行更新。视图加载正确,但是当我单击提交时,它会将我从localhost / ci / news / foo带到localhost / ci / news / view以及404.我大多试图模仿创建,只改变模型查询,但由于我已经挣扎了一段时间,所以尝试了几个想法。

我怀疑问题可能是以下之一。

指引我进入ci / news / view的东西 滥用我的$ slug变量 错误连接控制器和型号 我的模型查询中的语法。

我会发布所有相关代码。

这是视图的控制器功能,也是更新发生的地方。

public function view($slug)
{
    $this->load->helper('form');
    $this->load->library('form_validation');

    $data['news_item'] = $this->news_model->get_news($slug);

    $slug = $slug;

    $this->form_validation->set_rules('text', 'text', 'required');

    if (empty($data['news_item']))
    {
        show_404();
    }

    $data['title'] = $data['news_item']['title'];
    if ($this->form_validation->run() === FALSE)
    {
    $this->load->view('templates/header', $data);
    $this->load->view('news/view', $data);
    $this->load->view('templates/footer');
    }
    else
    {
        $this->news_model->update_news();
        $this->load->view('news/success');
    }
}

这是模型中的update_news()

public function update_news($slug)
{
$data = array(
    'slug' => $slug,
    'text' => $this->input->post('text')
);
$this->db->set('slug', $slug);
$this->db->update('news', $data);
}

和我的view.php

<?php 
echo validation_errors(); 
echo form_open('news/view'); 

echo '<h2>'.$news_item['title'].'</h2>';
?>

<label for="text">Text</label>
<textarea name="text"><?php echo $news_item['text']; ?></textarea><br />

<input type="submit" name="submit" value="Update" />
</form>

更新:按要求,我的get_news模型函数。

public function get_news($slug = FALSE)
{
if ($slug === FALSE)
{
    $query = $this->db->get('news');
    return $query->result_array();
}

$query = $this->db->get_where('news', array('slug' => $slug));
return $query->row_array();
}

3 个答案:

答案 0 :(得分:1)

在你的模型中,只需放置而不是设置。

 public function update_news($slug)
{
$data = array(
    'slug' => $slug,
    'text' => $this->input->post('text')
);
$this->db->where('slug', $slug);
$this->db->update('news', $data);
}

答案 1 :(得分:0)

我已对您的代码进行了一些小更新,但我仍然需要查看您的&#34; get_news&#34;功能,以完全澄清它是否被打破(由它显示404)

控制器:

<?php
public function view($slug) {

    $data['news_item'] = $this->news_model->get_news($slug);

    if (empty($data['news_item'])) {
        show_404();
    }

    $this->load->helper('form');
    $this->load->library('form_validation');

    $this->form_validation->set_rules('text', 'text', 'required');

    if ($this->form_validation->run() === FALSE) {
        $this->load->view('templates/header', $data);
        $this->load->view('news/view', $data);
        $this->load->view('templates/footer');
    } else {
        $this->news_model->update_news();
        $this->load->view('news/success');
    }
}
?>

型号:

<?
public function update_news($slug) {
    $data = array(
        'text' => $this->input->post('text')
    );
    $this->db->where('slug', $slug);
    $this->db->update('news', $data);
}
?>

查看:

<?php
echo validation_errors();
echo form_open('news/view/'.$news_item['slug']);
?>

<h2><?=$news_item['title']?></h2>

<label for="text">Text</label>
<textarea name="text"><?=$news_item['text'];?></textarea>
<br />
<input type="submit" name="submit" value="Update" />
</form>

答案 2 :(得分:0)

如果您尝试加载不存在的视图文件,即使控制器存在,您也会收到404错误。

您是否创造了新闻/成功&#39;查看文件?