在日常开发中难免会有发送通知短信到用户手机的需求,那网易云信的模板短信是个不错的选择。

1 说明

1.1 背景

网易云信 是网易公司2015年11月推出了一款IM云服务产品。

1.2 价格

注册账号之后送20条短信。之后最少40000条短信起步(2000RMB),0.05一条,短信有效期2年。短信还可跟验证码短信等业务共享。

计费规则:云信短信计费包括短信签名,70字计1条短信费,超过70字则以67字每条计费,当短信中出现中文字符,则单个汉字、英文、标点和空格等都算一个字。

2 体验

  • 官方有售前售后电话,也有QQ客服,QQ客服响应速度慢,建议直接打电话。购买后有一对一客户经理。服务态度还可以,对产品有什么疑问可以随时打电话得到解决。

  • 后台查询可以分为两种方式查询1、按照指定日期查询发送量;2、查询一天发送明细或者指定手机号码查询。

  • 短信有签名“【云短信】”字样。要改变短信签名要申请,分企业申请和个人申请。企业要上传营业执照,个人开发者要上传个人手持身份证的正反面。值得一提的是官方虽然提供了个人开发者申请更改短信签名的途径,但我打电话后得知个人开发者是通不过请求的。

  • 通知模板最多可创建400个,还有审核机制,通过速度取决于你是否已经购买短信。慢则大概48小时,快则1个小时。我怎么知道?我购买前后体验过。

3 集成

官方文档

返回状态码

Server Http API接口文档

3.1 计算checksum

官方概述

计算CheckSum的java代码举例如下:


import java.security.MessageDigest;

public class CheckSumBuilder {

    public static String getCheckSum(String appSecret, String nonce, String curTime) {
        return encode("sha1", appSecret + nonce + curTime);
    }

    public static String getMD5(String requestBody) {
        return encode("md5", requestBody);
    }

    private static String encode(String algorithm, String value) {
        if (value == null) {
            return null;
        }
        try {
            MessageDigest messageDigest = MessageDigest.getInstance(algorithm);
            messageDigest.update(value.getBytes());
            return getFormattedText(messageDigest.digest());
        } catch (Exception e) {
            throw new RuntimeException(e);
        }
    }

    private static String getFormattedText(byte[] bytes) {
        int len = bytes.length;
        StringBuilder buf = new StringBuilder(len * 2);
        for (int j = 0; j < len; j++) {
            buf.append(HEX_DIGITS[(bytes[j] >> 4) & 0x0f]);
            buf.append(HEX_DIGITS[bytes[j] & 0x0f]);
        }
        return buf.toString();
    }

    private static final char[] HEX_DIGITS = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd',
            'e', 'f' };
}

3.2 写工具类

网易云信提供的模板短信由固定内容与多个变量构成,其中 " %s " 为需要接口替换的变量,变量内容可以是汉字、字母、数字或者特殊字符组合,但单个变量内容长度不得超过30个字,一条模板短信中变量数量不限制,短信模板总字数限制300字内;

public class MessageTools {
    private static String APPKEY = "ee23e57324974ab73343c3688c7e2c95";//开发者平台分配的appkey
    private static String APPSECRET = "ee23e5732";//安全码不需要提交,这样数据被截获也不能被修改,否则将不能被校验
    private static String NONCE = "ee23e5732";//随机数(最大长度128个字符)
    private static String TEMPLATEID = "1234567";//短信模板ID

    public String sendMessage(String doctorPhoneNumber, String messageContent) {
        String curTime = String.valueOf((new Date()).getTime() / 1000L);//当前UTC时间戳,从1970年1月1日0点0 分0 秒开始到现在的秒数(String)
        String checkSum = CheckSumBuilder.getCheckSum(APPSECRET, NONCE, curTime);//SHA1(AppSecret + Nonce + CurTime),三个参数拼接的字符串,进行SHA1哈希计算,转化成16进制字符(String,小写)
        
        String url = "https://api.netease.im/sms/sendtemplate.action/" + "?templateid=" + TEMPLATEID + "&mobiles=[\""
                + doctorPhoneNumber + "\"]" + "&params=" + "[\"" + messageContent + "\"]";

        //spring RestTemplate发送请求
        RestTemplate restTemplate = new RestTemplate();
        HttpHeaders headers = new HttpHeaders();
        MediaType type = MediaType.parseMediaType("application/x-www-form-urlencoded; charset=UTF-8");

        headers.set("AppKey", APPKEY);
        headers.set("Nonce", NONCE);
        headers.set("CurTime", curTime);
        headers.set("CheckSum", checkSum);
        headers.setContentType(type);

        HttpEntity<String> entity = new HttpEntity<String>(headers);

        String smsReturns = restTemplate.postForObject(url, entity, String.class);
        
        return smsReturns;//json格式返回状态码
    }
}

至此调用方法即可发送短信!参数因模板中的变量多少而更变。

本站以现代、古代情诗为主,情诗网创办于2013年,以原创爱情诗歌、经典情诗、现代情诗、古代情诗、英文情诗、情诗绝句为主并收集古诗、古诗词、诗歌大全、诗词名句的文学门户。方便您下次继续阅读;可以放在浏览器的收藏夹中(快捷键Ctrl+D);或者看到喜欢或者有趣的诗词可以通过分享按钮给你的好友分享;情诗网是目前最全情诗大全网站之一。并欢迎广大诗歌爱好者阅览投稿!喜欢本站的话请大家把本站告诉给你朋友哦!地址是 www.qingshiwang.com !