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


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

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

 
 
       
Bookmark.   
Share
       
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





  By : TC Admin
  Article : บทความเป็นการเขียนโดยสมาชิก หากมีปัญหาเรื่องลิขสิทธิ์ กรุณาแจ้งให้ทาง webmaster ทราบด้วยครับ
  Score Rating :
  Create Date : 2017-01-19
  Download : No files
Sponsored Links
 

Sponsored Links
Android Play VDO เล่นวีดีโอไฟล์ง่าย ๆ บน Android ด้วย VideoView
Android Play VDO เล่นวีดีโอไฟล์ง่าย ๆ บน Android ด้วย VideoView
ในการเขียน Application บน Android มี Widgets ที่ชื่อว่า VideoView ที่จะเข้มาช่วยในการเขียนโปรแกรมบน Android ให้สามารถเล่นไฟล์ VDO ในรูปแบบต่าง ๆ ให้ง่ายและสะดวกยิ่งขึ้น
Rating : Update : 2013-05-29 15:19:36
PHP กับเทคนิคการ Submit Form แบบไม่เปลี่ยนหน้าโดยใช้ Target ไปยัง Iframe
PHP กับเทคนิคการ Submit Form แบบไม่เปลี่ยนหน้าโดยใช้ Target ไปยัง Iframe
เทคนิคนี้ไม่ใช่เป็นสิ่งใหม่ แต่ใช้มานานแล้วสำหรับการทำงานบางอย่างที่ไม่ต้องการให้มีการเปลี่ยนหน้าหลังจากเมื่อทำการกดปุ่ม Submit บน Form ในหน้าเว็บเพจ
Rating : Update : 2014-09-07 12:44:02
รู้จัก ASP.Net SignalR วิธีการรับ-ส่งข้อมูลแบบ Real Time - VB.Net,C#
รู้จัก ASP.Net SignalR วิธีการรับ-ส่งข้อมูลแบบ Real Time - VB.Net,C#
SignalR เป็น Library ของ .Net Framework เขียนร่วมกับ ASP.Net เพื่อใช้ในการรับ-ส่งข้อมูลจาก Server ไปยัง Client แบบ Real Time
Rating : Update : 2017-01-14 12:14:49
เปิดตัวแล้วสำหรับชุมชนนักพัฒนาจากอินเทลอัลตร้าบุ๊ค (Intel® Ultrabook™)
เปิดตัวแล้วสำหรับชุมชนนักพัฒนาจากอินเทลอัลตร้าบุ๊ค (Intel® Ultrabook™)
แหล่งที่คุณจะค้นพบทุก ๆ สิ่งที่เป็นไปได้กับรูปแบบใหม่ของอัลตร้าทินที่มีลักษณะบางเป็นพิเศษ (Ultra thin)
Rating : Update : 2012-03-13 14:20:09
โปรแกรม Copy file from server to pc(share file) By Itechs
โปรแกรม Copy file from server to pc(share file) By Itechs
LINK: https://drive.google.com/file/d/0B9WBIvRSivz9b08xU2R3eE1Cc0E/view?usp=sharing
Rating : Update : 2016-02-02 15:06:29
รู้จักกับ Controls เครื่องมือ ต่าง ๆ ที่ใช้สำหรับการเขียนโปรแกรมบน Windows Phone
รู้จักกับ Controls เครื่องมือ ต่าง ๆ ที่ใช้สำหรับการเขียนโปรแกรมบน Windows Phone
การเขียนโปรแกรมบน Windows Phone Application จะมี Controls หรือเครื่องมือที่ใช้สำหรับการออกแบบหน้าจอ Application ของ Page
Rating : Update : 2012-09-11 21:02:10


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
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-2015 All Rights Reserved.
for Contact Us : [Conditions Privacy Statement] ติดต่อโฆษณา 081-987-6107 , 084-715-5121 อัตราราคา คลิกที่นี่

Back to Top