I find it difficult to understand how to read json string from POST coming from jQuery (most of the articles I saw show how to send json, but not how to get it from POST message received on the Internet service.
This is the code that I have written so far.
On the client side:
<input type="text" id="UserNameText" />
<br />
<input type="password" id="PasswordText" />
<br />
<input type="button" id="Login" value="Login" onclick="DoLogin();" />
<script type="text/javascript" language="javascript">
function DoLogin()
{
var un = document.getElementById('UserNameText').value;
var pw = document.getElementById('PasswordText').value;
var info = "{ 'UserName':'" + un + "', 'Password':'" + pw + "'}";
$.ajax(
{
type: "POST",
url: "http://localhost:60876/Login.asmx/LoginSpecial",
dataType: 'json',
data: info,
contentType: "application/json; charset=utf-8",
success: function (msg) { alert(msg.d); },
error: function (msg) { alert(msg.responseText); }
});
}
</script>
on the server side I have this:
[ScriptMethod(ResponseFormat = ResponseFormat.Json)]
[WebMethod]
public string LoginSpecial()
{
NameValueCollection parameters = HttpContext.Current.Request.Params;
string p = parameters["QUERY_STRING"] != null ? parameters["QUERY_STRING"].ToString() : String.Empty;
string info = HttpContext.Current.Request["info"] != null ? HttpContext.Current.Request["info"].ToString() : String.Empty;
string data = HttpContext.Current.Request["data"] != null ? HttpContext.Current.Request["data"].ToString() : String.Empty;
string json = "{ 'UserName':'test', 'Password':'test'}";
JavaScriptSerializer serial = new JavaScriptSerializer();
Credentials credential = (Credentials)serial.Deserialize(json, typeof(Credentials));
return "Some json message here";
}
I set breakpoints and I hit the web service as expected, I just can't figure out how to get the json string from the POST message.
source
share