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

Registered : 102,799

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#)


[--Ad3--]


   
Share
Bookmark.   

  By : TC Admin
  Article : บทความเป็นการเขียนโดยสมาชิก หากมีปัญหาเรื่องลิขสิทธิ์ กรุณาแจ้งให้ทาง webmaster ทราบด้วยครับ
  Score Rating :
  Create Date : 2017-01-19
  Download : No files
Sponsored Links
ระบบ อัพโหลดไฟล์ ไม่อาศัย MySQL
ระบบ อัพโหลดไฟล์ ไม่อาศัย MySQL
ในบทความนี้ผม อัพโหลดไฟล์ ไม่อาศัย MySQL ไฟล์จะอัพโหลดไปที่ โฟลเดอร์ที่ไฟล์ index.php จัดเก็บอยู่
Rating : Update : 2016-12-20 16:49:55
ตอนที่ 8 : การใช้ If ....Else If...Else สร้างเงื่อนไข (SQL Server : Stored Procedure)
ตอนที่ 8 : การใช้ If ....Else If...Else สร้างเงื่อนไข (SQL Server : Stored Procedure)
นหัวข้อนี้เราจะมาเรียนรู้การใช้งาน IF บน Stored Procedure เพราะคำสั่งนี้เป็นการสร้างเงื่อนไขในการทำงานที่ได้ค่ามาจาก Parameters และ Variable และมันค่อนข้างจะมีความจำเป็นและสำคัญมากในการเขียน Stored
Rating : Update : 2015-10-04 11:36:44
ระบบ ข่าวในหน้าแรก ด้วย PHP
ระบบ ข่าวในหน้าแรก ด้วย PHP
ในบทความนี้ จะใช้ PHP อย่างเดียว เพราะ จะไม่เกินความสามารถของผู้อื่น
Rating : Update : 2016-12-20 16:50:23
How to backup MySQL database and upload to google drive by Itechs
How to backup MySQL database and upload to google drive by Itechs
Backup database MySQL and upload to google drive
Rating : Update : 2016-02-13 22:06:51
SignalR กับ Windows Form Application รับ-ส่ง ข้อมูลแบบ Real Time (VB.Net, C#)
SignalR กับ Windows Form Application รับ-ส่ง ข้อมูลแบบ Real Time (VB.Net, C#)
วิธีการใช้ SignalR บน Windows Form Application เพื่อรับ-ส่งข้อมูลแบบ Real Time ระหว่าง Server กับ Client สามารถส่งจากภายใน Windows Form ด้วยกัน หรือว่าจะส่งไปยัง Web page ก็ได้
Rating : Update : 2017-03-24 17:24:29
C# การใช้งาน DataSource Wizard กับ DataGridView (Access 2007)
C# การใช้งาน DataSource Wizard กับ DataGridView (Access 2007)
ซึ่งเป็นเรื่องเกี่ยวกับการใช้ DataSource Wizard ร่วมกับ Access 2007 สำหรับบุคลที่ชอบมีปัญหา และ ต้องการตัดปัญหาในเรื่องการศึกษาเกี่ยวกับ SQL Query DataSource Wizard
Rating : Update : 2015-10-02 21:08:12
Windows Form การใช้ User Control กับ MenuStrip สร้างฟร์อมแบบแบบง่ายๆ (VB.Net, C#)
Windows Form การใช้ User Control กับ MenuStrip สร้างฟร์อมแบบแบบง่ายๆ (VB.Net, C#)
ตัวอย่างการใช้ MenuStrip สร้าง Menu บน Windows Form Application และการสร้าง User Control เพื่อสร้าง Form ที่สามารถควบคุมการแสดงผลบนหน้าจอให้อยู่ในหน้าจอเดียวกัน
Rating : Update : 2017-03-24 17:38:18
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
สอน Struts การเขียนโปรแกรม Java Struts Framework
สอน jQuery การเขียนโปรแกรม ภาษา jQuery
สอน Yii  Framework การเขียนโปรแกรม ภาษา PHP กับ Yii
สอน .Net การเขียนโปรแกรม ภาษา .Net
Free Tutorial
สอน 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 01
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 , 089-968-0655 อัตราราคา คลิกที่นี่