Я колеблюсь, публикуя этот вопрос, так как в сети есть несколько ответов на один и тот же вопрос. Но мне не повезло, мне ничего не помогает. Для моего веб-приложения мне нужна часть уведомления, и для этого я подумал об использовании SignalR 2 в том же.
Но это не работает. Ниже приведены полные части кода:
==>Hub Class
[HubName("MyHub")]
public class MyHub : Hub
{
public static void Show()
{
IHubContext context = GlobalHost.ConnectionManager.GetHubContext<MyHub>();
context.Clients.All.displayStatus();
}
}
==> Глобальный файл
public class MvcApplication : System.Web.HttpApplication
{
protected void Application_Start()
{
SqlDependency.Start(ConfigurationManager.ConnectionStrings["DefaultConnection"].ConnectionString);
AreaRegistration.RegisterAllAreas();
FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters);
RouteConfig.RegisterRoutes(RouteTable.Routes);
BundleConfig.RegisterBundles(BundleTable.Bundles);
}
protected void Application_End()
{
SqlDependency.Stop(ConfigurationManager.ConnectionStrings["DefaultConnection"].ConnectionString);
}
}
==>Репозиторий
public class DAL
{
public List<DTO.Employee> GetEmployee()
{
List<DTO.Employee> l = new List<DTO.Employee>();
try
{
using (var con = new SqlConnection(ConfigurationManager.ConnectionStrings["DefaultConnection"].ConnectionString))
{
con.Open();
using (var cmd = new SqlCommand("select * from employee", con))
{
cmd.Notification = null;
SqlDependency dep = new SqlDependency(cmd);
dep.OnChange += new OnChangeEventHandler(Dep_OnChange);
using (var drd = cmd.ExecuteReader())
{
while (drd.Read())
{
l.Add(new DTO.Employee()
{
Id = Convert.ToInt64(drd["id"]),
Name = Convert.ToString(drd["name"])
});
}
}
}
}
}
catch { }
return l;
}
private void Dep_OnChange(object sender, SqlNotificationEventArgs e)
{
if (e.Type == SqlNotificationType.Change)
{
MyHub.Show();
}
}
}
==> Стартовый класс Овина
[assembly: OwinStartupAttribute(typeof(SignalR2_App1.Startup))]
namespace SignalR2_App1
{
public partial class Startup
{
public void Configuration(IAppBuilder app)
{
app.MapSignalR();
}
}
}
==> Посмотреть
<script src="~/Scripts/jquery-1.10.2.min.js"></script>
<script src="~/Scripts/jquery.signalR-2.2.0.min.js"></script>
<script src="~/signalr/hubs"></script>
<script type="text/javascript">
$(function () {
var job = $.connection.MyHub;
job.client.displayStatus = function () {
getData();
}
$.connection.hub.start();
getData();
})
function getData() {
$.ajax({
url: "/data/getdata",
contentType: "application/json charset=utf-8",
dataType: "json",
type: "Post",
success: function (result) {
$.each(result, function (e, obj) {
$("#tbldata_tbody").append("<tr><td>" + obj.Id + "</td><td>" + obj.Name + "</td></tr>")
})
},
error: function () {
alert("Error");
}
})
}
</script>
<body>
<table id="tbldata">
<thead>
<tr>
<td>Id</td>
<td>Name</td>
</tr>
</thead>
<tbody id="tbldata_tbody"></tbody>
</table>
==>Action
[HttpPost]
public JsonResult GetData()
{
DAL.DAL O = new DAL.DAL();
return Json(O.GetEmployee());
}
Вы можете скачать весь код по ссылке ниже:
Ссылка на код
GRANT SUBSCRIBE QUERY NOTIFICATIONS To sa
5. Выполнение предыдущего запроса выдавало ошибку:Cannot find the user 'sa', because it does not exist or you do not have permission.
6. Затем мы изменили его на public вместо sa, и все было в порядке. - person Arjun   schedule 05.03.2018