小前提:
- java:springboot框架,maven版本管理。
- 阿里云:有账号,已经进行实名认证。
java对接阿里云短信服务详解(验证码,推广短信,通知短信)
阿里云登录地址:https://account.aliyun.com/login/login.htm


创建用户组

添加完成后进入用户组,并为其添加权限:

创建用户



阿里云短信服务地址:https://dysms.console.aliyun.com/dysms.htm

在概览中直接点击立即开通短信服务!接下来点击快速学习:

点击添加签名,添加模板,去向阿里云申请自己定义的签名和短信模板!
打个时间戳 2023-1-13 ,我在写这篇文章的时候正在申请,现在的要求已经相当严格了,我被驳回好几次,所以填写相关信息的时候还是要认真一些哦


模板和签名申请提交后等待申请结果通过即可!
(可能是快过年了,审核超级慢,一般三个小时还没好,好了又驳回,
一次是官网没有体现出哪里需要用短信验证,
一次是应用商店没有搜索到app
祝大家申请的时候最好写好一遍过吧)
呃 写这边文章的时候又失败一次。

我签名是选的测试或学习,


点击 短信服务 控制台

点击 国内消息 我们需要添加一个签名和模板
签名和模板需要审核,一般两小时内审核。

ok 这里先审核。小编审核的时候特别慢,而且被打回好几次,所以大家填写资料的时候尽量详细吧。
这里审核这 我们去配置一下项目。
Spring Boot版本我使用的是2.3.x:
<!-- aliyun sms SDK -->
<dependency>
<groupId>com.aliyun</groupId>
<artifactId>aliyun-java-sdk-core</artifactId>
<version>4.5.3</version>
</dependency>
<!-- fastjson -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>1.2.68</version>
</dependency>
<!-- redis -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
@SpringBootTest
class AliyunSmsDemoApplicationTests {
@Test
void contextLoads() {
/**
* 连接阿里云:
*
* 三个参数:
* regionId 不要动,默认使用官方的
* accessKeyId 自己的用户accessKeyId
* accessSecret 自己的用户accessSecret
*/
DefaultProfile profile = DefaultProfile.getProfile(
"cn-hu", "LTAI4GKDXXXXXB", "1bc8pXXXXXXXXXXXXXXctBMMCI");
IAcsClient client = new DefaultAcsClient(profile);
// 构建请求:
CommonRequest request = new CommonRequest();
request.setSysMethod(MethodType.POST);
request.setSysDomain("dysmsapi.aliyuncs.com");
request.setSysVersion("2019-05-25");
request.setSysAction("SendSms");
// 自定义参数:
request.putQueryParameter("PhoneNumbers", "xxxxx0441");// 接收短信的手机号
request.putQueryParameter("SignName", "C上商城");// 短信签名
request.putQueryParameter("TemplateCode", "SMS_20xxxxx74");// 短信模版CODE
// 构建短信验证码
Map<String,Object> map = new HashMap<>();
map.put("code",1234);// 这里仅用于测试,所以验证码写死
request.putQueryParameter("TemplateParam", JSONObject.toJSONString(map));
try {
CommonResponse response = client.getCommonResponse(request);
System.out.println(response.getData());
} catch (ServerException e) {
e.printStackTrace();
} catch (ClientException e) {
e.printStackTrace();
}
}
}
application.yml和application.properties是同一个作用的文件,有些小白可能不太理解,这里看一下项目里使用的是那个后缀的配置文件,将内容复制进去即可。
application.yml
server:
port: 8080
# spring相关配置
spring:
redis:
# Redis数据库索引(默认为0)
database: 0
# Redis服务器地址
host: 8.xxx.xx.xx6
# Redis服务器连接端口
port: 6379
# Redis服务器连接密码(默认为空)
password: cspxxxxxxx
jedis:
pool:
# 连接池最大连接数(使用负值表示没有限制)
max-active: 8
# 连接池最大阻塞等待时间(使用负值表示没有限制)
max-wait: -1
# 连接池中的最大空闲连接
max-idle: 8
# 连接池中的最小空闲连接
min-idle: 0
# 连接超时时间(毫秒)
timeout: 8000
application.properties
# accessKeyId
aliyun.sms.accessKeyId=LTAI4xxxxxxxxxxV9B
# accessKeySecret
aliyun.sms.accessKeySecret=LTAI4xxxxxxxxxxV8V9B
# 短信模板Code
aliyun.sms.templateCode=SMS_xxxxx74
@RestController
public class AliyunSmsApiController {
@Autowired
private AliyunSendSmsService aliyunSendSmsService;
@Autowired
private RedisTemplate<String, String> redisTemplate;
@Value("${aliyun.sms.templateCode}")
private String templateCode;
/**
* 短信发送
*
* @param phone
* @return
*/
@GetMapping("/send/{phone}")
public String sendCode(@PathVariable("phone") String phone) {
// 根据手机号从redis中拿验证码
String code = redisTemplate.opsForValue().get(phone);
if (!StringUtils.isEmpty(code)) {
return phone + " : " + code + "已经存在,还没有过期!";
}
// 如果redis 中根据手机号拿不到验证码,则生成4位随机验证码
code = UUID.randomUUID().toString().substring(0, 4);
// 验证码存入codeMap
Map<String, Object> codeMap = new HashMap<>();
codeMap.put("code", code);
// 调用aliyunSendSmsService发送短信
Boolean bool = aliyunSendSmsService.sendMessage(phone, templateCode, codeMap);
if (bool) {
// 如果发送成功,则将生成的4位随机验证码存入redis缓存,5分钟后过期
redisTemplate.opsForValue().set(phone, code, 5, TimeUnit.MINUTES);
return phone + " : " + code + "发送成功!";
} else {
return phone + " : " + code + "发送失败!";
}
}
}
@Service
public class AliyunSendSmsService {
@Value("${aliyun.sms.accessKeyId}")
private String accessKeyId;
@Value("${aliyun.sms.accessKeySecret}")
private String accessKeySecret;
/**
* 发送短信验证码
*
* @param phone 接收短信的手机号
* @param templateCode 短信模板CODE
* @param codeMap 验证码map 集合
* @return
*/
public Boolean sendMessage(String phone, String templateCode, Map<String, Object> codeMap) {
/**
* 连接阿里云:
*
* 三个参数:
* regionId 不要动,默认使用官方的
* accessKeyId 自己的用户accessKeyId
* accessSecret 自己的用户accessSecret
*/
DefaultProfile profile = DefaultProfile.getProfile(
"cn-hangzhou", accessKeyId, accessKeySecret);
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("PhoneNumbers", phone);// 手机号
request.putQueryParameter("SignName", "CSP网上商城");// 短信签名
request.putQueryParameter("TemplateCode", templateCode);// 短信模版CODE
// 构建短信验证码
request.putQueryParameter("TemplateParam", JSONObject.toJSONString(codeMap));
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;
}
}

