You seem to be confusing the send and return aspects. You are not sending JSON to the script as the serialize() method serializes a form's data into a query string, not JSON (this string can be decoded using the normal CGI methods). On the other hand, you are telling jQuery that your response will be JSON ( dataType: "json" in your javascript and $q->header("application/json") in your perl script) but you are not sending JSON back, just a plain string.

I don't know your exact requirements but I suspect you don't need to send JSON to your script, you may however need to return JSON. This may help you to see the difference:

Javascript

<script type="text/javascript" > $(function() { $(".submit").click(function() { var formData = $("#reply-form").serialize(); alert(formData); $.ajax({ type: "post", url: "code.pl", cache: false, data: formData, dataType: "json", success: function(data) //onSuccess, { alert(data.calling_params); }, error: function() { alert( "Sorry, there was a problem!" ); } }); return false; }); }); </script>

Perl

use strict; use warnings; use CGI; use JSON; use Data::Dumper; my $q = new CGI; my $in = $q->Vars; my $string = Dumper ($in); my $response = encode_json( { calling_params => "$string" } ); print $q->header("application/json"); print $response;

In reply to Re: Read JSON data from a form by tangent
in thread Read JSON data from a form by Anonymous Monk

Title:
Use:  <p> text here (a paragraph) </p>
and:  <code> code here </code>
to format your post, it's "PerlMonks-approved HTML":



  • Posts are HTML formatted. Put <p> </p> tags around your paragraphs. Put <code> </code> tags around your code and data!
  • Titles consisting of a single word are discouraged, and in most cases are disallowed outright.
  • Read Where should I post X? if you're not absolutely sure you're posting in the right place.
  • Please read these before you post! —
  • Posts may use any of the Perl Monks Approved HTML tags:
    a, abbr, b, big, blockquote, br, caption, center, col, colgroup, dd, del, details, div, dl, dt, em, font, h1, h2, h3, h4, h5, h6, hr, i, ins, li, ol, p, pre, readmore, small, span, spoiler, strike, strong, sub, summary, sup, table, tbody, td, tfoot, th, thead, tr, tt, u, ul, wbr
  • You may need to use entities for some characters, as follows. (Exception: Within code tags, you can put the characters literally.)
            For:     Use:
    & &amp;
    < &lt;
    > &gt;
    [ &#91;
    ] &#93;
  • Link using PerlMonks shortcuts! What shortcuts can I use for linking?
  • See Writeup Formatting Tips and other pages linked from there for more info.