1. 获取AccessKey
为了保证云服务的安全,您需要创建一个能访问移动推送资源的RAM子账号,获取该子账号的AccessKey,并使用这个RAM子账号调用移动推送的OpenAPI。
操作步骤:
创建RAM子账号,操作方法请参见创建RAM用户,
授予RAM子账号管理移动推送(MPush)的权限,操作方法请参见为RAM用户授权。
获取子账号的AccessKey信息请参见获取AccessKey。
重要
AccessKey包含AccessKey ID和AccessKey Secret。
调用接口前,需配置环境变量,通过环境变量读取访问凭证。配置方法:
export CC_AK_ENV=<access_key_id> export CC_SK_ENV=<access_key_secret>
<access_key_id>替换为您RAM用户的AccessKey ID,<access_key_secret>替换为AccessKey Secret。
2. 获取AppKey
登录EMAS控制台,在首页我的产品模块单击您的应用,进入应用管理页面,应用管理页面即可查看AppKey。
3. 引入SDK依赖
using Aliyun.Acs.Core;
using Aliyun.Acs.Core.Exceptions;
using Aliyun.Acs.Core.Profile;
using Aliyun.Acs.Push.Model.V20160801;
using System;
4. 示例代码
说明
示例代码中的appKey需替换为您在步骤2中获取到的值。
您也可以使用可视化调试工具OpenAPI Explorer,获取代码示例。
using System;
using System.Collections.Generic;
using Aliyun.Acs.Core;
using Aliyun.Acs.Core.Exceptions;
using Aliyun.Acs.Core.Profile;
using Aliyun.Acs.Push.Model.V20160801;
// 配置SDK Profile
// 阿里云账号AccessKey拥有所有API的访问权限,建议您使用RAM用户进行API访问或日常运维。
// 强烈建议不要把AccessKey ID和AccessKey Secret保存到工程代码里,否则可能导致AccessKey泄露,威胁您账号下所有资源的安全。
// 本示例通过从环境变量中读取AccessKey,来实现API访问的身份验证。
namespace PushDemo
{
class Program
{
static void Main(string[] args)
{
IClientProfile profile = DefaultProfile.GetProfile("cn-hangzhou", Environment.GetEnvironmentVariable("CC_AK_ENV"), Environment.GetEnvironmentVariable("CC_SK_ENV"));
DefaultAcsClient client = new DefaultAcsClient(profile);
var request = new PushRequest();
request.AppKey = "appKey";
request.PushType = "NOTICE";
request.DeviceType = "ALL";
request.Target = "DEVICE";
request.TargetValue = "deviceIds";
request.Body = "ALi Push Title";
request.Title = "Ali Push Body";
try {
var response = client.GetAcsResponse(request);
Console.WriteLine(System.Text.Encoding.Default.GetString(response.HttpResponse.Content));
}
catch (ServerException e)
{
Console.WriteLine(e);
}
catch (ClientException e)
{
Console.WriteLine(e);
}
}
}
}
文档内容是否对您有帮助?