短信http接口的java代码调用示例

package com.login.utils;


import java.io.IOException;
import java.net.URISyntaxException;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;


import org.apache.http.HttpEntity;
import org.apache.http.NameValuePair;
import org.apache.http.client.entity.UrlEncodedFormEntity;
import org.apache.http.client.methods.CloseableHttpResponse;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.message.BasicNameValuePair;
import org.apache.http.util.EntityUtils;


/**
 * 短信http接口的java代码调用示例 基于Apache HttpClient 4.3 依赖于 httpcore-4.3.2.jar httpclient-4.3.5.jar 包
 * 
 */
public class JavaSmsApi {
    
    // 查账户信息的http地址
    private static String URI_GET_USER_INFO = "http://yunpian.com/v1/user/get.json";
    
    // 通用发送接口的http地址
    private static String URI_SEND_SMS = "http://yunpian.com/v1/sms/send.json";
    
    // 模板发送接口的http地址
    private static String URI_TPL_SEND_SMS = "http://yunpian.com/v1/sms/tpl_send.json";
    
    // 发送语音验证码接口的http地址
    private static String URI_SEND_VOICE = "http://yunpian.com/v1/voice/send.json";
    
    // 编码格式。发送编码格式统一用UTF-8
    private static String ENCODING = "UTF-8";
    
    public static void main(String[] args)
        throws IOException, URISyntaxException {
        // 修改为您的apikey.apikey可在官网(http://www.yuanpian.com)登录后用户中心首页看到
        String apikey = "1c888c4fdb61e5b10df8607addbda7db ";
        // 修改为您要发送的手机号
        String mobile = "13906531021";
        
        /** ************** 查账户信息调用示例 **************** */
        System.out.println(JavaSmsApi.getUserInfo(apikey));
        
        /** ************** 使用通用接口发短信(推荐) **************** */
        // 设置您要发送的内容(内容必须和某个模板匹配。以下例子匹配的是系统提供的1号模板)
        String text = "【熊猫教学】您的验证码是1234";
        // 发短信调用示例
        System.out.println(JavaSmsApi.sendSms(text, mobile));
        
        /** ************** 使用模板接口发短信(不推荐,建议使用通用接口) **************** */
        // 设置模板ID,如使用1号模板:【#company#】您的验证码是#code#
        // long tpl_id = 1;
        // // 设置对应的模板变量值
        // // 如果变量名或者变量值中带有#&=%中的任意一个特殊符号,需要先分别进行urlencode编码
        // // 如code值是#1234#,需作如下编码转换
        // String codeValue = URLEncoder.encode("#1234#", ENCODING);
        // String tpl_value = "#code#=" + codeValue + "&#company#=云片网";
        // // 模板发送的调用示例
        // System.out.println(JavaSmsApi.tplSendSms(apikey, tpl_id, tpl_value, mobile));
        /** ************** 使用接口发语音验证码 **************** */
        // String code = "1234";
        // System.out.println(JavaSmsApi.sendVoice(apikey, mobile, code));
    }
    
    /**
     * 取账户信息
     * 
     * @return json格式字符串
     * @throws java.io.IOException
     */
    public static String getUserInfo(String apikey)
        throws IOException, URISyntaxException {
        Map<String, String> params = new HashMap<String, String>();
        params.put("apikey", apikey);
        return post(URI_GET_USER_INFO, params);
    }
    
    /**
     * 通用接口发短信
     * 
     * @param apikey apikey
     * @param text 短信内容
     * @param mobile 接受的手机号
     * @return json格式字符串
     * @throws IOException
     */
    public static String sendSms(String text, String mobile)
        throws IOException {
        // 发送短信key
        String apikey = "1c888c4fdb61e5b10df8607addbda7db";
        Map<String, String> params = new HashMap<String, String>();
        params.put("apikey", apikey);
        params.put("text", text);
        params.put("mobile", mobile);
        return post(URI_SEND_SMS, params);
    }
    
    /**
     * 通过模板发送短信(不推荐)
     * 
     * @param apikey apikey
     * @param tpl_id 模板id
     * @param tpl_value 模板变量值
     * @param mobile 接受的手机号
     * @return json格式字符串
     * @throws IOException
     */
    public static String tplSendSms(String apikey, long tpl_id, String tpl_value, String mobile)
        throws IOException {
        Map<String, String> params = new HashMap<String, String>();
        params.put("apikey", apikey);
        params.put("tpl_id", String.valueOf(tpl_id));
        params.put("tpl_value", tpl_value);
        params.put("mobile", mobile);
        return post(URI_TPL_SEND_SMS, params);
    }
    
    /**
     * 通过接口发送语音验证码
     * 
     * @param apikey apikey
     * @param mobile 接收的手机号
     * @param code 验证码
     * @return
     */
    public static String sendVoice(String apikey, String mobile, String code) {
        Map<String, String> params = new HashMap<String, String>();
        params.put("apikey", apikey);
        params.put("mobile", mobile);
        params.put("code", code);
        return post(URI_SEND_VOICE, params);
    }
    
    /**
     * 基于HttpClient 4.3的通用POST方法
     * 
     * @param url 提交的URL
     * @param paramsMap 提交<参数,值>Map
     * @return 提交响应
     */
    public static String post(String url, Map<String, String> paramsMap) {
        CloseableHttpClient client = HttpClients.createDefault();
        String responseText = "";
        CloseableHttpResponse response = null;
        try {
            HttpPost method = new HttpPost(url);
            if (paramsMap != null) {
                List<NameValuePair> paramList = new ArrayList<NameValuePair>();
                for (Map.Entry<String, String> param : paramsMap.entrySet()) {
                    NameValuePair pair = new BasicNameValuePair(param.getKey(), param.getValue());
                    paramList.add(pair);
                }
                method.setEntity(new UrlEncodedFormEntity(paramList, ENCODING));
            }
            response = client.execute(method);
            HttpEntity entity = response.getEntity();
            if (entity != null) {
                responseText = EntityUtils.toString(entity);
            }
        }
        catch (Exception e) {
            e.printStackTrace();
        }
        finally {
            try {
                response.close();
            }
            catch (Exception e) {
                e.printStackTrace();
            }
        }
        return responseText;
    }
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值