|
SignalR กับ Windows Form Application รับ-ส่ง ข้อมูลแบบ Real Time (VB.Net, C#) |
SignalR กับ Windows Form Application รับ-ส่ง ข้อมูลแบบ Real Time (VB.Net, C#) การเขียน Windows Form หรือ Desktop Application ให้รับส่งข้อมูลแบบ Real Time เป็นโจทย์ยากอีกอย่างหนึ่งของ Dev ในสายนี้ และเชื่อว่าหลายๆ คนจะมองไปถึงการออกแบบที่ง่าย ๆ เช่นออกไปในรูปแบบการใช้ Web API หรือพวก Web Services ที่ใช้ Timer เข้ามากำหนดเวลาให้ทำงานเป็น Loop ไว้สำหรับตรวจสอบข้อมูลใหม่ๆ จาก Web Server เช่น ให้ดึงข้อมูลทุก ๆ 3-5 วินาที เพราะวิธีนี้แอดมินก็เคยใช้มาก่อนเช่นเดียวกัน แต่ผลที่ได้คือโปรแกรมมี Performance ต่ำมาก ทำงานโดยไม่จำเป็น เพราะเมื่อมีการใช้งานหลาย ๆ เครื่อง จะมีเกิด Request ขึ้นมามากมาย ทั้งๆ ไม่มีข้อมูลใหม่ ทุก Client ก็จะทำการเชื่อมต่อทุกๆ เวลาที่ได้กำหนดขึ้น และผลที่ตามมาสุดท้ายคือ โปรแกรมค้าง รวมทั้ง Server ก็ค้างบ่อยเช่นเดียวกัน
และด้วยเหตุผลนี่เองเพื่อให้การใช้งานและพัฒนาโปรแกรมที่ใช้รับส่งข้อมูลแบบ Real Time ทาง Microsoft ได้ออก Library ที่ชื่อว่า SignalR เป็น Open Source ที่สามารถโหลดและใช้งานได้ฟรี สามารถดาวน์โหลดและ Install ผ่าน Nuget Package
SignalR กับ Windows Form Application รับ-ส่ง ข้อมูลแบบ Real Time
SignalR ไม่ได้ออกแบบมาให้ทำงานเฉพาะบน ASP.Net เท่านั้น แต่มันยังสามารถทำงานร่วมกับ Windows Form Application , WPF และยังสามารถผสมผสาน การทำงานร่วมระหว่าง ASP.Net ที่ทำงานบน Web Browser กับ Windows Form เช่นส่งข้อความจาก Web ไปแสดงผลบน Windows Form หรือส่งจาก Windows Form ไปแสดงผลยังบน Web
การทำงานของ SignalR บน Windows Form Application จะมีรูปแบบเหมือนกับ Web Application คือ จะต้องมีเครื่องใดเครื่องหนึ่งทำหน้าที่เป็น Server และ เครื่องที่ทำหน้าที่เป็น Server จะต้องเปิด Service ของ Hub อยู่ตลอดเวลา และ Client ต่างๆ จะเชื่อมต่อกับ Hub Server ผ่าน IP Address หรือ URL ซึ่งสามารถเชื่อมต่อได้ทั้งในรูปแบบ Local , Lan หรือ HTTP ที่เชื่อมกันผ่าน Web site
Step 1 : สร้าง SignalR Server เพื่อรัน Hub Server
data:image/s3,"s3://crabby-images/9be5a/9be5a3c1486a953f3041909f3b36afa2838045ce" alt="Windows Form SignalR Real Time 1 Windows Form SignalR Real Time 1"
เลือกสร้าง Windows Form Application ด้วย C# Project
data:image/s3,"s3://crabby-images/11833/11833fb1fd408e903eb6f87eef83c2442fc508e1" alt="Windows Form SignalR Real Time 2 Windows Form SignalR Real Time 2"
ในที่นี้จะตั้งชื่อ Project ว่า SignalRServer
data:image/s3,"s3://crabby-images/aac5d/aac5dab7640302dffd78cd3cc4b5df7288174636" alt="Windows Form SignalR Real Time 3 Windows Form SignalR Real Time 3"
ให้เปลี่ยน Form1.cs ชื่อว่า StartServer.cs
data:image/s3,"s3://crabby-images/fb383/fb38346e31d9bb4f28f9550c882abb3d761cac7e" alt=""
data:image/s3,"s3://crabby-images/b5c32/b5c32145ff10b8b9d89c38494d891ca8f71d5b93" alt="Windows Form SignalR Real Time 4 Windows Form SignalR Real Time 4"
จากนั้นเปิดไฟล์ Program.cs แล้วเพิ่มคำสั่งต่างๆ ดังรูป
Program.cs
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using System.Windows.Forms;
namespace SignalRServer
{
static class Program
{
internal static StartServer MainForm { get; set; }
/// <summary>
/// The main entry point for the application.
/// </summary>
[STAThread]
static void Main()
{
Application.EnableVisualStyles();
Application.SetCompatibleTextRenderingDefault(false);
MainForm = new StartServer();
Application.Run(MainForm);
}
}
}
จากนั้นให้เปิด Package Manager Console
data:image/s3,"s3://crabby-images/a4832/a483234b415726477f4a83297d0da1df35d47e18" alt="Windows Form SignalR Real Time 5 Windows Form SignalR Real Time 5"
Tool -> Nuget Package Manager -> Package Manager Console
ให้ Install Package ต่างๆ ดังนี้
data:image/s3,"s3://crabby-images/003f1/003f176dc7ef58eaf01b8dc58b909876112c4701" alt="Windows Form SignalR Real Time 6 Windows Form SignalR Real Time 6"
install-package Microsoft.AspNet.SignalR
data:image/s3,"s3://crabby-images/3ed40/3ed4099bcece4c0dd880029ae21890e1b50dabf7" alt="Windows Form SignalR Real Time 7 Windows Form SignalR Real Time 7"
กำลังติดตั้ง
data:image/s3,"s3://crabby-images/30ad9/30ad9b80f3972c1db2b37468381f051723151857" alt="Windows Form SignalR Real Time 8 Windows Form SignalR Real Time 8"
Library ที่ได้
data:image/s3,"s3://crabby-images/05040/0504065b0ef80dd950bb753f254dbd0f6ea64ad6" alt="Windows Form SignalR Real Time 9 Windows Form SignalR Real Time 9"
Install-Package Microsoft.Owin.Cors
data:image/s3,"s3://crabby-images/b2dab/b2dab7265c2a382c3041dd0e0eb14392ec259709" alt="Windows Form SignalR Real Time 10 Windows Form SignalR Real Time 10"
Install-Package Microsoft.Owin.Hosting
data:image/s3,"s3://crabby-images/0208d/0208d1fa67ae7e2f8b9fcb4ea0f2de458b8fd186" alt="Windows Form SignalR Real Time 11 Windows Form SignalR Real Time 11"
Install-Package Microsoft.Owin.Host.HttpListener
data:image/s3,"s3://crabby-images/bfafa/bfafa2b020e3e7c0dc2bc437465088bb15c6f7a3" alt="Windows Form SignalR Real Time 12 Windows Form SignalR Real Time 12"
Note! อย่าลืมว่าจะต้องติดตั้ง Library ให้ครบทุกวัน เพราะแอดมินเคยเจอว่าถ้า Library บางตัวหาย Service ของ Hub จะไม่ทำงาน
data:image/s3,"s3://crabby-images/02d73/02d73766c4a9de9090f24e464ef4ae3bbfe53362" alt="Windows Form SignalR Real Time 13 Windows Form SignalR Real Time 13"
ให้เพิ่ม Class ใหม่และตั้งชื่อว่า MyHubChat.cs
data:image/s3,"s3://crabby-images/c674b/c674b7503c2678f3bdccecd82635f5f76995de76" alt="Windows Form SignalR Real Time 14 Windows Form SignalR Real Time 14"
ไฟล์ที่ได้
MyHubChat.cs
using Microsoft.AspNet.SignalR;
using Microsoft.Owin.Cors;
using Microsoft.Owin.Hosting;
using Owin;
using System;
using System.Reflection;
using System.Threading.Tasks;
using System.Windows.Forms;
namespace SignalRServer
{
public class MyChatHub : Hub
{
public void Send(string name, string message)
{
Clients.All.addMessage(name, message);
}
public override Task OnConnected()
{
Program.MainForm.WriteToConsole("Client connected: " + Context.ConnectionId);
return base.OnConnected();
}
public override Task OnDisconnected(bool stopCalled)
{
Program.MainForm.WriteToConsole("Client disconnected: " + Context.ConnectionId);
return base.OnDisconnected(true);
}
}
}
ใช้ชื่อคลาสว่า MyChatHub ซึ่งตอนที่ Client เรียกใช้งานจะใช้คำว่า myChatHub
data:image/s3,"s3://crabby-images/e20fa/e20fa37236c441328a5a2f865113c19449792ca4" alt="Windows Form SignalR Real Time 15 Windows Form SignalR Real Time 15"
ให้เพิ่มคลาสใหม่ชื่อว่า OWIN Startup Class ชื่อว่า Startup.cs
data:image/s3,"s3://crabby-images/4b00b/4b00b3cf7cc9f6fe1607a93331ceddd01e8461bc" alt="Windows Form SignalR Real Time 16 Windows Form SignalR Real Time 16"
ไฟล์ Startup.cs ที่ได้
Startup.cs
using System;
using System.Threading.Tasks;
using Microsoft.Owin.Cors;
using Microsoft.Owin.Hosting;
using Microsoft.Owin;
using Owin;
[assembly: OwinStartup(typeof(SignalRServer.Startup))]
namespace SignalRServer
{
public class Startup
{
public void Configuration(IAppBuilder app)
{
app.UseCors(CorsOptions.AllowAll);
app.MapSignalR();
}
}
}
data:image/s3,"s3://crabby-images/87684/87684cc33001c692a5f14a87779f0dafc206b274" alt="Windows Form SignalR Real Time 17 Windows Form SignalR Real Time 17"
กลับมาที่ฟอร์มของ StartServer.cs
data:image/s3,"s3://crabby-images/20703/207036d1f8acd33267868aa7379b16b8f66b19c9" alt="Windows Form SignalR Real Time 18 Windows Form SignalR Real Time 18"
ออกแบบ Form ดังรูป โดยใช้ Button และ RichTextBox จากนั้นสร้าง Method และ Event ต่างๆ ดังนี้
StartServer.cs
using Microsoft.AspNet.SignalR;
using Microsoft.Owin.Cors;
using Microsoft.Owin.Hosting;
using Owin;
using System;
using System.Reflection;
using System.Threading.Tasks;
using System.Windows.Forms;
namespace SignalRServer
{
public partial class StartServer : Form
{
private IDisposable SignalR { get; set; }
const string ServerURI = "http://localhost:8080"; // or IP Address
public StartServer()
{
InitializeComponent();
}
private void ButtonStart_Click(object sender, EventArgs e)
{
WriteToConsole("Starting server...");
ButtonStart.Enabled = false;
Task.Run(() => GoStartServer());
}
private void ButtonStop_Click(object sender, EventArgs e)
{
Close();
}
private void GoStartServer()
{
try
{
SignalR = WebApp.Start(ServerURI);
}
catch (TargetInvocationException)
{
WriteToConsole("Server failed to start. A server is already running on " + ServerURI);
//Re-enable button to let user try to start server again
this.Invoke((Action)(() => ButtonStart.Enabled = true));
return;
}
this.Invoke((Action)(() => ButtonStop.Enabled = true));
WriteToConsole("Server started at " + ServerURI);
}
internal void WriteToConsole(String message)
{
if (RichTextBoxConsole.InvokeRequired)
{
this.Invoke((Action)(() =>
WriteToConsole(message)
));
return;
}
RichTextBoxConsole.AppendText(message + Environment.NewLine);
}
private void StartServer_FormClosing(object sender, FormClosingEventArgs e)
{
if (SignalR != null)
{
SignalR.Dispose();
}
}
}
}
Note! จากโค้สจะเห็น http://localhost:8080 ซึ่งเป็น IP Address และ Port ที่จะทำหน้าที่เป็น Hub Server
ทดสอบการทำงานของ Hub Server
data:image/s3,"s3://crabby-images/f81c2/f81c217fc4f01c594408fdea580776eab0610aad" alt="Windows Form SignalR Real Time 19 Windows Form SignalR Real Time 19"
กดปุ่ม Start
data:image/s3,"s3://crabby-images/b7d9c/b7d9ce859569233bcc57dd27f5f863d5b6d352c3" alt="Windows Form SignalR Real Time 20 Windows Form SignalR Real Time 20"
ถ้าขั้นดึงรูปแสดงว่าตอนที่ Hub Server ทำงานแล้วโดยผ่าน IP และ Port : http://localhost:8080
Note!: ในกรณีที่ Services ไม่ทำงานอาจจะต้องดูเรื่อง สิทธิ์ในการรันว่าเป็น Administrator หรือว่า Network ยอมใผ้ใช้ Port นั้นๆ ได้หรือไม่
Step 2 : สร้าง SignalR Client เพื่อทดสอบรับ-ส่งขอความระหว่าง Server กับ Client
data:image/s3,"s3://crabby-images/9379d/9379dc945efd8d592ffff66bda085ba1d955df74" alt="Windows Form SignalR Real Time 21 Windows Form SignalR Real Time 21"
สร้าง Windows Form Application ตั้งชื่อว่า SignalRClient
data:image/s3,"s3://crabby-images/5f86b/5f86baca0a6863d09df5f8eb9155ce599155135a" alt="Windows Form SignalR Real Time 22 Windows Form SignalR Real Time 22"
เปลี่ยน Form1.cs เป็นชื่อ StartClient.cs
data:image/s3,"s3://crabby-images/c2ecf/c2ecffbc7acf7ecdd0442e5a32b4c409df1ca9b4" alt="Windows Form SignalR Real Time 23 Windows Form SignalR Real Time 23"
จากนั้นติดตั้ง Library ของ SignalR
install-package Microsoft.AspNet.SignalR.Client
data:image/s3,"s3://crabby-images/d6d30/d6d302d0e48c69083547f8fbb2901d9b83464e32" alt="Windows Form SignalR Real Time 24 Windows Form SignalR Real Time 24"
Library ที่ได้จากการติดตั้ง
data:image/s3,"s3://crabby-images/e0a86/e0a86fda9f1e31a1a4523626c68909b585c16713" alt="Windows Form SignalR Real Time 25 Windows Form SignalR Real Time 25"
กลับมาที่ฟอร์ม StartClient.cs ให้ออกแบบ Form ดังรูป ประกอบด้วย TextBox, Button และ RichTextBox
StartClient.cs
using Microsoft.AspNet.SignalR.Client;
using System;
using System.Net.Http;
using System.Windows.Forms;
namespace SignalRClient
{
public partial class ClientStart : Form
{
private String UserName { get; set; }
private IHubProxy HubProxy { get; set; }
const string ServerURI = "http://localhost:8080/signalr";
private HubConnection Connection { get; set; }
public ClientStart()
{
InitializeComponent();
}
private void ButtonConnect_Click(object sender, EventArgs e)
{
UserName = TextBoxUsername.Text;
if (!String.IsNullOrEmpty(UserName))
{
StatusText.Visible = true;
StatusText.Text = "Connecting to server...";
ConnectAsync();
}
}
private void ButtonSend_Click(object sender, EventArgs e)
{
HubProxy.Invoke("Send", UserName, TextBoxMessage.Text);
TextBoxMessage.Text = String.Empty;
TextBoxMessage.Focus();
}
private async void ConnectAsync()
{
Connection = new HubConnection(ServerURI);
Connection.Closed += Connection_Closed;
HubProxy = Connection.CreateHubProxy("MyChatHub");
//Handle incoming event from server: use Invoke to write to console from SignalR's thread
HubProxy.On<string, string>("AddMessage", (name, message) =>
this.Invoke((Action)(() =>
RichTextBoxConsole.AppendText(String.Format("{0}: {1}" + Environment.NewLine, name, message))
))
);
try
{
await Connection.Start();
}
catch (HttpRequestException)
{
StatusText.Text = "Unable to connect to server: Start server before connecting clients.";
//No connection: Don't enable Send button or show chat UI
return;
}
//Activate UI
ButtonSend.Enabled = true;
TextBoxMessage.Enabled = true;
TextBoxMessage.Focus();
TextBoxUsername.Enabled = false;
ButtonConnect.Enabled = false;
RichTextBoxConsole.AppendText("Connected to server at " + ServerURI + Environment.NewLine);
}
private void Connection_Closed()
{
//Deactivate chat UI; show login UI.
this.Invoke((Action)(() => ButtonSend.Enabled = false));
this.Invoke((Action)(() => StatusText.Text = "You have been disconnected."));
}
}
}
จากโค้ด http://localhost:8080/signalr เป็น URL หรือ IP ของ Hub Server
ทดสอบการทำงาน
data:image/s3,"s3://crabby-images/11277/1127745943098d74d8bd830ccdbf13848228727d" alt="Windows Form SignalR Real Time 26 Windows Form SignalR Real Time 26"
ก่อนอื่นจะต้องรันตัว SignalRServer เพื่อเปิด Hub Services ให้ทำงานก่อน
data:image/s3,"s3://crabby-images/d36ab/d36ab55998ebbdc095ef46a2fdc7cbf1bb49f42a" alt="Windows Form SignalR Real Time 27 Windows Form SignalR Real Time 27"
จากนั้นก็รัน SignalRClient และทดสอบการเชื่อมต่อโดนคีย์ชื่อและคลิก Connect
data:image/s3,"s3://crabby-images/a0c2d/a0c2da6982bd40f412bed5a8f27500bf6366a217" alt="Windows Form SignalR Real Time 28 Windows Form SignalR Real Time 28"
ถ้าสามารถ Connect ได้ฝั่ง Client และ Server จะแสดง Message ว่ามีการเชื่อมต่อ
data:image/s3,"s3://crabby-images/29c5a/29c5a389163571c0942162929a76d43263c4caa6" alt="Windows Form SignalR Real Time 29 Windows Form SignalR Real Time 29"
เพื่อให้สามารถรันได้หน้าจอให้เปิดโปรแกรมจากไฟล์ Debug โดยตรง
data:image/s3,"s3://crabby-images/8ecc0/8ecc012e0789b8fd78683fb72e761e8015a9f86f" alt="Windows Form SignalR Real Time 30 Windows Form SignalR Real Time 30"
ในที่นี้จะเปิดขึ้นมาสามหน่าจอ โดยแต่ล่ะหน้าจอให้ User ที่แตกต่างกันไปเช่น max, win และ tookta และจากภาพจะเห็นว่าเมื่อ Client แต่ล่ะตัวทำการเชื่อมต่อ แจะแสดง Message ที่ Server ว่ามี Client ทำการ Connect เข้ามา
data:image/s3,"s3://crabby-images/44921/449215372144cdde135745a7aef7e4331c7a0483" alt="Windows Form SignalR Real Time 31 Windows Form SignalR Real Time 31"
ทดสอบส่งข้อความจาก User ใด User หนึ่ง
data:image/s3,"s3://crabby-images/66428/664287742f47029ec988d0665b6627de1d03e107" alt="Windows Form SignalR Real Time 32 Windows Form SignalR Real Time 32"
จะเห็นว่าข้อความจะถูกส่งไปยังหน้าจอของทุกๆ User ที่ทำการเชื่อมต่อแบบทันทันที Real Time
data:image/s3,"s3://crabby-images/d7262/d72620b63d25e1f4bd9c87ea949c67bf2d8a5fc1" alt="Windows Form SignalR Real Time 33 Windows Form SignalR Real Time 33"
ทดสอบการส่ง
Download Code ตัวอย่าง 1
ตัวอย่างที่ 2 การส่งข้อความแบบเจาะจงไปยัง Client
โดยการเพิ่มช่อง To ระบุว่าจะส่งไปถึงใคร
data:image/s3,"s3://crabby-images/a93ef/a93ef899fa4bfd9bfb37ab0ac0ec0b9c176f9a22" alt="Windows Form SignalR Real Time 34 Windows Form SignalR Real Time 34"
จากตัวอย่างแรกข้อความะถูกส่งไปยังทุก Client ที่ทำการเชื่อมต่อ แต่ในการทำงานจริงแล้ว เราอาจจะให้ข้อความส่งไปถึงแค่บาง Client เท่านั้น ซึ่งในการทำงานของ Hub จะมีการส่งข้อมูลไปทุก Client ตลอดเวลา แต่เราสามารถกรองที่ Client ว่าข้อความที่ส่งมาจะให้แสดงผลบนหน้าจอหรือไม่
สิ่งที่ปรับมีเพียงเล็กน้อยเท่านั้น
MyChatHub.cs
public void Send(string name, string to, string message)
{
Clients.All.addMessage(name, to, message);
}
ในฝั่ง Server เพิ่ม Parameters ที่จะเก็บ to
ClientStart.cs
HubProxy.On<string, string, string>("AddMessage", (name, to, message) =>
this.Invoke((Action)(() =>
SetText(name, to, message)
))
);
ClientStart.cs
public void SetText(string name, string to, string message) {
if (to == UserName)
{
RichTextBoxConsole.AppendText(String.Format("{0}: {1}" + Environment.NewLine, name, message));
}
}
ClientStart.cs
HubProxy.Invoke("Send", UserName, TextBoxTo.Text, TextBoxMessage.Text);
ในส่วนของ Client ก็เพิ่ม to เข้าไปด้วยเช่นเดียวกัน โดนตอนที่รับข้อความจะมีการเช็ตว่า to นั้นตรงกับชื่อที่ Connect หรือไม่
ทดสอบการทำงาน
data:image/s3,"s3://crabby-images/cea99/cea99821981bb7a627eb5d8d8f5e0b0da7bec68d" alt="Windows Form SignalR Real Time 35 Windows Form SignalR Real Time 35"
ให้เปิด Server และ Client ขึ้นมา 3 หน้าจอ ให้เชื่อมต่อโดยใช้ User ที่แตกต่างกันไปเช่น max, win และ tookta
data:image/s3,"s3://crabby-images/29fb6/29fb64917181bf64def4e19b7d899474ac6e9f44" alt="Windows Form SignalR Real Time 36 Windows Form SignalR Real Time 36"
ทดสอบข้อความจาก max ไปหา win ข้อความน้้นก็จะถูกส่งไปยังเฉพาะ win เท่านั้น หรือจะทดสอบด้วย User อื่นๆ ก็จะได้ผลเช่นเดียวกัน
และจากที่ได้เกริ้นไว้ก่อนหน้านี้ว่า SignalR สามารถทำงานร่วมกันจะหว่าง ASP.Net , Windows Form , WPF ฉะนั้นเมื่อ Hub Server ทำงาน เราก็สามารถที่จะใช้ Application ต่างๆ เชื่อมต่อเข้ามาได้
Default.html
<!DOCTYPE html>
<html>
<head>
<title>SignalR Simple Chat</title>
<style type="text/css">
.container {
background-color: #99CCFF;
border: thick solid #808080;
padding: 20px;
margin: 20px;
}
</style>
</head>
<body>
<p><strong>To connect the web client, reload this page after a server is started</strong></p>
<div class="container">
<div id="yourname"></div>
<input type="hidden" id="displayname" />
Send to <input type="text" id="to" size="5" /> Message <input type="text" id="message" />
<input type="button" id="sendmessage" value="Send" />
<ul id="discussion"></ul>
</div>
<!--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.min.js"></script>
<!--Reference the autogenerated SignalR hub script. -->
<script src="http://localhost:8080/signalr/hubs"></script>
<!--Add script to update the page and send messages.-->
<script type="text/javascript">
$(function () {
//Set the hubs URL for the connection
$.connection.hub.url = "http://localhost:8080/signalr";
// Declare a proxy to reference the hub.
var chat = $.connection.myChatHub;
// Create a function that the hub can call to broadcast messages.
chat.client.addMessage = function (name, to, message) {
// Html encode display name and message.
if (to == $('#displayname').val()) {
var encodedName = $('<div />').text(name).html();
var encodedMsg = $('<div />').text(message).html();
// Add the message to the page.
$('#discussion').append('<li><strong>' + encodedName
+ '</strong>: ' + encodedMsg + '</li>');
}
};
// Get the user name and store it to prepend to messages.
$('#displayname').val(prompt('Enter your name:', ''));
$('#yourname').html('Your name = ' + $('#displayname').val());
// Set initial focus to message input box.
$('#message').focus();
// Start the connection.
$.connection.hub.start().done(function () {
$('#sendmessage').click(function () {
// Call the Send method on the hub.
chat.server.send($('#displayname').val(), $('#to').val(), $('#message').val());
// Clear text box and reset focus for next comment.
$('#message').val('').focus();
});
});
});
</script>
</body>
</html>
แค่เพียงอ้าง URL ให้ถูกต้อง http://localhost:8080/signalr ส่วนวิธีการสร้าง WebClient ให้อ่านจากบทความ ASP.Net SignalR
data:image/s3,"s3://crabby-images/15d4e/15d4e35aa60b69f7fd2752d14c497c1204173b94" alt="Windows Form SignalR Real Time 37 Windows Form SignalR Real Time 37"
ทดสอบการทำงานบน Web ให้ Login ด้วย User : chat
data:image/s3,"s3://crabby-images/da781/da781d0c56e84ab8e1b227143ab3d05bf573fa23" alt="Windows Form SignalR Real Time 38 Windows Form SignalR Real Time 38"
ทดสอบส่งข้อความจาก Web ไปหา Windows Form
ทดสอบการส่งข้อความจาก Windows Form ไปหา Web
Download Code ตัวอย่าง 2
จากบทความนี้เชื่อว่าเป็นความรู้ใหม่สำหรับใครหลายๆ คน และเมื่อเราได้เรียนรู้กับประโยชน์และการทำงานของมันแล้ว จะเกิดไอเดียต่าง ๆ และมุมมองที่เปลี่ยนไปกับการพัฒนาโปรแกรมหลากหลายประเภท และมันจะเกิดประโยชน์มากมายถ้านำไปใช้ให้ถูกวิธีและวัตถุประสงค์ เพราะไม่ได้เจาะจงว่าจะเป็นในรูปแบบของ Chat เท่านั้น แต่ในหลายๆ Application ต้องการการทำงานที่รวดเร็วในทันที เช่น การทำระบบ Booking Online , การแสดงกราฟ การทำระบบ Notification ไปยัง Client และอื่นๆ
.
|