• .NET快速对接极光消息推送


    什么是消息推送

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

    常见的一些APP消息推送示例

    强营销类:

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

    图片

    强关联性:

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

    图片

    强话题性:

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

    图片

    极光推送介绍

    极光推送(JPush)是日均消息量超百亿级规模的 App 消息推送专业服务平台,极光推送支持 Android、iOS、QuickApp、Web 等平台,SDK 接入方便快捷,推送通道高速稳定且支持海外专线,API 开放接口强大、灵活和易用、WEB 端支持创建通知、后效分析、标签别名管理和故障排查等运营功能。 极光推送(JPush)在为开发者提供基础推送服务的同时,还提供了用户精准标签、用户分群、地理围栏、应用内消息、智能发送策略、智能促活等服务能力,可有效提升消息的送达率、展示率和点击率,通过精细化运营触达助力 APP 提升日活和留存。

    平台类型支持

    图片

    消息类型支持

    图片

    通知样式支持

    图片

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

    • 首先极光推送支持多平台推送。

    • 支持大规模的消息推送。

    • 极光推送对接方便,不同后端语言都提供了对应的SDK。

    • 对于免费账号支持也非常的友好(不过免费账号高峰期有资源瓶颈,假如需要及时性很强的话可以购买高级版收费服务)。

    图片

    快速对接Jpush极光推送

    • 到极光推送官方网站注册开发者帐号;

    • 登录进入管理控制台,创建应用程序,得到 Appkey(SDK 与服务器端通过 Appkey 互相识别);

    • 在推送设置中给 Android 设置包名、给 iOS 上传证书、启用 WinPhone,根据你的需求进行选择;

    .NET FX 4.5项目快速接入

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

    • JPuhs-Sample👉(封装示例源码):https://github.com/YSGStudyHards/JPuhs-Sample

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

    图片

    2、极光推送调用

    1. namespace Jpush.Controllers
    2. {
    3.     /// <summary>
    4.     /// 极光推送管理
    5.     /// </summary>
    6.     public class JPushManageController : Controller
    7.     {
    8.         private readonly JPushClientUtil _jPushClientUtil;
    9.         public JPushManageController(JPushClientUtil jPushClientUtil)
    10.         { 
    11.           this._jPushClientUtil=jPushClientUtil;
    12.         }
    13.         /// <summary>
    14.         /// 单个设备注册ID推送
    15.         /// </summary>
    16.         /// <returns></returns>
    17.         public ActionResult SendPushByRegistrationId()
    18.         {
    19.             var isOk = _jPushClientUtil.SendPushByRegistrationId("追逐时光者欢迎你!""2022新年快乐""1507bfd3f715abecfa4", new Dictionary<stringobject>(), true);
    20.             return Json(new { result = isOk });
    21.         }
    22.         /// <summary>
    23.         /// 设备注册ID批量推送(一次推送最多1000个)
    24.         /// </summary>
    25.         /// <returns></returns>
    26.         public ActionResult SendPushByRegistrationIdList()
    27.         {
    28.             var registrationIds = new List<string>() { "1507bfd3f715abecfa455""1507bfd3f715abecfa433""1507bfd3f715abecfa422" };
    29.             var isOk = _jPushClientUtil.SendPushByRegistrationIdList("追逐时光者欢迎你!""2022新年快乐", registrationIds, new Dictionary<stringobject>(), true);
    30.             return Json(new { result = isOk });
    31.         }
    32.         /// <summary>
    33.         /// 广播推送
    34.         /// </summary>
    35.         /// <returns></returns>
    36.         public ActionResult BroadcastPush()
    37.         {
    38.             var isOk = _jPushClientUtil.BroadcastPush("追逐时光者欢迎你!""2022新年快乐", new Dictionary<stringobject>(), true);
    39.             return Json(new { result = isOk });
    40.         }
    41.     }
    42. }

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

    1. namespace Jpush.Common
    2. {
    3.     /// <summary>
    4.     /// 极光推送工具类
    5.     /// </summary>
    6.     public class JPushClientUtil
    7.     {
    8.         private const string appKey = "youAppKey";
    9.         private const string masterSecret = "youMasterSecret";
    10.         private static JPushClient client = new JPushClient(appKey, masterSecret);
    11.         /// <summary>
    12.         /// 单个设备注册ID推送
    13.         /// </summary>
    14.         /// <param name="title">推送标题(Android才会存在)</param>
    15.         /// <param name="noticeContent">通知内容</param>
    16.         /// <param name="registrationid">设备注册ID(registration_id)</param>
    17.         /// <param name="extrasParam">拓展参数(传入App接收的一些参数标识)</param>
    18.         /// <param name="isApnsProduction">注意:iOS是否推送生产环境(true是,false否推开发环境)</param>
    19.         /// <returns></returns>
    20.         public bool SendPushByRegistrationId(string title, string noticeContent, string registrationid, Dictionary<stringobject> extrasParam = null, bool isApnsProduction = true)
    21.         {
    22.             //设备标识参数拼接
    23.             var pushRegistrationId = new RegistrationIdList();
    24.             pushRegistrationId.registration_id.Add(registrationid);
    25.             return JPushBaseSendMessage(title, noticeContent, isApnsProduction, pushRegistrationId, extrasParam);
    26.         }
    27.         /// <summary>
    28.         /// 设备注册ID批量推送(一次推送最多1000个)
    29.         /// </summary>
    30.         /// <param name="title">推送标题(Android才会存在)</param>
    31.         /// <param name="noticeContent">通知内容</param>
    32.         /// <param name="registrationIds">注册ID(registration_id)列表,一次推送最多1000</param>
    33.         /// <param name="extrasParam">拓展参数(传入App接收的一些参数标识)</param>
    34.         /// <param name="isApnsProduction">注意:iOS是否推送生产环境(true是,false否推开发环境)</param>
    35.         /// <returns></returns>
    36.         public bool SendPushByRegistrationIdList(string title, string noticeContent, List<string> registrationIds, Dictionary<stringobject> extrasParam = null, bool isApnsProduction = true)
    37.         {
    38.             //设备标识参数拼接
    39.             var pushRegistrationId = new RegistrationIdList();
    40.             pushRegistrationId.registration_id.AddRange(registrationIds);
    41.             return JPushBaseSendMessage(title, noticeContent, isApnsProduction, pushRegistrationId, extrasParam);
    42.         }
    43.         /// <summary>
    44.         /// 广播推送
    45.         /// </summary>
    46.         /// <param name="title">推送标题(Android才会存在)</param>
    47.         /// <param name="noticeContent">通知内容</param>
    48.         /// <param name="extrasParam">拓展参数(传入App接收的一些参数标识)</param>
    49.         /// <param name="isApnsProduction">注意:iOS是否推送生产环境(true是,false否推开发环境)</param>
    50.         /// <returns></returns>
    51.         public bool BroadcastPush(string title, string noticeContent, Dictionary<stringobject> extrasParam = null, bool isApnsProduction = true)
    52.         {
    53.             return JPushBaseSendMessage(title, noticeContent, isApnsProduction, null, extrasParam, true);
    54.         }
    55.         /// <summary>
    56.         /// 极光消息推送公共方法
    57.         /// </summary>
    58.         /// <param name="title">推送标题(Android才会存在)</param>
    59.         /// <param name="noticeContent">通知内容</param>
    60.         /// <param name="pushRegistrationId">设备注册ID(registration_id)</param>
    61.         /// <param name="isApnsProduction">iOS是否推送生产环境(true是,false否推开发环境)</param>
    62.         /// <param name="extrasParam">拓展参数</param>
    63.         /// <param name="isRadioBroadcast">是否广播</param>
    64.         /// <returns></returns>
    65.         private bool JPushBaseSendMessage(string title, string noticeContent, bool isApnsProduction, RegistrationIdList pushRegistrationId, Dictionary<stringobject> extrasParam, bool isRadioBroadcast = false)
    66.         {
    67.             try
    68.             {
    69.                 object audience = pushRegistrationId;
    70.                 if (isRadioBroadcast)
    71.                 {
    72.                     audience = "all";
    73.                 }
    74.                 var pushPayload = new PushPayload()
    75.                 {
    76.                     Platform = new List<string> { "android""ios" },//推送平台设置
    77.                     Audience = audience,//推送目标
    78.                     //notifacation:通知内容体。是被推送到客户端的内容。与 message 一起二者必须有其一,可以二者并存。
    79.                     Notification = new Notification
    80.                     {
    81.                         Alert = noticeContent,//通知内容
    82.                         Android = new Android
    83.                         {
    84.                             Alert = noticeContent,//通知内容
    85.                             Title = title,//通知标题
    86.                             URIActivity = "com.king.sysclearning.platform.app.JPushOpenClickActivity",//该字段用于指定开发者想要打开的 activity,值为 activity 节点的 “android:name”属性值;适配华为、小米、vivo厂商通道跳转
    87.                             URIAction = "com.king.sysclearning.platform.app.JPushOpenClickActivity",//该字段用于指定开发者想要打开的 activity,值为 "activity"-"intent-filter"-"action" 节点的 "android:name" 属性值;适配 oppo、fcm跳转
    88.                             Extras = extrasParam //这里自定义JSON格式的Key/Value信息,以供业务使用。
    89.                         },
    90.                         IOS = new IOS
    91.                         {
    92.                             Alert = noticeContent,
    93.                             Badge = "+1",//此项是指定此推送的badge自动加1
    94.                             Extras = extrasParam //这里自定义JSON格式的Key/Value信息,以供业务使用。
    95.                         }
    96.                     },
    97.                     Options = new Options//可选参数
    98.                     {
    99.                         //iOS 环境不一致问题:API 推送消息给 iOS,需要设置 apns_production 指定推送的环境,false 为开发,true 为生产。
    100.                         IsApnsProduction = isApnsProduction// 设置 iOS 推送生产环境。不设置默认为开发环境。
    101.                     }
    102.                 };
    103.                 var response = client.SendPush(pushPayload);
    104.                 //200一定是正确。所有异常都不使用 200 返回码
    105.                 if (response.StatusCode == HttpStatusCode.OK)
    106.                 {
    107.                     return true;
    108.                 }
    109.                 else
    110.                 {
    111.                     return false;
    112.                 }
    113.             }
    114.             catch (Exception ex)
    115.             {
    116.                 return false;
    117.             }
    118.         }
    119.     }
    120.     public class RegistrationIdList
    121.     {
    122.         /// <summary>
    123.         /// 设备注册ID
    124.         /// </summary>
    125.         public List<string> registration_id { getset; } = new List<string>();
    126.     }
    127. }

    参考文章

    • 十分钟带你了解APP消息推送(Push):https://www.woshipm.com/operate/526224.html

    • 极光详细对接文档:https://docs.jiguang.cn/jpush/quickstart/3m_dem

  • 相关阅读:
    Plonky2:最好的SNARKs和STARKs
    4┃音视频直播系统之浏览器中通过 WebRTC 进行桌面共享
    kubernetes RBAC
    HMI-64-【多媒体】Ui全部制作完成
    java 集合处理:
    链路聚合简述
    TypeScript 联合类型
    快速编写CSDN博客 小技巧
    LeetCode每日一题(911. Online Election)
    iNeuOS工业互联网操作系统,民爆远程运维平台案例
  • 原文地址:https://blog.csdn.net/qq_37237487/article/details/134346038