手机收到短信验证码!
我正在尝试使用ruby和Savon来使用网络服务。测试服务为http://www.webservicex.net/WS/WSDetails.aspx?WSID=9&CATID=2require'rubygems'require'savon'client=Savon::Client.new"http://www.webservicex.net/stockquote.asmx?WSDL"client.get_quotedo|soap|soap.body={:symbol=>"AAPL"}end返回SOAP异常。检查soap信封,在我看来soap请求没有正确的命名空间。任何人都可以建议我
我想安装一个带有一些身份验证的私有(private)Rubygem服务器。我希望能够使用公共(public)Ubuntu服务器托管内部gem。我读到了http://docs.rubygems.org/read/chapter/18.但是那个没有身份验证-如我所见。然后我读到了https://github.com/cwninja/geminabox.但是当我使用基本身份验证(他们在他们的Wiki中有)时,它会提示从我的服务器获取源。所以。如何制作带有身份验证的私有(private)Rubygem服务器?这是不可能的吗?谢谢。编辑:Geminabox问题。我尝试“捆绑”以安装新的gem..
我真的很习惯使用Ruby编写以下代码:my_hash={}my_hash['test']=1Java中对应的数据结构是什么? 最佳答案 HashMapmap=newHashMap();map.put("test",1);我假设? 关于java-等价于Java中的RubyHash,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/22737685/
最近,当我启动我的Rails服务器时,我收到了一长串警告。虽然它不影响我的应用程序,但我想知道如何解决这些警告。我的估计是imagemagick以某种方式被调用了两次?当我在警告前后检查我的git日志时。我想知道如何解决这个问题。-bcrypt-ruby(3.1.2)-better_errors(1.0.1)+bcrypt(3.1.7)+bcrypt-ruby(3.1.5)-bcrypt(>=3.1.3)+better_errors(1.1.0)bcrypt和imagemagick有关系吗?/Users/rbchris/.rbenv/versions/2.0.0-p247/lib/ru
在Rails4.0.2中,我使用s3_direct_upload和aws-sdkgems直接为s3存储桶上传文件。在开发环境中它工作正常,但在生产环境中它会抛出如下错误,ActionView::Template::Error(noimplicitconversionofnilintoString)在View中,create_cv_url,:id=>"s3_uploader",:key=>"cv_uploads/{unique_id}/${filename}",:key_starts_with=>"cv_uploads/",:callback_param=>"cv[direct_uplo
我想在Ruby中创建一个用于开发目的的极其简单的Web服务器(不,不想使用现成的解决方案)。代码如下:#!/usr/bin/rubyrequire'socket'server=TCPServer.new('127.0.0.1',8080)whileconnection=server.acceptheaders=[]length=0whileline=connection.getsheaders想法是从命令行运行这个脚本,提供另一个脚本,它将在其标准输入上获取请求,并在其标准输出上返回完整的响应。到目前为止一切顺利,但事实证明这真的很脆弱,因为它在第二个请求上中断并出现错误:/usr/b
您如何在Rails中的实时服务器上进行有效调试,无论是在测试版/生产服务器上?我试过直接在服务器上修改文件,然后重启应用,但是修改好像没有生效,或者需要很长时间(缓存?)我也试过在本地做“脚本/服务器生产”,但是那很慢另一种选择是编码和部署,但效率很低。有人对他们如何有效地做到这一点有任何见解吗? 最佳答案 我会回答你的问题,即使我不同意这种热修补服务器代码的方式:)首先,你真的确定你已经重启了服务器吗?您可以通过跟踪日志文件来检查它。您更改的代码显示的View可能会被缓存。缓存页面位于tmp/cache文件夹下。您可以尝试手动删除
我正在尝试使用boilerpipe来自JRuby。我看过guide从JRuby调用Java,并成功地将它与另一个Java包一起使用,但无法弄清楚为什么同样的东西不能用于boilerpipe。我正在尝试基本上从JRuby中执行与此Java等效的操作:URLurl=newURL("http://www.example.com/some-location/index.html");Stringtext=ArticleExtractor.INSTANCE.getText(url);在JRuby中试过这个:require'java'url=java.net.URL.new("http://www
我只想对我一直在思考的这个问题有其他意见,例如我有classuser_controller和classuserclassUserattr_accessor:name,:usernameendclassUserController//dosomethingaboutanythingaboutusersend问题是我的User类中是否应该有逻辑user=User.newuser.do_something(user1)oritshouldbeuser_controller=UserController.newuser_controller.do_something(user1,user2)我
什么是ruby的rack或python的Java的wsgi?还有一个路由库。 最佳答案 来自Python标准PEP333:Bycontrast,althoughJavahasjustasmanywebapplicationframeworksavailable,Java's"servlet"APImakesitpossibleforapplicationswrittenwithanyJavawebapplicationframeworktoruninanywebserverthatsupportstheservletAPI.ht