Kavin-K
Kavin-K

Reputation: 2117

Getting Internal Server Error (500) - CodeIgniter

In my CodeIgniter project I need to insert data into db table, I am having

Internal server error (500)

issues to add data to database using Ajax.

My Ajax code is below,

$("#rsvp_form").validate({
    rules: {
        uname: {
            required: true,
            minlength: 8
        },
        uemail: "required",
        umessage: {
            required: true,
            maxlength: 100
        }
    },
    messages: {
        uname: {
            required: "Please enter your name",
            minlength: jQuery.validator.format("At least 8 characters required!")
        },
        uemail: "Please enter your email",
        umessage: {
            maxlength: jQuery.validator.format("Please enter no more than 100 characters!")
        },
    },
    // ajax request
    submitHandler: function (form) {

        var formData = {
            'user_name': $('input[name=uname]').val(),
            'user_email': $('input[name=uemail]').val(),
            'user_wish': $('input[name=umessage]').val()
        };

        // loader
        $(".loader").show();

        // ajax request
        $.ajax({
            type: "POST",
            url: "<?php echo base_url(); ?>index.php/Welcome/create_wish",
            data: formData,
            dataType: "json",
            success: function (data) {

                // if send data successfull
                if (data.status === 'success') {

                    $(".loader").hide();
                    $(form).fadeOut("slow");
                    setTimeout(function () {
                        $(".form-success").show("slow");
                    }, 300);

                    // if send data something wrong 
                } else if (data.status === 'error') {

                    $(".loader").hide();
                    $(form).fadeOut("slow");
                    setTimeout(function () {
                        $(".form-error").show("slow");
                    }, 300);
                }

            }
        });
        return false;
    }

});

My Welcome Controller function is below : ,

public function create_wish() {
    $this->load->model("model_wishes");
    $data = array(
    'user_name' => $this->input->post('uname'),
    'user_email' => $this->input->post('uemail'),
    'user_wish' => $this->input->post('umessage')
    );
    $this->model_wishes->createWish($data);
}

model_wishes Model is here,

function createWish($data) {
    $this->db->insert("wishes", $data);
}

welcome_message View is,

<form id="rsvp_form" action="">
<div class="row">
    <div class="form-group col-md-6">
        <label for="post-name">Name</label>
        <input autocomplete='name' type="text" class="form-control" id="uname" name="uname" required />
    </div>
    <div class="form-group col-md-6">
        <label for="post-email">Email</label>
        <input autocomplete='email' type="email" class="form-control" id="uemail" name="uemail" required/>
    </div>
</div>
<div class="row">
    <div class="form-group col-md-12 margin-b-2">
        <label for="post-message">Message</label>
        <textarea class="form-control" id="umessage" rows="5" name="umessage"></textarea>
    </div>
</div>
<div class="row">
    <div class="form-group col-md-12 text-left mb-0">
        <button id="btn-create" type="submit" class="button-medium btn btn-default fill-btn">Post Wish</button>
    </div>
</div>

When Post Wish button is clicked getting XHR failed loading: POST and an error

POST http://localhost/CodeIgniterProj/index.php/Welcome/create_wish 500 (Internal Server Error)

Please let me know what actually force to internal server error, and how could I fix this Issue.

Upvotes: 0

Views: 1131

Answers (3)

Nashir
Nashir

Reputation: 284

Instead of base_url use the site_url

site_url('Welcome/create_wish')

Upvotes: 0

Pradeep
Pradeep

Reputation: 9707

Hope this will help you :

Your submitHandler code should be like this :

submitHandler: function (form) 
{
  var formData = $(form).serialize();
  $(".loader").show();
  console.log(formData);
  $.ajax({
    type: "POST",
    url: "<?=site_url('Welcome/create_wish'); ?>",
    data: formData,
    dataType: "json",
    success: function (data) {
      alert(data);
    }
  });
}

And your controller create_wish should be like this :

public function create_wish() 
{
    $this->load->model("model_wishes");
    $user_name = $this->input->post('uname'));
    $user_email = $this->input->post('uemail');
    $user_wish = $this->input->post('umessage');

    $data = array(
      'user_name' => $user_name,
      'user_email' => $user_email,
      'user_wish' => $user_wish
    );
    $this->model_wishes->createWish($data);
    $response = array('status' => 'success');
    echo json_encode($response);
}

Upvotes: 0

Aman Kumar
Aman Kumar

Reputation: 4547

You are using wrong post input, please check below updated code

public function create_wish() {
    $this->load->model("model_wishes");
    $data = array(
    'user_name' => $this->input->post('user_name'),
    'user_email' => $this->input->post('user_email'),
    'user_wish' => $this->input->post('user_wish')
    );
    $this->model_wishes->createWish($data);
}

Upvotes: 3

Related Questions