zoukankan      html  css  js  c++  java
  • Amazon SNS (Simple Notification Service) Using C# and Visual Studio

    SNS (Amazon Simple Notification Services)

    Amazon SNS (Amazon Simple Notification Services) is a notification service used to send the notifications to the subscribed endpoint or devices. It is provided as a part of Amazon Web Services. It provides a low-cost infrastructure for the mass delivery of messages, emails, notifications, etc.

    Steps to Implementing Amazon SNS

    1. Create topic - you will get the Topic ARN for which you have to send the notification or send the messages.

    2. Create Application - after this, you have to create an application whether you want to send the notification over the Android application or over the iOS application.

    3. Create Endpoint - you need to create the endpoint and subscribe to that endpoint on which you have to publish the message or send the notification.

    4. Publish Message - the last step is to publish the message or send the notification to the endpoint.

    You can follow the same process for using this notification service over the Amazon Console too. You need to login to the console first. After that, you will see a screen like this.

    Type "Simple Notification Service" in the textbox and select from the results shown on the screen.

    AWS 

    Here, you will have the list of topics, subscriptions, applications, and endpoints that you create. In the above screenshot, I have created two endpoints - one for Android devices (GSM) and the other one is for iOS devices (APNS).

    For using the ASNS from the console, the steps are the same as described above. I am going to show a working example of the ASNS in .NET using Visual Studio.

    Let's begin.

    Step 1

    Install AWS Toolkit for Visual Studio.

    AWS

    Step 2

    Create a Windows or web application; whichever you prefer. I have created a Windows.Form application and have made two radio buttons and one submit button to send notifications.

    AWS

    Step 3

    After this, you need to setup your project to use the Amazon Services. First, you have to specify the Access Key, Secret Key, and Region in web.config file in case you are using the web application, and in app.config if you are using the Windows application.

    <appSettings> <add key="AWSAccessKey" value="************************" /> <add key="AWSSecretKey" value="*******************************************" /> <add key="AWSRegion" value="us-east-1" /> </appSettings>

    Step 4

    After this, you need to install a few of the necessary .dll files from the NuGet Package Manager. You can add these required libraries from the NuGet Package Manager or PM> console by typing the name of the libraries, as shown in the references.

    AWS

    Now, it's time to write a few lines of code for this functionality.

    using System;
    using System.Windows.Forms;
    using Newtonsoft.Json;
    using Amazon.SimpleNotificationService;
    using Amazon.SimpleNotificationService.Model;
    
    namespace AwsSnsPoc
    {
        public partial class Form1 : Form
        {
            public Form1()
            {
                InitializeComponent();
            }
            private void SendNotificationToDevice_Click(object sender, EventArgs e)
            {
                lblMsg.Visible = false; if (!iosDevice.Checked && !andriodDevice.Checked) { return; }
                sendnotification();
            }
            private void sendnotification()
            {
                // this endpoint is for android devices 
                var gcmARN = "arn:aws:sns:us-east-1:501401665234:endpoint/GCM/nameoftopic/***********************";
                // this endpoint is for ios devices 
                var apnsARN = "arn:aws:sns:us-east-1:502682123213:endpoint/APNS_SANDBOX/nameoftopic/*************";
                var checkedButton = iosDevice.Checked;
                // Creating the SNS client 
                var snsClient = new AmazonSimpleNotificationServiceClient();
                // Creating the topic request and the topic and response 
                var topicRequest = new CreateTopicRequest { Name = "TestSNSTopic" };
                var topicResponse = snsClient.CreateTopic(topicRequest);
                var topicAttrRequest = new SetTopicAttributesRequest
                {
                    opicArn = topicResponse.TopicArn,
                    AttributeName = "SNSTopic",
                    AttributeValue = "SNS Test AttrValue"
                };
                snsClient.SetTopicAttributes(topicAttrRequest);
                // Subscribe to the endpoint of the topic 
                var subscribeRequest = new SubscribeRequest()
                {
                    TopicArn = topicResponse.TopicArn,
                    Protocol = "application", // important to chose the protocol as I am sending notification to applications I have chosen application here. 
                    Endpoint = iosDevice.Checked ? apnsARN : gcmARN
                };
                var res = snsClient.Subscribe(subscribeRequest);
                RootObject reqObj = new RootObject();
                // Publishing the request to the endpoint (takecare of the protocol that is must is sending the json then use json else use sns, email, sqs etc. as per your requirement)
                PublishRequest publishReq = new PublishRequest()
                {
                    TargetArn = subscribeRequest.Endpoint MessageStructure = "json",
                    Message = JsonConvert.SerializeObject(reqObj)
                };
                PublishResponse response = snsClient.Publish(publishReq);
                if (response != null && response.MessageId != null)
                {
                    lblMsg.Visible = true;
                    lblMsg.Text = "Notification Send Successfully";
                }
            }
        }
        public class Aps
        {
            public string alert { get; set; }
            public string url { get; set; }
        }
        public class APNS
        {
            public Aps aps { get; set; }
        }
        public class GCMData
        {
            public string message { get; set; }
            public string url { get; set; }
        }
        public class GCM
        {
            public GCMData data { get; set; }
        }
        public class RootObject
        {
            public string @default { get; set; }
            public string APNS_SANDBOX { get; set; }
            public string GCM { get; set; }
            public RootObject()
            {
                @default = "This is the default message which must be present when publishing a message to a topic. The default message will only be used if a message is not present for one of the notification platforms.";
                APNS apns = new APNS()
                {
                    aps = new Aps()
                    {
                        alert = "Check out these awesome deals!",
                        url = "www.amazon.com"
    
                    }
                };
                GCM gcm = new GCM()
                {
                    data = new GCMData()
                    {
                        message = "Check out these awesome deals!",
                        url = "www.amazon.com"
                    }
                };
                this.APNS_SANDBOX = JsonConvert.SerializeObject(apns);
                this.GCM = JsonConvert.SerializeObject(gcm);
            }
        }
        //NOTE : One of the most important thing that you need to take care of that is you have to be very careful while forming the Object of the JSON request that you want to send like as I have given the JSON and the Object formation of that too. 
        //the sample of the notification message that we want to send, in Android devices we must get the android deals 
        //message on the notification 
        // { // "default": "This is the default message which must be present when publishing a message to a topic. The default message will only be used if a message is not present for one of the notification platforms.", // "APNS": {"aps":{"alert": "Check out these awesome ios deals!","url":"www.amazon.com"} }, 
        // "GCM": {"data":{"message":"Check out these awesome android deals!","url":"www.amazon.com"}}, //} # endregion 
    }
    

      

     

    If you get the message, "Notification sent successfully," you have successfully integrated this SNS Service into your application.

    For live testing on your devices, you must be ready with your device (iOS/Android) on which you are going to test this. I hope, you will enjoy implementing this awesome service from Amazon.

    If you have any queries or questions, I will be happy to give the solution.

    Happy coding! Enjoy.

  • 相关阅读:
    活用 %取余 用于变量循环
    jquery滚动条固定在某一位置
    jquary中各种相似操作介绍
    jquary中滚动条滚动到底部
    JSON到字符串之间的解析
    ecshop删去版权等信息
    分享代码和网页地图
    ecshop版权的修改,头部,底部
    ECSHOP中transport.js和jquery的冲突的简单解决办法
    从Eclipse迁移到Android Studio碰到的问题记录
  • 原文地址:https://www.cnblogs.com/Javi/p/9227560.html
Copyright © 2011-2022 走看看