看到这个 HTML 标记:
<input value="9961" name="c_id" id="c_id" type="hidden">
<input name="user_id" id="user_id" value="1" type="hidden">
<textarea id="comments" name="comments" style="width: 310px; resize: none; height: 75px"></textarea>
然后我在 jQuery 中编写此代码以通过 .post 发送此数据:
$("#dialog-form").dialog({
autoOpen: false,
height: 220,
width: 350,
resizable: false,
modal: true,
buttons: {
"Ok": function () {
if ($('#comments').val() != '') {
$.post("<?php echo site_url('wall/comment') ?>", {
value: $("#comments").val(),
user_id: $('#user_id').val(),
c_id: $("#c_id").val(),
is_post: true
});
$(this).dialog("close");
$(location).attr('href', "<?php echo site_url(); ?>");
}
},
"Cancelar": function () {
$(this).dialog("close");
}
},
close: function () {
$("#comments").val("");
}
});
但是由于某种原因不起作用,但是因为我使用了.post
方法,所以我找不到失败的地方,这意味着是 jQuery 还是服务器端部分。
编辑 这是获取数据并运行基本上是 INSERT 的查询的 PHP 代码:
public function comment() {
role_or_die('wall', 'comment', site_url(), lang('wall:no_permissions'));
$message = $this->input->post('value', TRUE);
$post_id = $this->input->post('c_id', TRUE);
$user_id = $this->input->post('user_id', TRUE);
$this->load->library('user_agent');
$device = "";
if ($this->agent->is_browser()) {
$device = $this->agent->browser();
}
if ($this->agent->is_mobile()) {
$device = $this->agent->mobile();
}
if ($this->wall_comment_m->insert(array('friend_id' => $user_id, 'message' => $message, 'post_id' => $post_id, 'device' => $device))) {
$this->session->set_flashdata('success', lang('message:comment_add_success'));
} else {
$this->session->set_flashdata('error', lang('message:comment_add_error'));
}
}
我看不到生成的 SQL 是否是错误的,或者是否由于 location.href 没有在服务器端设置数据。
我怎样才能找到它失败的地方?有什么方法或工具可以完成这项工作吗?