- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我的应用程序是一个带有数据库的 ASP NET MVC 5 应用程序。我的数据库中有一个名为 Logs 的表。我希望我的应用程序通知所有客户关于该表的新插入,所以我决定使用 SignalR + SQLTableDependency。我读了很多例子,把它们结合起来(但我对所有这些东西都很陌生),这就是我最终得到的:
我的日志实体类:
public class Log
{
public Log(int visitRequestId, string requestNumber)
{
Created = DateTime.Now;
VisitRequestId = visitRequestId;
RequestNumber = requestNumber;
}
public Log()
{
}
[DatabaseGenerated(DatabaseGeneratedOption.Identity), Key]
public int Id { get; set; }
[Required]
public int VisitRequestId { get; set; }
public string RequestNumber { get; set; }
public DateTime Created { get; set; }
public string Message { get; set; }
}
我的单例服务类:
public class JournalMessangesService
{
private static readonly Lazy<JournalMessangesService> _instance = new Lazy<JournalMessangesService>(()=>new JournalMessangesService(GlobalHost.ConnectionManager.GetHubContext<JournalMessageHub>().Clients));
private static SqlTableDependency<Log> _tableDependency;
private IHubConnectionContext<dynamic> Clients { get; }
public static JournalMessangesService Instance => _instance.Value;
private JournalMessangesService(IHubConnectionContext<dynamic> clients)
{
Clients = clients;
_tableDependency = new SqlTableDependency<Log>(
ConfigurationManager.ConnectionStrings["EFDbContext"].ConnectionString,
"Logs"
);
_tableDependency.OnChanged += SqlTableDependency_Changed;
_tableDependency.OnError += SqlTableDependency_OnError;
_tableDependency.Start();
}
private void SqlTableDependency_OnError(object sender, ErrorEventArgs e)
{
throw e.Error;
}
private void SqlTableDependency_Changed(object sender, RecordChangedEventArgs<Log> e)
{
if (e.ChangeType != ChangeType.None)
{
BroadcastJournalMessage(e.Entity);
}
}
private void BroadcastJournalMessage(Log log)
{
Clients.All.updateMessage(log);
}
public IEnumerable<Log> GetAllLogs()
{
var logEntries = new List<Log>();
var connString = ConfigurationManager.ConnectionStrings["EFDbcontext"].ConnectionString;
using (var connection = new SqlConnection(connString))
{
connection.Open();
using (var command = connection.CreateCommand())
{
command.CommandText = "SELECT * FROM [Logs]";
using (var dataReader = command.ExecuteReader() )
{
while (dataReader.Read())
{
var id = dataReader.GetInt32(dataReader.GetOrdinal("VisitRequestId"));
var reqNum = dataReader.GetString(dataReader.GetOrdinal("RequestNumber"));
var created = dataReader.GetDateTime(dataReader.GetOrdinal("Created"));
var message = dataReader.GetString(dataReader.GetOrdinal("Message"));
logEntries.Add(new Log(id, reqNum) {Created = created, Message = message});
}
}
}
}
return logEntries;
}
#region IDisposable Support
private bool disposedValue = false; // To detect redundant calls
protected virtual void Dispose(bool disposing)
{
if (!disposedValue)
{
if (disposing)
{
_tableDependency.Stop();
}
disposedValue = true;
}
}
~JournalMessangesService()
{
Dispose(false);
}
public void Dispose()
{
Dispose(true);
GC.SuppressFinalize(this);
}
#endregion
}
我的 Hub 类:
[HubName("journalMessageHub")]
public class JournalMessageHub : Hub
{
private readonly JournalMessangesService _journalMessangesService;
public JournalMessageHub() : this(JournalMessangesService.Instance) { }
public JournalMessageHub(JournalMessangesService journalMessangesService)
{
_journalMessangesService = journalMessangesService;
}
public IEnumerable<Log> GetAllLogs()
{
return _journalMessangesService.GetAllLogs();
}
}
我还在我的 Startup.cs 中添加了 app.MapSignalR();
。
这是我的 html View :
<script src="~/Scripts/jquery.signalR-2.2.2.js"></script>
<script src="/signalr/hubs" type="text/javascript"></script>
<script src="~/Scripts/noty.js"></script>
<script type="text/javascript">
$(document).ready(function() {
var journalHub = $.connection.journalMessageHub;
journalHub.client.updateMessage = function(log) {
new Noty({
text: log.Message,
type: 'warning',
theme: 'metroui',
timeout: '2000'
}).show();
};
$.connection.hub.start().done(function () {
journalHub.server.getAllLogs().done(function(data) {
console.log('data length: ' + data.length);
});
journalHub.client.updateMessage();
});
});
我想要的只是在我的日志数据库表中有插入时收到通知(通过 Noty.js,但这并不重要)。但是用我的代码我没有得到那个结果 - 通知被触发,但它们不包含任何日志数据,只有一些“未定义”的东西。
另一个问题是我不想在页面刷新时触发通知 - 仅当数据库更改时。
我认为我对代码的 javascript 部分有一些误解,但它可以是任何其他内容 - 我对所有这些网络内容都是全新的。
请帮助我,我无法再阅读所有那些 StockTicker 示例,它们对我不起作用。
非常感谢您的帮助。
最佳答案
也许像我这样随便的穷人会找出这篇文章,这会对他有所帮助。事实证明,我只是错过了 Microsoft.AspNet.SignalR.Client 包。我不认为我必须手动添加它。我添加了它,一切都开始像魅力一样工作。
关于c# - SignalR SQLTableDependency 数据库更改跟踪问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45458709/
我想知道如何存储在调用时可以触发到连接的客户端的变量服务器端? 我使用并发字典来跟踪连接 GUID 并想知道我是否可以在服务器上存储字符串或其他数据类型,例如最后 10 条消息,因此当出现新连接时,客
无法让 SignalR 在我的机器上工作(使用 IE9)。在输入一些文本并单击提交时,文本未按预期列出。另外,我希望从多个浏览器实例更新列表,但它不会发生。没有错误。有人可以帮忙吗? C# names
找到后this update围绕与组的通信,似乎一个组与集线器名称无关。如果这是正确的(如果我弄错了,请告诉我)集线器有什么方法可以访问另一个集线器的组,或者更好地拥有某种全局组? 我的问题是我有一个
抽象的 嗨,我在考虑是否可以使用 SignalR 发送消息。假设客户端断开连接,但最终在很短的时间内(例如 3 秒)重新连接。客户端会在断开连接时收到所有发送给他的消息吗? 例如,让我们考虑 Long
我正在为中等负载的 Web 应用程序评估 SignalR。 我们期望大约 500 条消息/秒,这对 SignalR 来说应该不是问题。 但是,我们担心此解决方案的可靠性。我们的环境有一个有问题的网络,
我有以下JS工作: var chat = $.connection.appHub; 我的应用程序有一个单一的中心AppHub,它处理两种类型的通知-Chat和Other。我使用一个集线器,因为我需要一
我升级到.NET 4.5,现在SignalR似乎坚持要在Firefox / Chrome中使用WebSockets-即使我只是在没有WebSocket Server的Windows 7上使用。 该请求
您能否在服务器端辨别给定的SignalR连接使用哪种传输方法? (WebSocket,SSE,长时间轮询等?) 最佳答案 在集线器内部,您可以通过查看请求的查询字符串来检测正在使用的传输: Conte
我在MVC4应用程序中使用Visual Studio 2012 Ultimate RC,SignalR 0.5.1和Jquery 1.7.2。 我看过:MVC4 SignalR "signalr/hu
假设我的网络连接中断了几秒钟,并且我错过了一些 SignalR 服务器推送的消息。 当我重新获得网络连接时,我错过的消息是否会丢失?或者当我重新连接时 signalR 会处理它们并将它们推出吗? 如果
如果我有一个 signalR 集线器,它向所有具有相当大的有效负载或私有(private)信息的客户端发送消息,那么所有连接到该集线器的客户端(同一组的一部分)是否都会收到消息,即使它们没有订阅客户端
如果我有一个 signalR 集线器,它向所有具有相当大的有效负载或私有(private)信息的客户端发送消息,那么所有连接到该集线器的客户端(同一组的一部分)是否都会收到消息,即使它们没有订阅客户端
谁能让我知道 SignalR 内部是如何以高级方式工作的? 我猜测它正在使用 Response.Flush 刷新数据,并且在客户端以一定的时间间隔发送 Ajax 请求。正确吗? 最佳答案 不,Sign
我正在使用 Microsoft SignalR 向浏览器推送通知。这些通知是由其他浏览器的操作触发的。我想做一个有时发送通知的后台任务。例如,在 12:45:21,我想向所有连接的用户发出通知,即使他
我的 SignalR 存在以下问题,用户从移动设备访问我的网站。 问题在于,当手机锁定或用户转到另一个应用程序时,会在服务器上触发 Disconnect() 方法(我尝试向服务器发送消息并等待它通过
如果我使用 SignalR 发送消息,客户端是否可能收不到消息?您如何验证通信中是否出现任何错误?我想在发送服务器通知后将消息发送回服务器,但有没有更好的方法? 最佳答案 是的,客户端可能没有收到消息
Web 服务器如何使用 SignalR 同步调用客户端上的方法?这里的关键部分是服务器应该等待客户端将数据发送回服务器才能继续? 基本上,我希望将客户端方法调用视为 WCF 服务请求。调用客户端并等待
我正在尝试调试 SignalR 连接问题,虽然我知道如何启用客户端日志记录,但我不知道如何启用服务器端日志记录。它似乎没有将任何内容记录到控制台。 我试过在 HubConfiguration 中使用
如果 SignalR 服务器的内部缓冲区溢出,则它似乎可以在将消息发送到客户端之前丢弃消息(请参阅 https://github.com/SignalR/SignalR/issues/2075 )。目
我在 Blazor 服务器端应用程序中使用 SignalR。我将 Microsoft.AspNetCore.SignalR.Client Nuget 包 (v5.0.11) 添加到项目中,并使用以下代
我是一名优秀的程序员,十分优秀!