atitit 短信接口规范与短信解决方案.docx

atitit 短信接口规范与短信解决方案.docx

大家好,又见面了,我是全栈君。

atitit 短信接口规范与短信解决方案.docx

 

1.1. 国内比较著名的短信提供商1

1.2. 短信接口规范1

1.3. 短信sdk构成1

1.4. 短信的实现1

1.5. SmsServiceYyuntongxunImp5

 

1.1. 国内比较著名的短信提供商

 

http://www.yuntongxun.com/member/numbermanager

亿美软通

Mob 项目。。

http://sms.1xinxi.cn/

 

 

1.2. 短信接口规范

/atiplat_cms/src/com/attilax/sms/SmsService.java

package com.attilax.sms;

 

public class SmsService {

 

public Object send(String mobile, String content) {

1.3. 短信sdk构成

一般有sdk源码,这块我们一般不需要。。

以及sdk jar包。。我们需要的这个

还有demo,就是调用sdkdemo,这个我们需要。的。。

1.4. 短信的实现

 

/atiplat_cms/src/com/attilax/sms/Sms1xinxi.java

 

package com.attilax.sms;

 

import java.io.BufferedReader;

import java.io.IOException;

import java.io.InputStream;

import java.io.InputStreamReader;

import java.io.UnsupportedEncodingException;

import java.net.HttpURLConnection;

import java.net.MalformedURLException;

import java.net.ProtocolException;

import java.net.URL;

import java.net.URLDecoder;

import java.net.URLEncoder;

 

import com.attilax.io.filex;

 

/*

 *  com.attilax.sms.Sms1xinxi.send

 功能:1xinxi.cn HTTP接口 发送短信

 

 说明:http://sms.1xinxi.cn/asmx/smsservice.aspx?name=登录名&pwd=接口密码&mobile=手机号码&content=内容&sign=签名&stime=发送时间&type=pt&extno=自定义扩展码

 */

public class Sms1xinxi extends SmsService {

 

private String SmsSign;

 

public Sms1xinxi()

{

this.pwd = “xxxx”;

this.uname=”zhida”;

this.SmsSign=””;//职达巴士

}

 

public Sms1xinxi(String  name, String key_pwd) {

this.pwd = key_pwd;

this.uname=name;

}

 

/**

 * @param args

 * @throws IOException

 */

public static void main(String[] args) throws IOException {

 

}

 

private Sms1xinxi addSmsSign(String string) {

this.SmsSign=string;

return this;

}

 

private String pwd;

private String uname;

 

/**

 * 0,2016040319043901506198394,0,1,0,提交成功

rr:0,2016040319043901506198394,0,1,0,提交成功

 * @param mobile

 * @param content

 * @return

 */

public String send(String mobile, String content) {

 

try {

// 发送内容

// String content = “第一信息 JAVA示例测试“;

//String sign = “签名“;

 

// 创建StringBuffer对象用来操作字符串

StringBuffer sb = new StringBuffer(

“http://sms.1xinxi.cn/asmx/smsservice.aspx?”);

 

// StringBuffer追加用户名

sb.append(“name=”+uname);

 

// StringBuffer追加密码(登陆网页版,在管理中心基本资料接口密码,是28位的)

sb.append(“&pwd=” + this.pwd);

 

// StringBuffer追加手机号码

sb.append(“&mobile=” + mobile);

 

// StringBuffer追加消息内容转URL标准码

 

sb.append(“&content=” + URLEncoder.encode(content, “UTF-8”));

 

// 追加发送时间,可为空,为空为及时发送

sb.append(“&stime=”);

 

// 加签名

 

sb.append(“&sign=” + URLEncoder.encode(this.SmsSign, “UTF-8”));

 

// type为固定值pt extno为扩展码,必须为数字 可为空

sb.append(“&type=pt&extno=”);

// 创建url对象

// String temp = new String(sb.toString().getBytes(“GBK”),”UTF-8″);

System.out.println(“sb:” + sb.toString());

URL url;

String returnStr;

 

url = new URL(sb.toString());

 

// 打开url连接

HttpURLConnection connection;

 

connection = (HttpURLConnection) url.openConnection();

 

// 设置url请求方式 ‘get’ 或者 ‘post

 

connection.setRequestMethod(“POST”);

 

// 发送

InputStream is;

 

is = url.openStream();

 

// 转换返回值

returnStr = Sms1xinxi.convertStreamToString(is);

 

// 返回结果为‘020140009090990,1,提交成功’ 发送成功 具体见说明文档

System.out.println(returnStr);

// 返回发送结果

return returnStr;

} catch (Exception e) {

// TODO Auto-generated catch block

e.printStackTrace();

throw new RuntimeException(e);

}

}

 

/**

 * 转换返回值类型为UTF-8格式.

 *

 * @param is

 * @return

 */

public static String convertStreamToString(InputStream is) {

StringBuilder sb1 = new StringBuilder();

byte[] bytes = new byte[4096];

int size = 0;

 

try {

while ((size = is.read(bytes)) > 0) {

String str = new String(bytes, 0, size, “UTF-8”);

sb1.append(str);

}

} catch (IOException e) {

e.printStackTrace();

} finally {

try {

is.close();

} catch (IOException e) {

e.printStackTrace();

}

}

return sb1.toString();

}

 

}

 

1.5. SmsServiceYyuntongxunImp

 

/**

 *

 */

package com.attilax.sms;

 

import com.csmy.my.center.util.RequestUtil;

 

/**

 * impt sms n capt itfs..

 * @author attilax

 *20161122日 下午4:05:07

 */

public class SmsServiceYyuntongxunImp extends SmsService  {

 

/**

 *

 */

private   String tmp_id = “1”;

 

//public String code=;

public String min=”10″;

 

public Object send(String mobile, String code)

{

return  new SDKTestSendTemplateSMS().send(mobile, code, tmp_id, min);

 

 

}

}

 

 

package com.attilax.sms;

 

import java.util.HashMap;

import java.util.Set;

 

import com.attilax.json.AtiJson;

import com.cloopen.rest.sdk.CCPRestSmsSDK;

 

public class SDKTestSendTemplateSMS {

 

/**

 * @param args

 */

public static void main(String[] args) {

String cp = “18573344543”;

String code = “6532”;

String templateId = “1”;

String min = “10”;

send(cp, code, templateId, min);

}

 

 

 

作者:: 绰号:老哇的爪子 ( 全名::Attilax Akbar Al Rapanui 阿提拉克斯 阿克巴 阿尔 拉帕努伊 ) 

汉字名:艾提拉(艾龙)   EMAIL:1466519819@qq.com

转载请注明来源: http://www.cnblogs.com/attilax/

Atiend

 

在电脑上发短信 – attilax的专栏 博客频道 – CSDN.NET.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/108768.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Android 9.0 WebView无法加载页面报错 net:ERR_CLEARTEXT_NOT_PERMITTED

    Android 9.0 WebView无法加载页面报错 net:ERR_CLEARTEXT_NOT_PERMITTED

    2021年10月2日
    124
  • Java集合篇:HashMap原理详解(JDK1.8)

    Java集合篇:HashMap原理详解(JDK1.8)

    2021年10月4日
    219
  • android详解_MPAndroidChart

    android详解_MPAndroidChart在开发当中曲线图用的时候太多了,之前都是自己手写,之后发现太累还丑不符合需求MPAndroidChart先介绍LineChart0.效果图首先依赖1. implementation

    2022年8月6日
    7
  • 检查网站有没有被挂马_安全网址检测

    检查网站有没有被挂马_安全网址检测介绍很多网站都被挂过马,挂马即在获取服务器的部分权限或所有权限后,向网页文件中插入一段恶意代码,即挂马。这些恶意代码可以是浏览器漏洞的利用代码,也可以是赚取流量的代码,或者是盗取账号的代码。URLSnooperurlsnooper字面理解即url窥探,官方说明是可以帮助用户发现音频和视频文件的url地址。下载地址是http://www.donationcoder.com/softw…

    2022年9月30日
    3
  • APT防御_简述对安全的理解

    APT防御_简述对安全的理解在信息化的时代,很多业务都依赖于互联网,例如说网上银行、网络购物、网游等。大量的数据依赖于网络。无疑Web成为领导者。随着国家安全法的不断完善,企业及公司对用户隐私以及公司的重要信息逐渐加强重视。也使得暴露在网络上的Web面临更高的挑战。这种黑白交替的时代,黑白技术在对抗中也在不断的发展。也使得安全测试逐渐规范化。作为新人,浅谈一下Web安全观。浅谈从Web安全到APT防御。一、web系统存在的安全性复杂应用系统代码量大、开发人员出现疏忽;系统屡次升级、人员频繁变更,使得代码存在差别;新旧资源存在

    2026年1月29日
    3
  • 车用总线技术 | J1939协议实用指南与J1939数据记录方案

    车用总线技术 | J1939协议实用指南与J1939数据记录方案“没错,这是一份SAEJ1939协议的简单、实用指南。”—虹科开篇:在这篇介绍中,我们介绍了J1939协议的基本知识,其中包括PGN和SPN。因为这是一篇偏向应用的简介,所以您还将会学习到如何通过DBC文件解码J1939数据、如何记录J1939、典型的应用案例和实用技巧。下面,来了解下这份简单易懂的J1939介绍吧~什么是J1939?J1939简介简而言之,SAEJ1939其实是一套标准,重型车辆ECU间就是按照这套标准在CAN总线上进行通信的。当今大多数车辆都通过CAN(Con…

    2022年5月1日
    652

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号