详细介绍Java阿里云的短信验证码实现
阿里云手机短信验证码
第一步 登录阿里云开放平台
1、进入阿里云开放平台---->点击控制台
2、点击AccessKey管理
3、点击之后会弹出提示,选择开始使用子用户
4、新建一个用户组,然后按要求填写即可
5、创建一个用户,按要求填写内容,勾选编程访问
6、会得到AccessKey(id,密码)
要将这个账号保存下来!
//用户登录名称 ==================== //AccessKey ID ==================== //AccessKey Secret ============================
第二步,开通阿里云短信服务
1、找到短信控制台面板,点击国内消息
2、选择模板管理,点击添加模板
以下内容按要求填写即可,申请说明需要有正当理由不然审核可能通不过
点击提交,等待审核
3、步骤同上,点击签名管理,添加签名
注:签名需要填写应用名称、网站名称 例如:(dy学习网站) 个人用户选择适用场景的时候选择验证码,申请说明需要填写正当理由。不然可能审核不通过。
提交后等待审核通过即可。
第三步,编写代码测试
1、新建项目
创建一个Java项目,笔者创建的是SpringBoot项目
2、添加依赖
点击快速学习——> 查看APIDemo,里面会有maven的依赖和官方的Demo
maven依赖:
<dependency> <groupId>com.aliyun</groupId> <artifactId>aliyun-java-sdk-core</artifactId> <version>4.5.0</version> </dependency>
3、编写代码
简单测试,结合了redis的使用
controller:
package com.qxx.sendmessage.controller; import com.qxx.sendmessage.service.SendMessage; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.redis.core.RedisTemplate; import org.springframework.util.StringUtils; import org.springframework.web.bind.annotation.CrossOrigin; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RestController; import java.util.HashMap; import java.util.UUID; import java.util.concurrent.TimeUnit; /** * @author 东亚猛男Qxx */ @RestController @CrossOrigin //跨域的支持 public class Controller { @Autowired private SendMessage sendMessage; @Autowired private RedisTemplate<String,String> template; //RestFul风格请求 @GetMapping("/send/{phone}") public String send(@PathVariable("phone") String phone){ //先看redis里面该手机号储存的验证码是否失效 String code = template.opsForValue().get(phone); if (!StringUtils.isEmpty(code)){ return phone+":"+"验证码尚未过期!"; } //截取6为字符当作验证码(UUID) code = UUID.randomUUID().toString().substring(0, 5); HashMap<String,Object> map = new HashMap<>(); //key必须为code map.put("code",code); //调用service层的方法 传两个参数:phone,map Boolean flag = sendMessage.sendMessage(phone,map); if (flag){ //存入redis,设置失效时间 template.opsForValue().set(phone,code,5, TimeUnit.MINUTES); return phone+":"+"验证码"+code+"发送成功!"; } return "发送失败"; } }
service:
package com.qxx.sendmessage.service.impl; import com.alibaba.fastjson.JSONObject; import com.aliyuncs.CommonRequest; import com.aliyuncs.CommonResponse; import com.aliyuncs.DefaultAcsClient; import com.aliyuncs.IAcsClient; import com.aliyuncs.exceptions.ClientException; import com.aliyuncs.exceptions.ServerException; import com.aliyuncs.http.MethodType; import com.aliyuncs.profile.DefaultProfile; import com.qxx.sendmessage.service.SendMessage; import org.springframework.stereotype.Service; import java.util.HashMap; import java.util.Map; /** * @author 东亚猛男Qxx */ @Service public class SendMessageImpl implements SendMessage { @Override public Boolean sendMessage(String phoneNum,Map<String, Object> map) { System.out.println(JSONObject.toJSONString(map)); //连接阿里云,第一个参数不用改变,后两个填写自己的accessKeyId和accessSecret DefaultProfile profile = DefaultProfile.getProfile("cn-hangzhou", "<accessKeyId>", "<accessSecret>"); IAcsClient client = new DefaultAcsClient(profile); //构建请求! CommonRequest request = new CommonRequest(); request.setSysMethod(MethodType.POST); request.setSysDomain("dysmsapi.aliyuncs.com"); //不要动 request.setSysVersion("2017-05-25"); //不要动 request.setSysAction("SendSms"); //自定义参数(手机号,验证码,签名,模板) request.putQueryParameter("RegionId", "cn-hangzhou"); request.putQueryParameter("PhoneNumbers", phoneNum); request.putQueryParameter("SignName", "签名"); request.putQueryParameter("TemplateCode", "模板(SMS-*****)"); //构建一个短信的验证码 request.putQueryParameter("TemplateParam", JSONObject.toJSONString(map)); try { CommonResponse response = client.getCommonResponse(request); System.out.println(response.getData()); return response.getHttpResponse().isSuccess(); } catch (ServerException e) { e.printStackTrace(); } catch (ClientException e) { e.printStackTrace(); } return false; } }
4、测试
此处用的是postman工具
redis:
短信:
结语:
可以编写可复用的微服务接口,来实现验证码的发送,根据实际情况进行封装
到此这篇关于详细介绍Java阿里云的短信验证码实现的文章就介绍到这了,更多相关Java阿里云短信验证码内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!
赞 (0)