Register Register Member Login Member Login Member Login Forgot Password ??
PHP , ASP , ASP.NET, VB.NET, C#, Java , jQuery , Android , iOS , Windows Phone
 

Registered : 103,647

HOME > บทความจากสมาชิก > ASP.Net SignalR : ตัวอย่างการรับส่งข้อมูลแบบ Real Time และการจัดเก็บลงใน Database



 

ASP.Net SignalR : ตัวอย่างการรับส่งข้อมูลแบบ Real Time และการจัดเก็บลงใน Database

ASP.Net SignalR : ตัวอย่างการรับส่งข้อมูลแบบ Real Time และการจัดเก็บลงใน Database บทความนี้จะเป็นตัวอย่างการเขียน SignalR บน ASP.Net Web Application ในการรับส่งข้อมูลแบบ Real Time รับข้อมูลจาก Input จำนวน 2 รายการคือ Name และ Email โดยข้อมูลที่รับเข้ามานั้น จะแสดงผลไปยัง Client อื่นๆ ในรูปแบบของ HTML Table ที่เปิดหน้าจอไว้ในขณะนั้นๆ ซึ่งข้อมูลในทุกๆ Client จะแสดงผลแบบ Real Time ตลอดเวลา เมื่อมีข้อมูลใหม่ ๆ เกิดขึ้น และในตัวอย่างนี้ยังมีการนำข้อมูลไปจัดเก็บลงใน Table ด้วย



ตัวอย่างการใช้ SignalR รับ-ส่งข้อมูลแบบ Real Time และการจัดเก็บลงใน Database


รู้จัก ASP.Net SignalR วิธีการรับ-ส่งข้อมูลแบบ Real Time - VB.Net,C#

ก่อนอื่นให้ทำความเข้าใจเกี่ยวกับ SignalR ในบทความก่อนหน้านี้ให้เข้าใจ ก่อนที่จะเริ่มในหัวข้อนี้

ASP.Net SignalR Database Table








สร้าง Table ใหม่ชื่อว่า mytable มีคำสั่งดังนี้

CREATE TABLE [dbo].[mytable](
	[id] [int] IDENTITY(1,1) NOT NULL,
	[name] [varchar](150) NULL,
	[email] [varchar](150) NULL,
 CONSTRAINT [PK_mytable] PRIMARY KEY CLUSTERED 
(
	[id] ASC
));
คำสั่งสำหรับสร้าง Table

ASP.Net SignalR Database Table

Table ที่ได้

ASP.Net SignalR Database Table

ตัวอย่างจัดเก็บข้อมูล

กลับมาที่ Project บน Visual Studio

ASP.Net SignalR Database Table

ในส่วนของ Hub Class ให้ตั้งชื่อเป็น MyHub

