我已经使用codeigniter创建了一个。当用户第一次进入表单页面时,用户然后提交值,然后将值存储到数据库中,并再次将用户定向到表单页面。现在问题是如果用户在第一次提交表单后刷新页面,最后插入的值会一次又一次地自动添加到数据库中,因为用户刷新页面如何停止此操作???
这是我的查看代码......
<?php echo form_open("site/upload_data"); ?>
<div id="container" style="float:left; width:561px; height:50px">
<div id="name" style="float:left; width:150px;">
Movie Name:
</div>
<div id="field" style="float:left; width:411px;">
<input type="text" name="movie_name" />
</div>
</div>
<div id="container" style="float:left; width:561px; height:50px">
<div id="name" style="float:left; width:150px;">
Release Date:
</div>
<div id="field" style="float:left; width:411px;">
<input type="text" name="date" />
</div>
</div>
<div id="container" style="float:left; width:561px; height:160px">
<div id="name" style="float:left; width:150px;">
Genres:
</div>
<div id="field" style="float:left; width:411px;">
<input type="checkbox" name="genres" value="Action">Action
<input type="checkbox" name="genres" value="Adventure">Adventure
<input type="checkbox" name="genres" value="Animation">Animation
<input type="checkbox" name="genres" value="Biography">Biography<br />
<input type="checkbox" name="genres" value="Comedy">Comedy
<input type="checkbox" name="genres" value="Crime">Crime
<input type="checkbox" name="genres" value="Documentary">Documentary
<input type="checkbox" name="genres" value="Drama">Drama<br />
<input type="checkbox" name="genres" value="Family">Family
<input type="checkbox" name="genres" value="Fantasy">Fantasy
<input type="checkbox" name="genres" value="Film-Noir">Film-Noir
<input type="checkbox" name="genres" value="Game-Show">Game-Show<br />
<input type="checkbox" name="genres" value="History">History
<input type="checkbox" name="genres" value="Horror">Horror
<input type="checkbox" name="genres" value="Music">Music
<input type="checkbox" name="genres" value="Musical">Musical<br />
<input type="checkbox" name="genres" value="Mystery">Mystery
<input type="checkbox" name="genres" value="News">News
<input type="checkbox" name="genres" value="Reality-TV">Reality-TV
<input type="checkbox" name="genres" value="Romance">Romance<br />
<input type="checkbox" name="genres" value="Sci-Fi">Sci-Fi
<input type="checkbox" name="genres" value="Sport">Sport
<input type="checkbox" name="genres" value="Talk-Show">Talk-Show
<input type="checkbox" name="genres" value="Thriller">Thriller<br />
<input type="checkbox" name="genres" value="War">War
<input type="checkbox" name="genres" value="Western">Western
</div>
</div>
<div id="container" style="float:left; width:561px; height:50px">
<div id="name" style="float:left; width:150px;">
Rating:
</div>
<div id="field" style="float:left; width:411px;">
<input id="ttcontact" type="radio" checked="checked" value="G" name="rating">
G
<input id="ttcontact" type="radio" value="PG" name="rating">
PG
<input id="ttcontact" type="radio" value="PG-13" name="rating">
PG-13
<input id="ttcontact" type="radio" value="R" name="rating">
R
<input id="ttcontact" type="radio" value="NC-17" name="rating">
NC-17
</div>
</div>
<div id="container" style="float:left; width:561px; height:50px">
<div id="name" style="float:left; width:150px;">
Stars:
</div>
<div id="field" style="float:left; width:411px;">
<input type="text" name="star" placeholder="Eg: Max, John" />
</div>
</div>
<div id="container" style="float:left; width:561px; height:50px">
<div id="name" style="float:left; width:150px;">
Director:
</div>
<div id="field" style="float:left; width:411px;">
<input type="text" name="director" />
</div>
</div>
<div id="container" style="float:left; width:561px; height:50px">
<div id="name" style="float:left; width:150px;">
Writers:
</div>
<div id="field" style="float:left; width:411px;">
<input type="text" name="writers" />
</div>
</div>
<div id="container" style="float:left; width:561px; height:50px">
<div id="name" style="float:left; width:150px;">
Movie Path:
</div>
<div id="field" style="float:left; width:411px;">
<input type="text" name="path" />
</div>
</div>
<div id="container" style="float:left; width:561px; height:50px; text-align:center">
<div id="btn" style="float:left;margin-left: 375px; margin-top: 25px;">
<input type="submit" value="Submit" />
</div>
</div>
<?php echo form_close(); ?>
</div>
这是我的控制器代码......
public function upload_data()
{
$this->load->library('form_validation');
// field name, error message, validation rules
$this->form_validation->set_rules('movie_name', 'Movie Name', 'trim|required|min_length[4]|xss_clean');
$this->form_validation->set_rules('date', 'date', 'trim|required|min_length[4]|xss_clean');
$this->form_validation->set_rules('genres', 'genres', 'trim|required|min_length[4]|xss_clean');
$this->form_validation->set_rules('star', 'star', 'trim|required|min_length[4]|xss_clean');
$this->form_validation->set_rules('director', 'director', 'trim|required|min_length[4]|xss_clean');
$this->form_validation->set_rules('writers', 'writers', 'trim|required|min_length[4]|xss_clean');
$this->form_validation->set_rules('path', 'path', 'trim|required|min_length[4]|xss_clean');
if($this->form_validation->run() == FALSE)
{
$this->admin();
}
else
{
$result = $this->site_upload->add_data();
if ($result)
{
$this->load->view('admin');
}
}
}
这是我的标准代码......
public function add_data()
{
$values = array (
'movie_name' => $this->input->post('movie_name'),
'date' => $this->input->post('date'),
'genres' => $this->input->post('genres'),
'rating' => $this->input->post('rating'),
'star' => $this->input->post('star'),
'director' => $this->input->post('director'),
'writers' => $this->input->post('writers'),
'path' => $this->input->post('path')
);
$rows = $this->db->insert('data',$values);
return $rows;
}
答案 0 :(得分:1)
您可以在成功插入后重定向页面,以防止重复插入。
header("Location: your_submit_page.php?fresh");
答案 1 :(得分:1)
if($this->form_validation->run() == FALSE)
{
$this->admin();
}
else
{
$result = $this->site_upload->add_data();
if ($result)
{
redirect('/path/you/want/to/redirect'); //do the redirection
}
}
redirect()
将达到目的。
答案 2 :(得分:0)
您还可以替换具有给定ID的简单按钮的提交输入,然后使用(例如)jQuery来监听该按钮的“onclick”事件,然后执行POST请求,而不是使用你现在的浏览器。
我发现这种方式更优雅,因为它允许您显示错误消息,而不会让您重新开始使用表单填写过程,这有时是单调乏味的。当然,由于当前页面中没有帖子标题,您可以根据需要重新加载多次,而无需实际发布。
您可能想告诉我们“表单打开”功能如何解析,主要是为了知道POST的位置。