实用技巧

关注公众号 jb51net

关闭
首页 > 网络编程 > ASP.NET > 实用技巧 > .NET对接极光消息推送

.NET对接极光消息推送的实现方法

作者:追逐时光者

很多手机APP会不定时的给用户推送消息,本文主要介绍了.NET对接极光消息推送,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

什么是APP消息推送?

  很多手机APP会不定时的给用户推送消息,例如一些新闻APP会给用户推送用户可能感兴趣的新闻,或者APP有更新了,会给用户推送是否选择更新的消息等等,这就是所谓的“消息推送”。

更多APP消息推送的介绍可查阅该篇文章:十分钟带你了解APP消息推送(Push)👉

如下是我们日常生活中常见的一些APP消息推送示例:

强营销类:

直接把营销力度,营销模式以一种叫卖式方式展现出来,目的通过优惠,时效性勾起用户贪小便宜的心理,好奇心理,如下所示:

强关联性:

在信息爆炸的时代,大脑会自动筛选对自己有价值的信息和没价值的信息,如果在一条信息中有@你,您之类的言语,大脑会自动识别,使用直接关联的技巧在于巧用“你”相关的字眼。

强热点:热点对眼球的吸引程度不言而喻,但是追热点这些事情呢,新闻资讯类由于其自身的属性,在热点话题这一块有天然优势,而其他类型的APP对热点的解读和追踪多少差强人意,尤其文案书写这块,没有杜蕾斯这样的能力,就别强撩用户,适得其反反而显得没水平。

强话题性:

营销界有这么一句话,没有违和感就创造不了传播,不出位就制造不了话题,那么强话题性的文案自带传播属性,一般都会击中用户内心的某个感触,比如对社会的愤世嫉俗,对高房价的逆反心理,对旅游的文艺心等等。

极光推送介绍

  JPush 是经过考验的大规模 App 推送平台,每天推送消息量级为数百亿条。 开发者集成 SDK 后,可以通过调用 API 推送消息。同时,JPush 提供可视化的 web 端控制台发送通知,统计分析推送效果。 JPush 全面支持 Android, iOS, Winphone 三大手机平台。

为什么选择极光作为APP的消息推送平台?

特权对比👉

快速对接Jpush极光推送

极光详细对接文档👉

.NET FX 4.5项目接入

  该项目是基于C#/.NET(.NET Framework4.5.1的示例)极光推送对接实例,主要是对接极光集成为我们.Neter提供的SKD。在这里我主要封装了单个设备注册ID推送,设备注册ID批量推送和广播推送三种推送三种方式,其他的推送方式大家可以参考文档去进行封装。

JPuhs-Sample👉(封装示例源码)

1、在项目中引入Jiguang.JPush nuget包

2、极光推送调用

namespace Jpush.Controllers
{
    /// <summary>
    /// 极光推送管理
    /// </summary>
    public class JPushManageController : Controller
    {

        private readonly JPushClientUtil _jPushClientUtil;

        public JPushManageController(JPushClientUtil jPushClientUtil)
        { 
          this._jPushClientUtil=jPushClientUtil;
        }


        /// <summary>
        /// 单个设备注册ID推送
        /// </summary>
        /// <returns></returns>
        public ActionResult SendPushByRegistrationId()
        {
            var isOk = _jPushClientUtil.SendPushByRegistrationId("追逐时光者欢迎你!", "2022新年快乐", "1507bfd3f715abecfa4", new Dictionary<string, object>(), true);

            return Json(new { result = isOk });
        }


        /// <summary>
        /// 设备注册ID批量推送(一次推送最多1000个)
        /// </summary>
        /// <returns></returns>
        public ActionResult SendPushByRegistrationIdList()
        {
            var registrationIds = new List<string>() { "1507bfd3f715abecfa455", "1507bfd3f715abecfa433", "1507bfd3f715abecfa422" };
            var isOk = _jPushClientUtil.SendPushByRegistrationIdList("追逐时光者欢迎你!", "2022新年快乐", registrationIds, new Dictionary<string, object>(), true);

            return Json(new { result = isOk });
        }


        /// <summary>
        /// 广播推送
        /// </summary>
        /// <returns></returns>
        public ActionResult BroadcastPush()
        {
            var isOk = _jPushClientUtil.BroadcastPush("追逐时光者欢迎你!", "2022新年快乐", new Dictionary<string, object>(), true);

            return Json(new { result = isOk });
        }

    }
}

3、极光推送工具类(JPushClientUtil)

namespace Jpush.Common
{
    /// <summary>
    /// 极光推送工具类
    /// </summary>
    public class JPushClientUtil
    {
        private const string appKey = "youAppKey";
        private const string masterSecret = "youMasterSecret";
        private static JPushClient client = new JPushClient(appKey, masterSecret);

        /// <summary>
        /// 单个设备注册ID推送
        /// </summary>
        /// <param name="title">推送标题(Android才会存在)</param>
        /// <param name="noticeContent">通知内容</param>
        /// <param name="registrationid">设备注册ID(registration_id)</param>
        /// <param name="extrasParam">拓展参数(传入App接收的一些参数标识)</param>
        /// <param name="isApnsProduction">注意:iOS是否推送生产环境(true是,false否推开发环境)</param>
        /// <returns></returns>
        public bool SendPushByRegistrationId(string title, string noticeContent, string registrationid, Dictionary<string, object> extrasParam = null, bool isApnsProduction = true)
        {
            //设备标识参数拼接
            var pushRegistrationId = new RegistrationIdList();
            pushRegistrationId.registration_id.Add(registrationid);

            return JPushBaseSendMessage(title, noticeContent, isApnsProduction, pushRegistrationId, extrasParam);
        }