MyHub.cs (C#)
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using Microsoft.AspNet.SignalR;
using System.Data;
using System.Data.SqlClient;
using Newtonsoft.Json;

namespace myWebApplication
{
    public class MyHub : Hub
    {
        public class mytable
        {
            public string name { get; set; }
            public string email { get; set; }
        }

        public void SaveData(string name, string email)
        {
            string json = string.Empty;

            SqlConnection objConn;
            SqlCommand objCmd;
            String strConnString, strSQL;
            SqlDataReader dtReader;

            strConnString = @"Server=localhost;UID=sa;PASSWORD=;database=mydatabase;Max Pool Size=400;Connect Timeout=600;";
            objConn = new System.Data.SqlClient.SqlConnection(strConnString);
            objConn.Open();

            // Insert New Data
            if (name != string.Empty && email != string.Empty)
            {
                strSQL = "INSERT INTO mytable (name, email) " +
                "VALUES ('" + name + "','" + email + "')";
                objCmd = new SqlCommand();
                objCmd.Connection = objConn;
                objCmd.CommandType = CommandType.Text;
                objCmd.CommandText = strSQL;
                objCmd.ExecuteNonQuery();
            }

            // Get Data
            strSQL = "SELECT * FROM mytable order by id asc";
            objCmd = new SqlCommand(strSQL, objConn);
            dtReader = objCmd.ExecuteReader();

            var ls = new List<mytable>();
            if (dtReader.HasRows)
            {
                while (dtReader.Read())
                {
                    ls.Add(new mytable { name = dtReader["name"].ToString(), email = dtReader["email"].ToString() });
                }
            }
            json = JsonConvert.SerializeObject(ls);

            dtReader.Close();
            objCmd = null;
            objConn.Close();
            objConn = null;

            // Call the displayData method to update clients.
            Clients.All.displayData(json);
        }
    }
}
จาก Code จะเป็นคำสั่งง่ายๆ คือ รับค่า name และ email เพื่อ Insert ลงใน table จากนั้นส่งค่าทั้งหมดกลับไปทุก ๆ client ในรูปแบบของ JSON








myWebForm.aspx
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="myWebForm.aspx.cs" Inherits="myWebApplication.myWebForm" %>


<!DOCTYPE html>
<html>
<head>
    <title>SignalR Simple</title>
    <style type="text/css">
        .container {
            background-color: #99CCFF;
            border: thick solid #808080;
            padding: 20px;
            margin: 20px;
        }
    </style>
</head>
<body>
    <div class="container">
        Name <input type="text" id="txtName" size="5" /> Email <input type="text" id="txtEmail" />
        <input type="button" id="btnSave" value="Save" />
    </div>

        <table width="400" border="1" id="myTable">
        <!-- head table -->
        <thead>
          <tr>
            <td width="200"> <div align="center">Name </div></td>
            <td width="200"> <div align="center">Email </div></td>
          </tr>
        </thead>
        <!-- body dynamic rows -->
        <tbody></tbody>
        </table>
    <!--Script references. -->
    <!--Reference the jQuery library. -->
    <script src="Scripts/jquery-1.10.2.min.js" "></script>
    <!--Reference the SignalR library. -->
    <script src="/Scripts/jquery.signalR-2.2.1.js"></script>
    <!--Reference the autogenerated SignalR hub script. -->
    <script src="/signalr/hubs"></script>
    <!--Add script to update the page and send messages.-->
    <script type="text/javascript">
        $(function () {

       
            // Declare a proxy to reference the hub.
            var chat = $.connection.myHub;
       
            // Create a function that the hub can call to broadcast messages.
            chat.client.displayData = function (jsonData) {

                $('#myTable > tbody:last').empty();

                var obj = jQuery.parseJSON(jsonData);
                $.each(obj, function (key, val) {
                    var name = val["name"];
                    var email = val["email"];
                    var tr = "<tr>";
                    tr = tr + "<td>" + name + "</td>";
                    tr = tr + "<td>" + email + "</td>";
                    tr = tr + "</tr>";
                    $('#myTable > tbody:last').append(tr);
                });

            };

          
            // Start the connection.
            $.connection.hub.start().done(function () {
                $('#btnSave').click(function () {
                    // Call the Send method on the hub.
                    chat.server.saveData($('#txtName').val(), $('#txtEmail').val());
                    // Clear text box and reset focus for next comment.
                    $('#txtName').val('').focus();
                    $('#txtEmail').val('').focus();
                });

                //First load
                chat.server.saveData('', '');
            });

        });
    </script>
</body>
</html>
Code นี้เป็นส่วนของ Client รับค่า JSON ที่ถูกส่งมาจาก Server จากนั้นแสดงผลบน HTML

Result

ASP.Net SignalR Database Table

ทำการรันโปรแกรมและเปิดหน้าจอขึ้ยมา 3 หน้าจอ ในครั้งแรกจะเห็นว่าจะโหลดข้อมูลที่อยู่ใน Table มาแสดง

ASP.Net SignalR Database Table

ทดสอบส่งข้อมูลจาก Form ใด Form หนึ่งจะเห็นว่าข้อมูลถูกส่งไปแสดงผลยังทุก ๆ Form ที่เปิดอยู่

ASP.Net SignalR Database Table

ทดสอบจกา Form อื่น ๆ ก็จะได้ผลลัพทธ์เช่นเดียวกัน

ASP.Net SignalR Database Table

เมื่อดูใน Database และ Table จะเห็นว่าข้อมูลถูก Insert เข้ามา

Download Code

Query ข้อมูลจาก SQL Server เป็น JSON และการ Deserialize (Decode) ข้อมูล (VB.Net,C#)




   
Share
Bookmark.   

  By : TC Admin
  Article : บทความเป็นการเขียนโดยสมาชิก หากมีปัญหาเรื่องลิขสิทธิ์ กรุณาแจ้งให้ทาง webmaster ทราบด้วยครับ
  Score Rating :
  Create Date : 2017-01-19
  Download : No files
Sponsored Links
ตอนที่ 1 : ดาวน์โหลดและติดตั้ง Database Oracle 11g ฟรี จากเว็บไซต์ของ Oracle
ตอนที่ 1 : ดาวน์โหลดและติดตั้ง Database Oracle 11g ฟรี จากเว็บไซต์ของ Oracle
ห่างหายไปจากบทความ Oracle Database ไปนานพอสมควร ได้มีโอกาศมาเริ่มจับมันอีกครั้ง พร้อม ๆ กับจะพยายามเขียนบทความ ในรูปแบบเทคนิคการใช้งานขั้นสูงขึ้น ในคงามตั้งใจแต่แรกคือต้องการ สอนการเขียน Stored Procedure อย่างเดียว
Rating : Update : 2016-02-02 09:00:41
การสร้าง Event Scheduler  หรือ Job Schedule บน MySQL/MariaDB ตั้งเวลาทำงาน
การสร้าง Event Scheduler หรือ Job Schedule บน MySQL/MariaDB ตั้งเวลาทำงาน
การเขียน event หรือ job schedule บน mysql และ mariadb เพื่อให้ทำงานตามระยะเวลาที่กำหนด เหมาะสำหรับใช้ในการสร้าง job งงานต่างๆ เช่น backup รายการ clear ข้อมูลต่างๆ
Rating : Update : 2017-03-24 17:35:11
การ Backup และ Restore ฐานข้อมูล SQL Server Database อย่างถูกวิธี (รองรับ 2005,2008,2012,2014)
การ Backup และ Restore ฐานข้อมูล SQL Server Database อย่างถูกวิธี (รองรับ 2005,2008,2012,2014)
บทความนี้จะเป็นวิธีการ Backup ข้อมูลบน SQL Server Database อย่างถูกต้องและสามารถทำไปใช้งานกับ SQL Server ในเวอร์ชั่นที่สูงกว่าได้
Rating : Update : 2017-03-25 13:26:50
โค้ดสำหรับโหลดไฟล์จากเว็บ one2up แบบบ้านๆ
โค้ดสำหรับโหลดไฟล์จากเว็บ one2up แบบบ้านๆ
โค้ดสำหรับโหลดไฟล์จากเว็บ one2up แบบบ้านๆ by TOR@Chemistry
Rating : Update : 2016-01-23 14:05:50
สร้าง DataTable บน .Net Application แบบง่าย ๆ ด้วย C# หรือ VB.Net
สร้าง DataTable บน .Net Application แบบง่าย ๆ ด้วย C# หรือ VB.Net
วันนี้ว่าง ๆ เลยหาเทคนิควิธีสร้าง DataTable ในรูปแบบ Column และ Rows แบบง่าย ๆ หลายคนอาจจะใช้เป็นประจำอยู่แล้วหรืออาจะใช้พวก List แทน
Rating : Update : 2017-03-25 13:29:48
(.Net) เขียน Windows App / Console App ตั้งเวลาการทำงาน Schedule Timer (VB.Net,C#)
(.Net) เขียน Windows App / Console App ตั้งเวลาการทำงาน Schedule Timer (VB.Net,C#)
มีโอกาศได้เขียนโปรแกรมเกี่ยวกับ Schedule หรือตั้งให้โปรแกรมทำงานตามระยะเวลาที่กำหนด เช่น ทำงานทุก ๆ 5,10 นาที หรือทุก ๆ ชม. หรือทำงานวันล่ะหนึ่งครั้ง โดยปกติแล้ว เราสามารถใช้พวกคำสั่ง Timer
Rating : Update : 2017-04-19 09:03:20
ระบบ Login PHP + JQuery แบบ Encrypt 2 ระดับ
ระบบ Login PHP + JQuery แบบ Encrypt 2 ระดับ
บทความแรกก็ขอเป็นระบบ Login ก่อนนะครับ อันนี้เป็น Algorithm ส่วนตัวที่มี ตัวอย่างมาจาก การ Login แบบ hash 2 Step ของ Google ซึ่งจะมีในบทความต่อไปครับ
Rating : Update : 2016-05-25 09:20:43
ThaiCreate.Com Forum




Comunity Forum Free Web Script
Jobs Freelance Free Uploads
Free Web Hosting Free Tools

สอน PHP ผ่าน Youtube ฟรี
สอน Android การเขียนโปรแกรม Android
สอน Windows Phone การเขียนโปรแกรม Windows Phone 7 และ 8
สอน iOS การเขียนโปรแกรม iPhone, iPad
สอน Java การเขียนโปรแกรม ภาษา Java
สอน Java GUI การเขียนโปรแกรม ภาษา Java GUI
สอน JSP การเขียนโปรแกรม ภาษา Java
สอน jQuery การเขียนโปรแกรม ภาษา jQuery
สอน .Net การเขียนโปรแกรม ภาษา .Net
Free Tutorial
สอน Google Maps Api
สอน Windows Service
สอน Entity Framework
สอน Android
สอน Java เขียน Java
Java GUI Swing
สอน JSP (Web App)
iOS (iPhone,iPad)
Windows Phone
Windows Azure
Windows Store
Laravel Framework
Yii PHP Framework
สอน jQuery
สอน jQuery กับ Ajax
สอน PHP OOP (Vdo)
Ajax Tutorials
SQL Tutorials
สอน SQL (Part 2)
JavaScript Tutorial
Javascript Tips
VBScript Tutorial
VBScript Validation
Microsoft Access
MySQL Tutorials
-- Stored Procedure
MariaDB Database
SQL Server Tutorial
SQL Server 2005
SQL Server 2008
SQL Server 2012
-- Stored Procedure
Oracle Database
-- Stored Procedure
SVN (Subversion)
แนวทางการทำ SEO
ปรับแต่งเว็บให้โหลดเร็ว


สุดยอด Source Code V2.0
 

แจ้งชำระเงิน/โอนเงิน
 

Hit Link
   


Acc : thaicreate@hotmail.com










Load balance : Server 03
ThaiCreate.Com Logo
© www.ThaiCreate.Com. 2003-2017 All Rights Reserved.
ไทยครีเอทบริการ จัดทำดูแลแก้ไข Web Application ทุกรูปแบบ (PHP, .Net Application, VB.Net, C#)
for Contact Us : [Conditions Privacy Statement] ติดต่อโฆษณา 081-987-6107 , 084-715-5121 อัตราราคา คลิกที่นี่