C# signar.net客户端
因此,我尝试连接到c#中的服务,我无法控制此服务,无法在那里更改任何内容,也没有任何文档可以帮助:( 因此,我要做的是将这个JavaScript信号器客户端更改为.net(但不是全部)C# signar.net客户端,c#,asp.net,signalr,signalr.client,C#,Asp.net,Signalr,Signalr.client,因此,我尝试连接到c#中的服务,我无法控制此服务,无法在那里更改任何内容,也没有任何文档可以帮助:( 因此,我要做的是将这个JavaScript信号器客户端更改为.net(但不是全部) $(文档).ready(函数(){ //队列api的URL var queueApi=“/CCMWa/api/v1/queues/”; //信号机连接 $.connection.hub.logging=true; var myHub=$.connection.queueStatistics; //有线事件处理程序
$(文档).ready(函数(){
//队列api的URL
var queueApi=“/CCMWa/api/v1/queues/”;
//信号机连接
$.connection.hub.logging=true;
var myHub=$.connection.queueStatistics;
//有线事件处理程序
myHub.client.onQueueNowDataUpdate=函数(数据){
//警报(数据);
var data=JSON.stringify(数据);
$(“#消息”).append(“服务器:收到onQueueNowDataUpdate ”);
$('#getNowResults')。文本(数据);
};
//有线事件处理程序
myHub.client.onQueueConversationUpdate=函数(数据){
//警报(数据);
var data=JSON.stringify(数据);
$(“#消息”).append(“服务器:接收到onQueueConversationUpdate ”);
$('#getConversationResults')。文本(数据);
};
//有线事件处理程序
myHub.client.connected=函数(){
$(“#消息”).append(“服务器:表示我们已连接”);
};
//有线事件处理程序
myHub.client.reconnected=函数(){
$(“#消息”).append(“ 服务器:表示我们已重新连接”);
};
//开始
$.connection.hub.start()
.done(函数(){
日志消息(“客户端:连接已启动”);
//myHub.server.joinFoo()
//.done(函数(){
//日志消息(“客户端:已发送加入到服务器”);
// })
})
.fail(函数(){
日志消息(“客户端:无法连接到服务器”);
});
$(“#开始显示”)。单击(函数(){
var id=$(“#queueNowId”).val();
myHub.server.startQueueStateMonitor(id)
.done(函数(){
$(“#消息”).append(“ 客户端:addMonitor for”+id+“ ”);
})
.fail(函数(){
$(“#消息”).append(“客户端:无法发送addMonitor ”);
});
});
功能日志消息(消息)
{
$('#messages')。追加(message);
}
$(“#停止”)。单击(函数(){
var id=$(“#queueNowId”).val();
myHub.server.stopQueueStateMonitor(id)
.done(函数(){
$(“#消息”).append(“客户端:删除“+id+”的监视器” ”;
})
.fail(函数(){
$(“#消息”).append(“客户端:无法发送removeMonitor ”);
});
});
$(“#getAll”)。单击(函数(){
var-uri=queueApi;
//警报(uri);
$.get(uri,
功能(项目){
data=JSON.stringify(项目);
$(“#getAllResults”).text(数据);
});
});
$(“#获取详细信息”)。单击(函数(){
var id=$(“#queueDetailsId”).val();
var uri=queueApi+id;
//警报(uri);
$.get(uri,
功能(项目){
data=JSON.stringify(项目);
$('#getDetailsResults')。文本(数据);
});
});
$(“#getNow”)。单击(函数(){
var id=$(“#queueNowId”).val();
var uri=queueApi+id+“/now”;
//警报(uri);
$.get(uri,
功能(项目){
data=JSON.stringify(项目);
$('#getNowResults')。文本(数据);
});
});
$(“#开始转换监视器”)。单击(函数(){
var id=$(“#queueConversationsId”).val();
myHub.server.startQueueConversationMonitor(id)
.done(函数(){
$(“#消息”).append(“客户端:addMonitor for”+id+“ ”);
})
.fail(函数(){
$(“#消息”).append(“客户端:无法发送addMonitor ”);
});
});
$(“#stopConversationMonitor”)。单击(函数(){
var id=$(“#queueConversationsId”).val();
myHub.server.stopQueueConversationMonitor(id)
.done(函数(){
$(“#消息”).append(“客户端:删除“+id+”的监视器” ”;
})
.fail(函数(){
$(“#消息”).append(“客户端:无法发送removeMonitor ”);
});
});
$(“#获取对话”)。单击(函数(){
var id=$(“#queueConversationsId”).val();
var uri=queueApi+id+“/conversations”;
//警报(uri);
$.get(uri,
功能(项目){
data=JSON.stringify(项目);
$('#getConversationResults')。文本(数据);
});
});
});
下面是我目前在c语言中的内容#
使用系统;
使用System.Collections.Generic;
使用System.Linq;
使用系统文本;
使用系统线程;
使用System.Threading.Tasks;
使用Microsoft.AspNet.signal.Client;
使用Microsoft.AspNet.signal.Client.Hubs;
命名空间控制台应用程序3
{
班级计划
{
静态void Main(字符串[]参数)
{
//设置连接
var连接=新的HUB连接(“http://servername/CCMWa/");
connection.TraceLevel=TraceLevels.All;
connection.TraceWriter=Console.Out;
//代理胡
$(document).ready(function () {
//URL of the queues api
var queueApi = "/CCMWa/api/v1/queues/";
//SignalR connection
$.connection.hub.logging = true;
var myHub = $.connection.queueStatistics;
//Wire event handlers
myHub.client.onQueueNowDataUpdate = function (data) {
//alert(data);
var data = JSON.stringify(data);
$('#messages').append('<li>Server: Received onQueueNowDataUpdate</li>');
$('#getNowResults').text(data);
};
//Wire event handlers
myHub.client.onQueueConversationUpdate = function (data) {
//alert(data);
var data = JSON.stringify(data);
$('#messages').append('<li>Server: Received onQueueConversationUpdate</li>');
$('#getConversationResults').text(data);
};
//Wire event handlers
myHub.client.connected = function () {
$('#messages').append('<li>Server: Says we are Connected</li>');
};
//Wire event handlers
myHub.client.reconnected = function () {
$('#messages').append('<li>Server: Says we are Reconnected</li>');
};
//Start
$.connection.hub.start()
.done(function () {
logMessage("Client: Connection Started");
//myHub.server.joinFoo()
// .done(function () {
// logMessage("Client: Sent Join to Server");
// })
})
.fail(function () {
logMessage("Client: Could not connect to server");
});
$("#startNow").click(function () {
var id = $("#queueNowId").val();
myHub.server.startQueueStateMonitor(id)
.done(function () {
$('#messages').append('<li>Client: addMonitor for ' + id + '</li>');
})
.fail(function () {
$('#messages').append('<li>Client: failed to send addMonitor</li>');
});
});
function logMessage(message)
{
$('#messages').append(message);
}
$("#stopNow").click(function () {
var id = $("#queueNowId").val();
myHub.server.stopQueueStateMonitor(id)
.done(function () {
$('#messages').append('<li>Client: removeMonitor for ' + id + '</li>');
})
.fail(function () {
$('#messages').append('<li>Client: failed to send removeMonitor</li>');
});
});
$("#getAll").click(function () {
var uri = queueApi;
//alert(uri);
$.get(uri,
function (items) {
data = JSON.stringify(items);
$("#getAllResults").text(data);
});
});
$("#getDetails").click(function () {
var id = $("#queueDetailsId").val();
var uri = queueApi + id;
//alert(uri);
$.get(uri,
function (items) {
data = JSON.stringify(items);
$('#getDetailsResults').text(data);
});
});
$("#getNow").click(function () {
var id = $("#queueNowId").val();
var uri = queueApi + id + "/now";
//alert(uri);
$.get(uri,
function (items) {
data = JSON.stringify(items);
$('#getNowResults').text(data);
});
});
$("#startConversationMonitor").click(function () {
var id = $("#queueConversationsId").val();
myHub.server.startQueueConversationMonitor(id)
.done(function () {
$('#messages').append('<li>Client: addMonitor for ' + id + '</li>');
})
.fail(function () {
$('#messages').append('<li>Client: failed to send addMonitor</li>');
});
});
$("#stopConversationMonitor").click(function () {
var id = $("#queueConversationsId").val();
myHub.server.stopQueueConversationMonitor(id)
.done(function () {
$('#messages').append('<li>Client: removeMonitor for ' + id + '</li>');
})
.fail(function () {
$('#messages').append('<li>Client: failed to send removeMonitor</li>');
});
});
$("#getConversations").click(function () {
var id = $("#queueConversationsId").val();
var uri = queueApi + id + "/conversations";
//alert(uri);
$.get(uri,
function (items) {
data = JSON.stringify(items);
$('#getConversationResults').text(data);
});
});
});
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading;
using System.Threading.Tasks;
using Microsoft.AspNet.SignalR.Client;
using Microsoft.AspNet.SignalR.Client.Hubs;
namespace ConsoleApplication3
{
class Program
{
static void Main(string[] args)
{
//Set connection
var connection = new HubConnection("http://servername/CCMWa/");
connection.TraceLevel = TraceLevels.All;
connection.TraceWriter = Console.Out;
//Make proxy to hub based on hub name on server
var myHub = connection.CreateHubProxy("queueStatistics");
//Start connection
connection.Start().ContinueWith(task => {
if (task.IsFaulted) {
Console.WriteLine("There was an error opening the connection:{0}",
task.Exception.GetBaseException());
} else {
Console.WriteLine("Connected");
}
}).Wait();
myHub.Invoke<string>("startQueueStateMonitor", "445cb4e7-88a7-47d4-bb13-e8b40854f4a5").ContinueWith(task =>
{
if (task.IsFaulted) {
Console.WriteLine("There was an error calling send: {0}",
task.Exception.GetBaseException());
} else {
Console.WriteLine("hello");
Console.WriteLine(task.Result);
}
});
myHub.On("connected", () => Console.WriteLine(" server said connected"));
myHub.On<string>("onQueueNowDataUpdate", data => { Console.WriteLine(data); });
//myHub.On<string>("onQueueConversationUpdate", data => { Console.WriteLine(data); });
Console.Read();
connection.Stop();
}
}
}
08:10:06.4207699 - null - ChangeState(Disconnected, Connecting)
08:10:06.7977915 - 66fd7caa-b3f8-4297-9c83-5a2dd5c9e72e - SSE: GET http://servername/CCMWa/signalr/connect?transport=serverSentEvents&connectionToken=n6c1mQ6E22kyyqrALVJ2LK2nlWqKQbFZmJOLs9flk75jhvbwPPddp5wGcBMg_9VGeXtWLlqmjETWUaT_de8KLiODqxZG3ZAa6KzHqM9Ik4cuS0CuWnz8YspN79wPsF3l0&connectionData=[{"Name":"queueStatistics"}]
08:10:06.8617951 - 66fd7caa-b3f8-4297-9c83-5a2dd5c9e72e - ChangeState(Connecting, Connected) Connected
08:10:06.8667954 - 66fd7caa-b3f8-4297-9c83-5a2dd5c9e72e - SSE: OnMessage(Data: initialized)
08:10:07.0518060 - 66fd7caa-b3f8-4297-9c83-5a2dd5c9e72e - OnMessage({"I":"0"}) hello
08:10:07.1168097 - 66fd7caa-b3f8-4297-9c83-5a2dd5c9e72e - SSE: OnMessage(Data: {"C":"Gg,0|Ix,1|Iy,0|Iz,0","M":[{"H":"queueStatistics","M":"connected","A":[]}]}) server said connected 08:10:07.1328106 - 66fd7caa-b3f8-4297-9c83-5a2dd5c9e72e - SSE: OnMessage(Data: {"C":"Gg,0|Ix,1|Iy,1|Iz,0|Hf,13A2","G":"JbB1ER_V5dMWm0Cxe5LFQluULoB69DHmULrH6WM_nM2Dbsk-y-qGne7GwpaUSUlSfdS1KNUjuVgU-Femd 3IucV56Iw545IKDvlxNXL7pmdcGtvZbAIjMKIjXbEdTLSMAkxGGJZDhr4nD4KWzpHMQtA2","M":[]}) 08:10:07.1338107 - 66fd7caa-b3f8-4297-9c83-5a2dd5c9e72e - SSE: OnMessage(Data: {"C":"Gg,0|Ix,2|Iy,1|Iz,0|Hf,13A2","M":[{"H":"queueStatistics","M":"onQueueNowDataUpdate","A":[{"configData":{"Id":"445cb 4e7-88a7-47d4-bb13-e8b40854f4a5","Name":"Dutch","Reporting":"P503","MediaType":0,"MediaServer":null,"MediaServerId":"00000000-0000-0000-0000-000000000000","NowStatisticsUrl":null,"StatisticsHubName":" queueStatistics","Links":[],"Url":null},"Status":"ACD","LongestWaiting":0.0,"Acd":0,"NonAcd":0,"Out":0,"Unavailable":1,"Offered":3,"Handled":3,"Abandoned":0,"Interflow":0,"Requeue":0,"ServiceLevel":10 0,"AgentsIdle":2,"ItemsWaiting":0,"QueueOpen":false,"AgentsLoggedIn":0,"AgentsAvailable":2,"EstimatedWaitTime":0.0,"AverageHandlingTime":0,"DetailsUrl":null}]}]})
08:10:07.1878138 - 66fd7caa-b3f8-4297-9c83-5a2dd5c9e72e - OnError(Newtonsoft.Json.JsonReaderException: Error reading string. Unexpected token: StartObject. Path ''. at Newtonsoft.Json.JsonReader.ReadAsStringInternal() at Newtonsoft.Json.Linq.JTokenReader.ReadAsString() at Newtonsoft.Json.Serialization.JsonSerializerInternalReader.ReadForType(JsonReader reader, JsonContract contract, Boolean hasConverter) at Newtonsoft.Json.Serialization.JsonSerializerInternalReader.Deserialize(JsonReader reader, Type objectType, Boolean checkAdditionalContent) at Newtonsoft.Json.JsonSerializer.DeserializeInternal(JsonReader reader, Type objectType) at Newtonsoft.Json.JsonSerializer.Deserialize(JsonReader reader, Type objectType) at Newtonsoft.Json.Linq.JToken.ToObject(Type objectType, JsonSerializer jsonSerializer) at Newtonsoft.Json.Linq.JToken.ToObject[T](JsonSerializer jsonSerializer) at Microsoft.AspNet.SignalR.Client.Hubs.HubProxyExtensions.Convert[T](JToken obj, JsonSerializer serializer) at Microsoft.AspNet.SignalR.Client.Hubs.HubProxyExtensions.<>c__DisplayClass6`1.<On>b__4(IList`1 args) at Microsoft.AspNet.SignalR.Client.Hubs.Subscription.OnReceived(IList`1 data) at Microsoft.AspNet.SignalR.Client.Hubs.HubProxy.InvokeEvent(String eventName, IList`1 args) at Microsoft.AspNet.SignalR.Client.Hubs.HubConnection.OnMessageReceived(JToken message) at Microsoft.AspNet.SignalR.Client.Connection.Microsoft.AspNet.SignalR.Client.IConnection.OnReceived(JToken message) at Microsoft.AspNet.SignalR.Client.Transports.TransportHelper.ProcessResponse(IConnection connection, String response, Boolean& timedOut, Boolean& disconnected))
08:10:08.0928655 - 66fd7caa-b3f8-4297-9c83-5a2dd5c9e72e - SSE: OnMessage(Data: {"C":"Gg,0|Ix,2|Iy,1|Iz,0|Hf,13A3","M":[{"H":"queueStatistics","M":"onQueueNowDataUpdate","A":[{"configData":{"Id":"445cb 4e7-88a7-47d4-bb13-e8b40854f4a5","Name":"Dutch","Reporting":"P503","MediaType":0,"MediaServer":null,"MediaServerId":"00000000-0000-0000-0000-000000000000","NowStatisticsUrl":null,"StatisticsHubName":" queueStatistics","Links":[],"Url":null},"Status":"ACD","LongestWaiting":0.0,"Acd":0,"NonAcd":0,"Out":0,"Unavailable":1,"Offered":3,"Handled":3,"Abandoned":0,"Interflow":0,"Requeue":0,"ServiceLevel":10 0,"AgentsIdle":2,"ItemsWaiting":0,"QueueOpen":false,"AgentsLoggedIn":0,"AgentsAvailable":2,"EstimatedWaitTime":0.0,"AverageHandlingTime":0,"DetailsUrl":null}]}]})
08:10:08.1308677 - 66fd7caa-b3f8-4297-9c83-5a2dd5c9e72e - OnError(Newtonsoft.Json.JsonReaderException: Error reading string. Unexpected token: StartObject. Path ''. at Newtonsoft.Json.JsonReader.ReadAsStringInternal() at Newtonsoft.Json.Linq.JTokenReader.ReadAsString() at Newtonsoft.Json.Serialization.JsonSerializerInternalReader.ReadForType(JsonReader reader, JsonContract contract, Boolean hasConverter) at Newtonsoft.Json.Serialization.JsonSerializerInternalReader.Deserialize(JsonReader reader, Type objectType, Boolean checkAdditionalContent) at Newtonsoft.Json.JsonSerializer.DeserializeInternal(JsonReader reader, Type objectType) at Newtonsoft.Json.JsonSerializer.Deserialize(JsonReader reader, Type objectType) at Newtonsoft.Json.Linq.JToken.ToObject(Type objectType, JsonSerializer jsonSerializer) at Newtonsoft.Json.Linq.JToken.ToObject[T](JsonSerializer jsonSerializer) at Microsoft.AspNet.SignalR.Client.Hubs.HubProxyExtensions.Convert[T](JToken obj, JsonSerializer serializer) at Microsoft.AspNet.SignalR.Client.Hubs.HubProxyExtensions.<>c__DisplayClass6`1.<On>b__4(IList`1 args) at Microsoft.AspNet.SignalR.Client.Hubs.Subscription.OnReceived(IList`1 data) at Microsoft.AspNet.SignalR.Client.Hubs.HubProxy.InvokeEvent(String eventName, IList`1 args) at Microsoft.AspNet.SignalR.Client.Hubs.HubConnection.OnMessageReceived(JToken message) at Microsoft.AspNet.SignalR.Client.Connection.Microsoft.AspNet.SignalR.Client.IConnection.OnReceived(JToken message) at Microsoft.AspNet.SignalR.Client.Transports.TransportHelper.ProcessResponse(IConnection connection, String response, Boolean& timedOut, Boolean& disconnected))`
myHub.On<string>("onQueueNowDataUpdate", data => { Console.WriteLine(data); });
"M": [
{
"H": "queueStatistics",
"M": "onQueueNowDataUpdate",
"A": [
{
"configData": {
"M": "Foobar"
{
"H": "queueStatistics",
"M": "onQueueNowDataUpdate",
"A": [
{
"configData": {
"Id": "445cb 4e7-88a7-47d4-bb13-e8b40854f4a5",
"Name": "Dutch",
"Reporting": "P503",
"MediaType": 0,
"MediaServer": null,
"MediaServerId": "00000000-0000-0000-0000-000000000000",
"NowStatisticsUrl": null,
"StatisticsHubName": " queueStatistics",
"Links": [
],
"Url": null
},
"Status": "ACD",
"LongestWaiting": 0.0,
"Acd": 0,
"NonAcd": 0,
"Out": 0,
"Unavailable": 1,
"Offered": 3,
"Handled": 3,
"Abandoned": 0,
"Interflow": 0,
"Requeue": 0,
"ServiceLevel": 100,
"AgentsIdle": 2,
"ItemsWaiting": 0,
"QueueOpen": false,
"AgentsLoggedIn": 0,
"AgentsAvailable": 2,
"EstimatedWaitTime": 0.0,
"AverageHandlingTime": 0,
"DetailsUrl": null
}
]
}
public class ConfigData
{
public string Id { get; set; }
public string Name { get; set; }
public string Reporting { get; set; }
public int MediaType { get; set; }
public object MediaServer { get; set; }
public string MediaServerId { get; set; }
public object NowStatisticsUrl { get; set; }
public string StatisticsHubName { get; set; }
public List<object> Links { get; set; }
public object Url { get; set; }
}
public class A
{
public ConfigData configData { get; set; }
public string Status { get; set; }
public double LongestWaiting { get; set; }
public int Acd { get; set; }
public int NonAcd { get; set; }
public int Out { get; set; }
public int Unavailable { get; set; }
public int Offered { get; set; }
public int Handled { get; set; }
public int Abandoned { get; set; }
public int Interflow { get; set; }
public int Requeue { get; set; }
public int ServiceLevel { get; set; }
public int AgentsIdle { get; set; }
public int ItemsWaiting { get; set; }
public bool QueueOpen { get; set; }
public int AgentsLoggedIn { get; set; }
public int AgentsAvailable { get; set; }
public double EstimatedWaitTime { get; set; }
public int AverageHandlingTime { get; set; }
public object DetailsUrl { get; set; }
}
public class RootObject
{
public string H { get; set; }
public string M { get; set; }
public List<A> A { get; set; }
}
myHub.On<RootObject>("onQueueNowDataUpdate", data => { <<Do something with RootData instance here>> });