用Ajax的方式,抓取資料庫資料轉成Json(以WebForm為例)

這邊貼上練習用的Source Code,
利用jquery.ajax()用異步(asynchronous),用Post的方式,抓取資料庫的資料。
 

Ajax.aspx

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Ajax.aspx.cs" Inherits="Ajax_Ajax" %>

<!DOCTYPE html>

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title></title>
    <script src="../js/jquery-1.8.3.js"></script>
    <script>
        function SendData() {
            $.ajax({
                url: "../Ajax/GetData.aspx",
                method:"POST",
                data: "Date=" + $("#txtDate").val() + "&Code=" + $("#txtCode").val(),
                async: true,
                dataType: "Json",
                success: function (data) {
                    var obj = JSON.stringify(data);
                    var mapData = JSON.parse(obj);
                    $("#area").val(obj);
                }
            });
        }
    </script>
</head>
<body>
    <form id="form1" runat="server">
        <div>
            <input type="text" id="txtDate">
            <input type="text" id="txtCode">
            <input type="button" onclick="SendData()" value="Send"/>
            <textarea id="area"></textarea>
        </div>
    </form>
</body>
</html>

GetData.aspx.cs

using System;
using System.Collections.Generic;
using System.Configuration;
using System.Data;
using System.Data.SqlClient;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using Newtonsoft.Json;

public partial class Ajax_GetData : System.Web.UI.Page
{
    protected void Page_Load(object sender, EventArgs e)
    {
        if (Request.QueryString["Date"] != null && Request.QueryString["Code"] != null)
        {

            DateTime Date;
            DateTime.TryParse(Request.QueryString["Date"], out Date);
            string Code = Request.QueryString["Code"];

            DataSet ds = new DataSet("Test");
            SqlConnection connection = new SqlConnection(ConfigurationManager.ConnectionStrings["testConnection"].ConnectionString);
            SqlCommand cmd = new SqlCommand("[dbo].[DetailsInfo]", connection);
            cmd.CommandType = CommandType.StoredProcedure;

            cmd.Parameters.Add("@Date", SqlDbType.DateTime).Value = Date;
            cmd.Parameters.Add("@Code", SqlDbType.NVarChar, 50).Value = Code;

            connection.Open();
            SqlDataAdapter adapter = new SqlDataAdapter();
            adapter.SelectCommand = cmd;
            adapter.Fill(ds);

            Response.Write(JsonConvert.SerializeObject(ds));
        }
    }
}