使用Ajax和Codeigniter评论系统

时间:2016-02-05 07:28:55

标签: php mysql ajax codeigniter

我正在使用ajax和CodeIgniter实现一个评论框。

我想要一个脚本,其中有登录的用户注释,并且Ajax将user_idpost发送到控制器,注释被添加到MySQL数据库,然后刷新注释列表。 下面的代码只是在使用ajax完成功能。 这是我的观点scenery.php

的一部分
  <?php 
$scenery_id=$scenery1['scenery_id'];

 echo form_open(('display_scenery/add_comment/'.$scenery_id)); ?>

 <div class="input-group" ><!-- input group starts-->

  <input type="text" class="form-control" id ="Comment" name ="Comment"  placeholder="Comment on Scenery..." maxlength="300" size= "70" required> 
  <input type ="hidden" name= "Scenery_id" value= " <?php echo $scenery_id?>" />

   <button type="submit"  id = "submit"class="btn btn-info regibutton" >Post</button>


    </div>

 </form>
  <hr/>
   <div id = "comment-box">
 <?php
  if ($comment==NULL){
 //if no scenery comment echo disclaimer
         echo " <ul style = ' margin-left: 0px;padding-left: 0px;'> <li style = 'list-style: none; background-color: #fff; padding : 5px 5px 5px 10px; margin: 5px 5px 5px 5px'>";
      echo " No scenery Comments";  
       echo "</li>
 </ul>"; 
} else{

   foreach ($comment as $row){
 // if the  comments are availabe echo  them
    echo " <ul style = ' margin-left: 0px;padding-left: 0px;'> <li style = 'list-style: none; background-color: #fff; padding : 10px 5px 5px 10px; margin: 5px 5px 5px 5px'>";
  echo $row->Comment;
   echo "<br/>";
     echo "<p style='font-size: 11px; color:#333; padding-top: 5px;'>".date(" D d M Y - H:i:s ",strtotime($row->Date_posted))."By - ". $row->Username. " </p>";
     echo $row->Date_added;

     echo "</li>
 </ul>";
 }

 }
   }
  ?>
  </div>
   </div>
  <br>
 <br>

这是我的Controller display_scenery.php

    public function add_comment(){

$this->load->library('form_validation'); 
    $session_data = $this->session->userdata('logged_in');
        $User_id= $session_data['User_id'];
    $scenery_id = $_POST['Scenery_id'];
    $Comment=$_POST['Comment'];

 $this->form_validation->set_rules('Comment', 'Comment', 'trim|required');
  if($this->form_validation->run() == FALSE)
    {
        ///$error=   form_error('Comment');
        $this-> session->set_flashdata('error',  form_error('Comment'));    
        redirect ('scenery', 'refresh');
}
else {
    //loads the model image_display then redirects to scenery page
  $this-> image_display->add_comment( $scenery_id,     $Comment,$User);             
  redirect ('scenery', 'refresh');


}


   }

2 个答案:

答案 0 :(得分:2)

如果用户已登录,可能是您将用户的数据存储在会话变量中,因此您可以从其会话数据中获取用户的ID(事实上,您不应该&#39; t接受来自前端的这些信息,因为用户可以轻松地更改其UID的值,假装是使用Chrome开发者工具或Firebug的其他人。一旦他们登录,您可以使用jQuery的$ .ajax方法提交AJAX查询:

$.ajax({
    // Submitting to Controller_name->submit_comment() on your site
    'url': 'https://www.example.com/controller_name/submit_comment',
    // Submit as a POST request
    'type': 'POST',
    // comment_text should be a variable containing
    // the text of the comment
    'data': 
    {
        'comment_text': comment_text
    },
    // Controller method will return a JSON object
    'dataType': 'json',
    // Success method for response
    'success': function (response)
    {
        // If success, display comment. This is all coming
        // from the PHP code below.
        if (response.status === true)
        {
            $('#comments').append('<div class="comment"><span class="user-id">' + response.comment.user_id + '</span> at <span class="timestamp">' + response.comment.timestamp + '</span></br />' + response.comment.text + '</div>');
        }
        // Else failure, display error
        else
        {
            $('#comments').append('<div class="comment-error">' + response.error + '</div>');
        }
    }
});

在CodeIgniter后端,您将向Controller_name控制器添加一个名为submit_comment的方法:

public function submit_comment()
{
    $response = array(
        'status' => FALSE,
    );

    // Get the various pieces of data that are needed
    // to store the comment - text, user ID, timestamp of comment.
    $comment = array(
        // Get user ID from session data
        'user_id' => $this->session->userdata('user_id'),
        // Get comment from POST data
        'text' => $this->input->post('comment'),
        // Set timestamp to current epoch time
        'timestamp' => time()
    );

    // Do your validation and database query to save the comment here.
    // Store the result in a variable called $comment_posted
    // (TRUE for success, FALSE for failure).

    // If data validation/database query succeed:
    if ($comment_posted)
    {
        // Set status to true to indicate success.
        $response['status'] = TRUE;
        // Rewrite timestamp to date/time string since humans don't speak epoch.
        $comment['timestamp'] = date('m/d/Y g:ia', $comment['timestamp']);
        // Include comment object in body of response.
        $response['comment'] = $comment;
    }
    // Else the validation/query failed, return an error message.
    else
    {
        // Return a useful error message.
        $response['error'] = 'Some useful error message here.';
    }

    // Print the response array as a JSON-encoded string,
    // which will be consumed by the success method in
    // the Javascript code above.
    die(json_encode($response));
}

答案 1 :(得分:1)

你可以在没有AJAX的情况下制作它,只是为了让功能得以实现。 也不要发送用户ID,因为你应该已经在服务器端拥有它,只需发送帖子ID。