短信验证 (短信必须先购买了再使用)
导入相关依赖
- # 能够直接导入就直接添加 maven 依赖, 没法直接导入的去阿里云下载 jar 包本地添加
- <dependency>
- <groupId>com.aliyun</groupId>
- <artifactId>aliyun-java-sdk-core</artifactId>
- <version>3.0.0</version>
- <scope>system</scope>
- <systemPath>${project.basedir}/lib/aliyun-java-sdk-core-3.0.0.jar</systemPath>
- </dependency>
- <dependency>
- <groupId>com.aliyun</groupId>
- <artifactId>aliyun-java-sdk-dm</artifactId>
- <version>3.1.0</version>
- <scope>system</scope>
- <systemPath>${project.basedir}/lib/aliyun-java-sdk-dm-3.1.0.jar</systemPath>
- </dependency>
- <dependency>
- <groupId>com.aliyun</groupId>
- <artifactId>aliyun-java-sdk-dysmsapi</artifactId>
- <version>1.1.0</version>
- </dependency>
必须要先去阿里云注册, 拿到 apikey 等相关信息
- # 短信测试代码, 替换 #### 就可以直接使用了
- import com.aliyuncs.DefaultAcsClient;
- import com.aliyuncs.IAcsClient;
- import com.aliyuncs.dysmsapi.model.v20170525.SendSmsRequest;
- import com.aliyuncs.dysmsapi.model.v20170525.SendSmsResponse;
- import com.aliyuncs.http.MethodType;
- import com.aliyuncs.profile.DefaultProfile;
- import com.aliyuncs.profile.IClientProfile;
- public class SendAliyunPhone {
- public static void main(String[] args) throws Exception {
- // 设置超时时间 - 可自行调整
- System.setProperty("sun.net.client.defaultConnectTimeout", "10000");
- System.setProperty("sun.net.client.defaultReadTimeout", "10000");// 初始化 ascClient 需要的几个参数
- final String product = "Dysmsapi";// 短信 API 产品名称 (短信产品名固定, 无需修改)
- final String domain = "dysmsapi.aliyuncs.com";// 短信 API 产品域名 (接口地址固定, 无需修改)
- // 替换成你的 AK
- final String accessKeyId = "####";// 你的 accessKeyId, 参考本文档步骤 2
- final String accessKeySecret = "####";// 你的 accessKeySecret, 参考本文档步骤 2
- // 初始化 ascClient, 暂时不支持多 region(请勿修改)
- IClientProfile profile = DefaultProfile.getProfile("cn-hangzhou", accessKeyId,
- accessKeySecret);
- DefaultProfile.addEndpoint("cn-hangzhou", "cn-hangzhou", product, domain);
- IAcsClient acsClient = new DefaultAcsClient(profile);
- // 组装请求对象
- SendSmsRequest request = new SendSmsRequest();
- // 使用 post 提交
- request.setMethod(MethodType.POST);
- // 必填: 待发送手机号. 支持以逗号分隔的形式进行批量调用, 批量上限为 1000 个手机号码, 批量调用相对于单条调用及时性稍有延迟, 验证码类型的短信推荐使用单条调用的方式; 发送国际 / 港澳台消息时, 接收号码格式为国际区号 + 号码, 如 "85200000000"
- request.setPhoneNumbers("####");
- // 必填: 短信签名 - 可在短信控制台中找到
- request.setSignName("####");
- // 必填: 短信模板 - 可在短信控制台中找到, 发送国际 / 港澳台消息时, 请使用国际 / 港澳台短信模版
- request.setTemplateCode("####");
- // 可选: 模板中的变量替换 JSON 串, 如模板内容为 "亲爱的 ${name}, 您的验证码为 ${code}" 时, 此处的值为
- // 友情提示: 如果 JSON 中需要带换行符, 请参照标准的 JSON 协议对换行符的要求, 比如短信内容中包含 \ r\n 的情况在 JSON 中需要表示成 \\r\\n, 否则会导致 JSON 在服务端解析失败
- request.setTemplateParam("{\"name\":\"Tom\", \"code\":\"123\"}");
- // 可选 - 上行短信扩展码 (扩展码字段控制在 7 位或以下, 无特殊需求用户请忽略此字段)
- //request.setSmsUpExtendCode("90997");
- // 可选: outId 为提供给业务方扩展字段, 最终在短信回执消息中将此值带回给调用者
- request.setOutId("yourOutId");
- // 请求失败这里会抛 ClientException 异常
- SendSmsResponse sendSmsResponse = acsClient.getAcsResponse(request);
- if (sendSmsResponse.getCode() != null && sendSmsResponse.getCode().equals("OK")) {
- // 请求成功
- System.out.println("请求成功");
- }
- }
- }
邮件推送 (每天有 200 条的免费额度)
导入相关依赖
邮件推送 (参考阿里云提供的 API 文档)
1. 创建发信域名
2 创建发信地址
3 发送邮件
- # 测试代码
- import com.aliyuncs.DefaultAcsClient;
- import com.aliyuncs.IAcsClient;
- import com.aliyuncs.dm.model.v20151123.SingleSendMailRequest;
- import com.aliyuncs.dm.model.v20151123.SingleSendMailResponse;
- import com.aliyuncs.profile.DefaultProfile;
- import com.aliyuncs.profile.IClientProfile;
- public class SendAliyunEmail {
- public static void main(String[] args) {
- // 如果是除杭州 region 外的其它 region(如新加坡, 澳洲 Region), 需要将下面的 "cn-hangzhou" 替换为 "ap-southeast-1", 或 "ap-southeast-2".
- IClientProfile profile = DefaultProfile.getProfile("cn-hangzhou", "####", "####");
- // 如果是除杭州 region 外的其它 region(如新加坡 region), 需要做如下处理
- /*try {
- DefaultProfile.addEndpoint("dm.cn-hangzhou.aliyuncs.com", "cn-hangzhou", "Dm", "dm.cn-hangzhou.aliyuncs.com");
- } catch (ClientException e) {
- e.printStackTrace();
- }*/
- IAcsClient client = new DefaultAcsClient(profile);
- SingleSendMailRequest request = new SingleSendMailRequest();
- try {
- //request.setVersion("2017-06-22");// 如果是除杭州 region 外的其它 region(如新加坡 region), 必须指定为 2017-06-22
- request.setAccountName("####");
- request.setFromAlias("华尔街");
- request.setAddressType(1);
- request.setReplyToAddress(true);
- //request.setToAddress("目标地址");
- // 可以给多个收件人发送邮件, 收件人之间用逗号分开, 批量发信建议使用 BatchSendMailRequest 方式
- request.setToAddress("####@foxmail.com");
- request.setSubject("注册验证");
- request.sethtmlBody("欢迎注册华尔街, 你的验证码是 090706");
- SingleSendMailResponse httpResponse = client.getAcsResponse(request);
- System.out.println(httpResponse);
- } catch (Exception e) {
- e.printStackTrace();
- }
- }
- }
来源: http://www.jianshu.com/p/e9a41cfea7cc