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,251

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
Oracle สอนเขียน Stored Procedure, Table, View, Function, Trigger บน Oracle Database
Oracle สอนเขียน Stored Procedure, Table, View, Function, Trigger บน Oracle Database
Oracle สอนเขียน Stored Procedure, Table, View, Function, Trigger บน Oracle Database
Rating : Update : 2016-01-26 09:11:15
การใช้ PHP กับ Array และ String Separate Comma ไป WHERE IN ใน SQL Query (MySQL / MariaDB)
การใช้ PHP กับ Array และ String Separate Comma ไป WHERE IN ใน SQL Query (MySQL / MariaDB)
เทคนิคการเขียน PHP กับ Array และ String ที่เป็น Separate ในรูปแบบของ Comma (,) นำค่าที่ได้ไป WHERE IN ใน MySQL Database และ MariaDB
Rating : Update : 2017-04-04 19:02:27
การ Join บน SQL และการใช้ Sub Query เพื่อพัฒนา Skill การเขียน Query ขั้นเทพ!!!
การ Join บน SQL และการใช้ Sub Query เพื่อพัฒนา Skill การเขียน Query ขั้นเทพ!!!
เทคนิคการเขียน Join Table และการ JOIN ด้วยการใช้ Sub Query ซึ่งเป็นเทคนิคที่พัฒนา Skill ตัวเองเมื่อเจอ Query ที่มีความซับซ้อน เพื่อให้ได้ Result ที่ต้องการ
Rating : Update : 2017-04-05 11:00:37
WebSocket คืออะไร??? วิธีการรับส่งข้อมูลแบบ real time ด้วย php
WebSocket คืออะไร??? วิธีการรับส่งข้อมูลแบบ real time ด้วย php

Rating : Update : 2017-01-26 16:22:41
C#/VB.net : ZipFile and Compression การ Zip บีบอัดไฟล์บน .Net Application แบบง่ายๆ
C#/VB.net : ZipFile and Compression การ Zip บีบอัดไฟล์บน .Net Application แบบง่ายๆ
การเขียนโปรแกรมบน .Net Application และการ Zip/Compression การบีบอัดไฟล์แบบง่ายๆ ด้วย Class ของ System.IO.Compression และ ZipFile รองรับการเขียน Application ได้ทุกประเภท เช่น ASP.Net, Windows Form, Console App และอื่นๆ
Rating : Update : 2017-04-05 17:18:50
การใช้ HTML5 และ Geolocation อ่านตำแหน่ง Current Location ปัจจุบัน (Latitude และ Longitude)
การใช้ HTML5 และ Geolocation อ่านตำแหน่ง Current Location ปัจจุบัน (Latitude และ Longitude)
ในปัจจุบันเวลาเราเข้าเว็บหลายๆ จะเห็นว่ามี Dialog แจ้งเตือนเพื่อขออนุญาติดึง Location ปัจจุบันของเรา ซึ่งอาจจะนำไปใช้คำนวณหรือตรวจสอบอะไรก็แล้วแต่ และสิ่งที่เค้าจะได้กลับไปก็คือ Latitude และ Longitude
Rating : Update : 2017-05-12 11:16:08
รู้จัก Composer คืออะไร การติดตั้งบน PHP Composer  เช่น XAMPP , Appserv และอื่นๆ
รู้จัก Composer คืออะไร การติดตั้งบน PHP Composer เช่น XAMPP , Appserv และอื่นๆ
รู้จัก Composer คืออะไร การติดตั้งบน PHP Composer เช่น XAMPP , Appserv และอื่นๆ
Rating : Update : 2017-03-18 22:41:17
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
สอน 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 05
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 อัตราราคา คลิกที่นี่