- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试让 PushSharp(2.0.4.0?)作为 Windows 服务运行。每次服务运行并执行push.QueueNotification() 时,小程序都会挂起对stopAPNS(push) 的调用。当我运行类似的代码作为控制台应用程序时,它每次都运行良好(即我正在收到推送通知)。控制台应用程序基于 PushSharp.Sample 项目。
有趣的是,如果我启动/停止我的小程序而不执行任何push.QueueNotification()调用,我的服务将正确退出。在其他情况下,OnStop() 中对 stopAPNS(push) 的调用不会挂起。我想这是有道理的......队列是空的
我在.NET 4.0和4.5下编译了PushSharp项目。在每种情况下,我都会得到相同的行为。
我在下面提供了代码的清理版本。
对于为什么当作为 Windows 服务运行时,push.StopAllServices(true) 调用会挂起有什么想法吗?
谢谢。
public class PushNoteService : System.ServiceProcess.ServiceBase
{
// Initialize global instance of PushBroker service
private PushBroker push = new PushBroker();
#region Constructor
public PushNoteService()
{
// This call is required by the Windows.Forms Component Designer.
InitializeComponent();
// TODO: Add any initialization after the InitComponent call
}
#endregion
#region Component Designer generated code
// The main entry point for the process
static void Main()
{
System.ServiceProcess.ServiceBase[] ServicesToRun;
// More than one user Service may run within the same process. To add
// another service to this process, change the following line to
// create a second service object. For example,
//
// ServicesToRun = new System.ServiceProcess.ServiceBase[] {new PushNoteService(), new MySecondUserService()};
//
ServicesToRun = new System.ServiceProcess.ServiceBase[] { new PushNoteService() };
System.ServiceProcess.ServiceBase.Run(ServicesToRun);
}
#endregion
#region OnStart
/// <summary>
/// Set things in motion so your service can do its work.
/// </summary>
protected override void OnStart(string[] args)
{
YYLog.Log.Instance.Info("Starting service.");
timer2.Enabled = true;
YYLog.Log.Instance.Info("Starting APNS.");
startAPNS(push);
}
#endregion
#region OnStop
/// <summary>
/// Stop this service.
/// </summary>
protected override void OnStop()
{
YYLog.Log.Instance.Info("Stopping service.");
// Add code here to perform any tear-down necessary to stop your service.
timer2.Enabled = false;
YYLog.Log.Instance.Info("Stopping APNS.");
stopAPNS(push);
// some clean up.
push = null;
YYLog.Log.Instance.Info("Service stopped.");
}
#endregion
#region Acess Methods
/// <summary>
/// On Timer_Elasped events, websites are accessed to check status.
/// </summary>
/// <param name="sender">Sender.</param>
/// <param name="e">E.</param>
private void timer2_Elapsed(object sender, System.Timers.ElapsedEventArgs e)
{
int count = checkForPushRequest();
YYLog.Log.Instance.Info(" Count: " + count.ToString());
if (count > 0)
{
stopAPNS(push);
}
}
private int checkForPushRequest()
{
YYLog.Log.Instance.Info("Processing push notifications...");
int count = 0;
// Get the ConnectionStrings collection.
ConnectionStringSettings connections = ConfigurationManager.ConnectionStrings["MyDB"];
using (SqlConnection conn = new SqlConnection(connections.ConnectionString))
{
conn.Open();
SqlCommand cmd = new SqlCommand("MySP", conn);
cmd.CommandType = System.Data.CommandType.StoredProcedure;
SqlDataReader dr = cmd.ExecuteReader(System.Data.CommandBehavior.CloseConnection);
while (dr.Read())
{
// increment counter
count++;
int badgeNumber = 0;
string deviceToken = Convert.ToString(dr[dr.GetOrdinal("DeviceToken")]);
string alertMessage = Convert.ToString(dr[dr.GetOrdinal("AlertMessage")]);
if (!dr.IsDBNull(dr.GetOrdinal("BadgeNumber")))
{
badgeNumber = Convert.ToInt16(dr[dr.GetOrdinal("BadgeNumber")]);
}
string soundFile = Convert.ToString(dr[dr.GetOrdinal("SoundFile")]);
// Send out the notification to APNS
YYLog.Log.Instance.Trace(" Sending notification to " + deviceToken);
sendPush(deviceToken, alertMessage, badgeNumber, soundFile);
}
dr.Close();
}
return count;
}
private void sendPush(string DeviceToken, string AlertMessage, int BadgeNumber, string SoundFile)
{
push.QueueNotification(new AppleNotification()
.ForDeviceToken(DeviceToken)
.WithAlert(AlertMessage)
.WithBadge(BadgeNumber)
.WithSound(SoundFile));
}
private void startAPNS(PushBroker push)
{
//Wire up the events for all the services that the broker registers
push.OnNotificationSent += NotificationSent;
push.OnChannelException += ChannelException;
push.OnServiceException += ServiceException;
push.OnNotificationFailed += NotificationFailed;
push.OnDeviceSubscriptionExpired += DeviceSubscriptionExpired;
push.OnDeviceSubscriptionChanged += DeviceSubscriptionChanged;
push.OnChannelCreated += ChannelCreated;
push.OnChannelDestroyed += ChannelDestroyed;
string appleCertFileName = System.Configuration.ConfigurationManager.AppSettings["APNS_Certificate"];
var appleCert = File.ReadAllBytes(appleCertFileName);
string appleCertPassword = System.Configuration.ConfigurationManager.AppSettings["APNS_Certificate_Password"];
bool productionMode = bool.Parse(System.Configuration.ConfigurationManager.AppSettings["APNS_Production_Mode"]);
push.RegisterAppleService(new ApplePushChannelSettings(productionMode, appleCert, appleCertPassword)); //Extension method
}
private void stopAPNS(PushBroker push)
{
YYLog.Log.Instance.Info("Waiting for Queue to Finish...");
//Stop and wait for the queues to drains
push.StopAllServices(true);
YYLog.Log.Instance.Info("Queue Finished");
}
#region Events
private void DeviceSubscriptionChanged(object sender, string oldSubscriptionId, string newSubscriptionId, INotification notification)
{
//Currently this event will only ever happen for Android GCM
YYLog.Log.Instance.Info("Device Registration Changed: Old-> " + oldSubscriptionId + " New-> " + newSubscriptionId + " -> " + notification);
}
private void NotificationSent(object sender, INotification notification)
{
YYLog.Log.Instance.Info("Sent: " + sender + " -> " + notification);
}
private void NotificationFailed(object sender, INotification notification, Exception notificationFailureException)
{
YYLog.Log.Instance.Error("Failure: " + sender + " -> " + notificationFailureException.Message + " -> " + notification);
}
private void ChannelException(object sender, IPushChannel channel, Exception exception)
{
YYLog.Log.Instance.Error("Channel Exception: " + sender + " -> " + exception);
}
private void ServiceException(object sender, Exception exception)
{
YYLog.Log.Instance.Error("Channel Exception: " + sender + " -> " + exception);
}
private void DeviceSubscriptionExpired(object sender, string expiredDeviceSubscriptionId, DateTime timestamp, INotification notification)
{
YYLog.Log.Instance.Info("Device Subscription Expired: " + sender + " -> " + expiredDeviceSubscriptionId);
}
private void ChannelDestroyed(object sender)
{
YYLog.Log.Instance.Info("Channel Destroyed for: " + sender);
}
private void ChannelCreated(object sender, IPushChannel pushChannel)
{
YYLog.Log.Instance.Info("Channel Created for: " + sender);
}
#endregion
#endregion
}
最佳答案
我们有一个 Web 应用程序,但我认为解决方案可以是相同的。我们花了一整天的时间来猜测这个问题!最后是Newtonsoft.Json版本错误我们的解决方案中的一些项目依赖于该库的旧版本,因此我们运气不好,在 Web 项目的/bin 文件夹中获得了错误的版本。
关于push-notification - PushSharp 的 StopAllServices() 作为 Windows 服务挂起,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16713546/
我遵循了提供的文档 here并且可以在 Android N 及更高版本上成功创建通知组。然而,我遇到的问题是 Android Oreo,每个发布到群组的通知都会为群组播放声音。 这很烦人,因为我只想播
单点触控 当应用程序返回前台时,我需要激活的 ViewController 来了解这一点。 是否有一个事件或覆盖我可以用来确定 View 被带到前台。 我确实找到了“WillEnterForegrou
我正在尝试在我的项目中创建一个通知系统。 这些是我已经完成的步骤: 1-php artisan notifications:table 2-php artisan migrate 3-php arti
我想知道如何批量发送推送通知。我们从以下3个主要模式来看问题: 一次API调用->一条消息->发送给指定用户 一次 API 调用 -> 一条消息 -> 传递给许多不同的用户(由 id 指定) 一个 A
我想在用户点击保存或删除按钮时显示通知。 Here is what i use for it.(Kendo notification) 我认为我的 CSS 部分有问题,我更改了很多东西但我仍然在原地。
在我的测试代码中,我使用了 notification.flags |= Notification.DEFAULT_SOUND; notification.flags |= No
当 Redis Sentinel 通知事件时,它不会提供 Redis 主节点的名称。 配置摘录: # sentinel notification-script # # Call the speci
Microsoft Exchange 引入了流通知作为 Exchange 2010 中拉/推通知的替代方法。有关流的基本介绍可以在此 msdn article 上找到。和 blog 但是,我无法弄清楚
我在理解WebExtensions notification.onClicked事件的文档时遇到问题。 最终,我要在单击通知时将通知文本复制到剪贴板。但是,现在我在理解回调内容或必须在其中插入noti
我即将实现ionic-native Push Notifications .这可以在浏览器中运行吗?还是我需要安装 iOS/Android 模拟器? 最佳答案 除非您使用 Phonegap 推送服务器
Safari 12.1 是否支持服务 worker PWA 推送通知?我试过这个 demo在 iOS 上,但它仍然不适合我。 有机会得到它们吗?谢谢。 最佳答案 目前没有关于此功能的通信...Appl
我遇到了一个奇怪的错误。一段时间以来,这种崩溃一直在我的 Fabric 中出现 致命异常:android.app.RemoteServiceException:startForeground 的错误通
我正在使用 Google Cloud Messaging 在 iOS 应用中接收推送通知。为了了解该系统的可靠性,我进行了两项测试。1.当应用程序处于前台时接收通知 下面称为curl 12. 当应用程
String ns = Context.NOTIFICATION_SERVICE; NotificationManager mNotificationManager = (NotificationM
我想在我的 Android 应用程序中使用 Notification,但我不知道 Android 中的 Notification 和 Push Notification 有什么区别. 我在网上搜索了这
我有两个模型之间的多对多关系: 用户 namespace App\Models; class User extends Model { use HasApiTokens, Notifiable
我在 App Store 中有一个 iPad 应用程序,其逻辑主要依赖于本地通知。换句话说,应用程序内部发生的很多事情都是由委托(delegate)方法应用程序 didReceiveLocalNoti
我知道如何制作每天在特定时间触发的本地通知。但是如何为每个通知更改 UNMutableNotificationContent.Body? 现在它只是一遍又一遍地显示相同的文本。 我正在为 iOS 10
请问,是否可以在没有用户 ID 的情况下发送推送通知?假设我们想向所有下载了我们应用程序的用户发送推送消息。或者出于安全原因,用户 ID 不能存储在数据库中(或在应用程序中使用)。 最佳答案 不管怎样
我在使用 Twilio notify 发送通知时遇到异常。 当我在使用相同的 Twilio NotificationCreator bean 发送 SMS 后发送通知时,如果我发送通知而不发送 SMS
我是一名优秀的程序员,十分优秀!