Project Description
JPush.NET is JPush SDK for .NET. It can help you send, monitor and manage all your JPush messages by programming, following JPush official REST API.
Click here to view JPush official document.
This project contains following parts:
- Pure API client, following official REST API. You can download orreview documentation.
- ASP.NET MVC based Web Portal for basic operations and simple configuration. (Can be demo)
IMPORTANT NOTE:
- JPush Server SDK 1.0.0 is for JPush v2, which would be retired by JPush officially.
- To support v3, please download & use latest version.
- In latest version, to make developers take minor change, class JPushClient has been changed to use JPushClientV3 logics inside.
- Major changes in v3:
- Always use SSL for sending/querying push message.
- Use Basic Authentication Header instead of hash code for authentication.
- Split model to Message and Notification to for UI/logic.
- Enhancement and improvement for PushType. They can be multiple used in one push for complicated filter requirements.
- Add Windows Phone in Platform.
- Add different models for each platform.
Sample for JPushClientV3:
Here is a sample based on .NET console application.
using System; using System.Collections.Generic; using System.IO; using System.Net; using System.Text; using System.Threading; using ifunction.JPush.V3; using Newtonsoft.Json; namespace ifunction.JPush.Test { class Program { staticvoid Main(string[] args) { var appKey = "1234567890abcdef"; // Your App Key from JPushvar masterSecret = "1234567890abcdef"; // Your Master Secret from JPush Dictionary<string, string> customizedValues = new Dictionary<string, string>(); customizedValues.Add("CK1", "CV1"); customizedValues.Add("CK2", "CV2"); JPushClientV3 client = new JPushClientV3(appKey, masterSecret); Audience audience = new Audience(); // In JPush V3, tag can be multiple added with different values.// In following code, it is to send push to those who are in ((Tag1 AND Tag2) AND (Tag3 OR Tag4))// If you want to send to all, please use: audience.Add(PushTypeV3.Broadcast, null); audience.Add(PushTypeV3.ByTagWithinAnd, new List<string>(newstring[] { "Tag1", "Tag2" })); audience.Add(PushTypeV3.ByTagWithinOr, new List<string>(newstring[] { "Tag3", "Tag4" })); // In JPush V3, Notification would not be display on screen, it would be transferred to app instead.// And different platform can provide different notification data. Notification notification = new Notification { AndroidNotification = new AndroidNotificationParameters { Title = "JPush provides V3.", Alert = "JPush V2 would be retired soon.", CustomizedValues = customizedValues }, iOSNotification = new iOSNotificationParameters { Badge = 1, Alert = "JPush V2 would be retired soon.", Sound = "YourSound", CustomizedValues = customizedValues } }; var response = client.SendPushMessage(new PushMessageRequestV3 { Audience = audience, Platform = PushPlatform.AndroidAndiOS, IsTestEnvironment = true, AppMessage = new AppMessage { Content = "Hello, this is a test push of V3 from .NET. Have a nice day!", CustomizedValue = customizedValues }, Notification = notification }); Console.WriteLine(response.ResponseCode.ToString() + ":"+ response.ResponseMessage); Console.WriteLine("Push sent."); Console.WriteLine(response.ResponseCode.ToString() + ":"+ response.ResponseMessage); List<string> idToCheck = new List<string>(); idToCheck.Add(response.MessageId); var statusList = client.QueryPushMessageStatus(idToCheck); Console.WriteLine("Status track is completed."); if (statusList != null) { foreach (var one in statusList) { Console.WriteLine(string.Format("Id: {0}, Android: {1}, iOS: {2}", one.MessageId, one.AndroidDeliveredCount, one.ApplePushNotificationDeliveredCount)); } } Console.WriteLine("Press any key to exit."); Console.Read(); } } } |
RESTful API reference: http://docs.jpush.cn/display/dev/Push-API-v3
IMPORTANT NOTE:
If you already use JPushClient V2 (Class: JPushClient), you can continue to use that. Library would convert the old PushMessageRequest to PushMessageRequestV3.
Sample for JPushClient:
Here is a sample based on .NET console application.
class Program { staticvoid Main(string[] args) { var appKey = "1234567890abcdef"; // Your App Key from JPushvar masterSecret = "1234567890abcdef"; // Your Master Secret from JPush Dictionary<string, string> customizedValues = new Dictionary<string, string>(); customizedValues.Add("CK1", "CV1"); customizedValues.Add("CK2", "CV2"); JPushClient client = new JPushClient(appKey, masterSecret, false); var response = client.SendPushMessage(new PushMessageRequest { MessageType = MessageType.Notification, Platform = PushPlatform.Android, Description = "DotNET", PushType = PushType.Broadcast, IsTestEnvironment = true, Message = new PushMessage { Content = "Hello, this is a test push from .NET. Have a nice day!", PushTitle = "A title.", Sound = "YourSound", CustomizedValue = customizedValues } }); Console.WriteLine(response.ResponseCode.ToString() + ":"+ response.ResponseMessage); Console.WriteLine("Push sent."); Console.WriteLine(response.ResponseCode.ToString() + ":"+ response.ResponseMessage); List<string> idToCheck = new List<string>(); idToCheck.Add(response.MessageId); var statusList = client.QueryPushMessageStatus(idToCheck); Console.WriteLine("Status track is completed."); if (statusList != null) { foreach (var one in statusList) { Console.WriteLine(string.Format("Id: {0}, Android: {1}, iOS: {2}", one.MessageId, one.AndroidDeliveredCount, one.ApplePushNotificationDeliveredCount)); } } Console.WriteLine("Press any key to exit."); Console.Read(); } } |
RESTful API reference: http://docs.jpush.cn/display/dev/Index
If you have any question or concern, you can contact
me.