        /// <summary>
        /// 设备注册ID批量推送(一次推送最多1000个)
        /// </summary>
        /// <param name="title">推送标题(Android才会存在)</param>
        /// <param name="noticeContent">通知内容</param>
        /// <param name="registrationIds">注册ID(registration_id)列表,一次推送最多1000个</param>
        /// <param name="extrasParam">拓展参数(传入App接收的一些参数标识)</param>
        /// <param name="isApnsProduction">注意:iOS是否推送生产环境(true是,false否推开发环境)</param>
        /// <returns></returns>
        public bool SendPushByRegistrationIdList(string title, string noticeContent, List<string> registrationIds, Dictionary<string, object> extrasParam = null, bool isApnsProduction = true)
        {
            //设备标识参数拼接
            var pushRegistrationId = new RegistrationIdList();
            pushRegistrationId.registration_id.AddRange(registrationIds);

            return JPushBaseSendMessage(title, noticeContent, isApnsProduction, pushRegistrationId, extrasParam);
        }

        /// <summary>
        /// 广播推送
        /// </summary>
        /// <param name="title">推送标题(Android才会存在)</param>
        /// <param name="noticeContent">通知内容</param>
        /// <param name="extrasParam">拓展参数(传入App接收的一些参数标识)</param>
        /// <param name="isApnsProduction">注意:iOS是否推送生产环境(true是,false否推开发环境)</param>
        /// <returns></returns>
        public bool BroadcastPush(string title, string noticeContent, Dictionary<string, object> extrasParam = null, bool isApnsProduction = true)
        {
            return JPushBaseSendMessage(title, noticeContent, isApnsProduction, null, extrasParam, true);
        }

        /// <summary>
        /// 极光消息推送公共方法
        /// </summary>
        /// <param name="title">推送标题(Android才会存在)</param>
        /// <param name="noticeContent">通知内容</param>
        /// <param name="pushRegistrationId">设备注册ID(registration_id)</param>
        /// <param name="isApnsProduction">iOS是否推送生产环境(true是,false否推开发环境)</param>
        /// <param name="extrasParam">拓展参数</param>
        /// <param name="isRadioBroadcast">是否广播</param>
        /// <returns></returns>
        private bool JPushBaseSendMessage(string title, string noticeContent, bool isApnsProduction, RegistrationIdList pushRegistrationId, Dictionary<string, object> extrasParam, bool isRadioBroadcast = false)
        {
            try
            {
                object audience = pushRegistrationId;

                if (isRadioBroadcast)
                {
                    audience = "all";
                }

                var pushPayload = new PushPayload()
                {
                    Platform = new List<string> { "android", "ios" },//推送平台设置
                    Audience = audience,//推送目标
                    //notifacation:通知内容体。是被推送到客户端的内容。与 message 一起二者必须有其一,可以二者并存。
                    Notification = new Notification
                    {
                        Alert = noticeContent,//通知内容
                        Android = new Android
                        {
                            Alert = noticeContent,//通知内容
                            Title = title,//通知标题
                            URIActivity = "com.king.sysclearning.platform.app.JPushOpenClickActivity",//该字段用于指定开发者想要打开的 activity,值为 activity 节点的 “android:name”属性值;适配华为、小米、vivo厂商通道跳转
                            URIAction = "com.king.sysclearning.platform.app.JPushOpenClickActivity",//该字段用于指定开发者想要打开的 activity,值为 "activity"-"intent-filter"-"action" 节点的 "android:name" 属性值;适配 oppo、fcm跳转
                            Extras = extrasParam //这里自定义JSON格式的Key/Value信息,以供业务使用。
                        },
                        IOS = new IOS
                        {
                            Alert = noticeContent,
                            Badge = "+1",//此项是指定此推送的badge自动加1
                            Extras = extrasParam //这里自定义JSON格式的Key/Value信息,以供业务使用。
                        }
                    },
                    Options = new Options//可选参数
                    {
                        //iOS 环境不一致问题:API 推送消息给 iOS,需要设置 apns_production 指定推送的环境,false 为开发,true 为生产。
                        IsApnsProduction = isApnsProduction// 设置 iOS 推送生产环境。不设置默认为开发环境。
                    }
                };

                var response = client.SendPush(pushPayload);
                //200一定是正确。所有异常都不使用 200 返回码
                if (response.StatusCode == HttpStatusCode.OK)
                {
                    return true;
                }
                else
                {
                    return false;
                }
            }
            catch (Exception ex)
            {
                return false;
            }
        }
    }

    public class RegistrationIdList
    {
        /// <summary>
        /// 设备注册ID
        /// </summary>
        public List<string> registration_id { get; set; } = new List<string>();
    }
}

相关链接地址

极光对接官方文档

极光推送.NET-Nuget地址

极光推送.NET Core版本SDK

极光推送.NET Fx4.x版本SDK

JPuhs-Sample(封装示例源码)

到此这篇关于.NET对接极光消息推送的实现方法的文章就介绍到这了,更多相关.NET对接极光消息推送内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文