阿里大于短信接口调用

//参数名称必须为String PhoneNumbers , String SignName(短信签名),String TemplateCode (短信模板码)
public class SMSUtils {
   
	public static void SendSMS(String PhoneNumbers , String SignName,String TemplateCode ,HttpServletRequest req ) 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个手机号码,批量调用相对于单条调用及时性稍有延迟,验证码类型的短信推荐使用单条调用的方式
		request.setPhoneNumbers(PhoneNumbers);
		// 必填:短信签名-可在短信控制台中找到
		request.setSignName(SignName);
		// 必填:短信模板-可在短信控制台中找到
		request.setTemplateCode(TemplateCode);
		//request.setTemplateCode("SMS_116580423");
		// 可选:模板中的变量替换JSON串,如模板内容为"亲爱的${name},您的验证码为${code}"时,此处的值为
		// 友情提示:如果JSON中需要带换行符,请参照标准的JSON协议对换行符的要求,比如短信内容中包含\r\n的情况在JSON中需要表示成\\r\\n,否则会导致JSON在服务端解析失败
		//随机生成一个六位的数字验证码
		int random = (int) ((Math.random()*9+1)*100000);	
		request.setTemplateParam("{\"code\":\"" + random + "\"}");
		//将手机号和验证码放在session域中
		req.getSession().setAttribute(PhoneNumbers, random);
		req.getSession().setMaxInactiveInterval(900);
		// 可选-上行短信扩展码(无特殊需求用户请忽略此字段)
		// request.setSmsUpExtendCode("90997");
		// 可选:outId为提供给业务方扩展字段,最终在短信回执消息中将此值带回给调用者
		 request.setOutId("yourOutId");
		//请求失败这里会抛ClientException异常
		 SendSmsResponse sendSmsResponse = acsClient.getAcsResponse(request);
		 if(sendSmsResponse.getCode() != null && sendSmsResponse.getCode().equals("OK")) {
		 //请求成功
	}
}

}


调用短信方法
@Controller
@RequestMapping("/Verify")
public class VerifyController {
	 @Autowired
	 private SetStateService setstateservice;
	
	//用户发送验证码(点击发送验证码)
	@RequestMapping("/sendSMS")
	@ResponseBody
	public Result SendSMS( String userPhone,HttpServletRequest req) throws Exception{
	Result result = new Result();
	String PhoneNumbers = req.getParameter("userPhone");
	SMSUtils.SendSMS(PhoneNumbers, "短信签名", "SMS_******",req);
	}
	
	

	//用户验证
	@RequestMapping("/setState")
	@ResponseBody
	public Result setState( YUser user, HttpServletRequest request){
		Result result = new Result();
		String userPhone = user.getUserPhone();
		String code = user.getVerificationCode();
		Object object = request.getSession().getAttribute(userPhone);
		if(object==null ){
			result.setData("0");
			result.setState("请发送验证码");
			return result;
		}
		//进行验证
	   if(object.toString().equals(code)){
	   //公司要求验证后要求创建一个user
		    YUser yUser = new YUser();
		    yUser.setUserPhone(userPhone);
		    yUser.setUserState(1);
		    setstateservice.setUser(yUser);
		    Integer id = yUser.getId();
		    System.out.println(yUser.getId());
			result.setData(id+"");
			result.setState("success");
			result.setObject(user);
			return result;
		}
			result.setData("0");
			result.setState("error");
			return result;
	}

jar包为官方sdk中 aliyun-java-sdk-core-3.3.1,aliyun-java-sdk-dysmsapi-1.0.0.jar


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值