阿里云函数计算发送短信单文件轻量版

本文涉及的产品
函数计算FC,每月15万CU 3个月
简介: 本文实现了使用阿里云《函数计算》+《短信服务》发送短信的简单功能,官方短信服务SDK功能全面,但较为冗杂,二爷精简了官方SDK,实现了一段代码(单文件)发送短信的功能。 阅读本文,你需要先了解阿里云函数计算、阿里云短信服务的基本常识。 试用本代码,需要预先在短信服务中申请短信签名、短信模板。

本文实现了使用阿里云《函数计算》+《短信服务》发送短信的简单功能,官方短信服务SDK功能全面,但较为冗杂,二爷精简了官方SDK,实现了一段代码(单文件)发送短信的功能。

阅读本文,你需要先了解阿里云函数计算、阿里云短信服务的基本常识。

试用本代码,需要预先在短信服务中申请短信签名、短信模板。

# -*- coding: utf-8 -*-
import uuid
from aliyunsdkcore.client import AcsClient
from aliyunsdkcore.request import RpcRequest

# 短信发送单文件轻量版(阿里云函数计算+Python3环境测试通过),Created on 2018-06-30

#注意不要更改
REGION = "cn-hangzhou"
PRODUCT_NAME = "Dysmsapi"
DOMAIN = "dysmsapi.aliyuncs.com"

ACCESS_KEY_ID = "您在阿里云申请的ACCESS_KEY_ID"
ACCESS_KEY_SECRET = "您在阿里云申请的ACCESS_KEY_SECRET"

acs_client = AcsClient(ACCESS_KEY_ID, ACCESS_KEY_SECRET, REGION)

class SendSmsRequest(RpcRequest):
	def __init__(self):
		RpcRequest.__init__(self, 'Dysmsapi', '2017-05-25', 'SendSms')
	def get_TemplateCode(self):
		return self.get_query_params().get('TemplateCode')
	def set_TemplateCode(self,TemplateCode):
		self.add_query_param('TemplateCode',TemplateCode)
	def get_PhoneNumbers(self):
		return self.get_query_params().get('PhoneNumbers')
	def set_PhoneNumbers(self,PhoneNumbers):
		self.add_query_param('PhoneNumbers',PhoneNumbers)
	def get_SignName(self):
		return self.get_query_params().get('SignName')
	def set_SignName(self,SignName):
		self.add_query_param('SignName',SignName)
	def get_ResourceOwnerAccount(self):
		return self.get_query_params().get('ResourceOwnerAccount')
	def set_ResourceOwnerAccount(self,ResourceOwnerAccount):
		self.add_query_param('ResourceOwnerAccount',ResourceOwnerAccount)
	def get_TemplateParam(self):
		return self.get_query_params().get('TemplateParam')
	def set_TemplateParam(self,TemplateParam):
		self.add_query_param('TemplateParam',TemplateParam)
	def get_ResourceOwnerId(self):
		return self.get_query_params().get('ResourceOwnerId')
	def set_ResourceOwnerId(self,ResourceOwnerId):
		self.add_query_param('ResourceOwnerId',ResourceOwnerId)
	def get_OwnerId(self):
		return self.get_query_params().get('OwnerId')
	def set_OwnerId(self,OwnerId):
		self.add_query_param('OwnerId',OwnerId)
	def get_SmsUpExtendCode(self):
		return self.get_query_params().get('SmsUpExtendCode')
	def set_SmsUpExtendCode(self,SmsUpExtendCode):
		self.add_query_param('SmsUpExtendCode',SmsUpExtendCode)
	def get_OutId(self):
		return self.get_query_params().get('OutId')
	def set_OutId(self,OutId):
		self.add_query_param('OutId',OutId)

def send_sms(business_id, phone_numbers, sign_name, template_code, template_param=None):
	smsRequest = SendSmsRequest()
	smsRequest.set_OutId(business_id)				#设置业务请求流水号,必填
	smsRequest.set_PhoneNumbers(phone_numbers)			#短信发送的号码列表,必填
	smsRequest.set_SignName(sign_name)				#短信签名
	smsRequest.set_TemplateCode(template_code)			#申请的短信模板编码,必填
	if template_param is not None:
		smsRequest.set_TemplateParam(template_param)		#短信模板变量参数

	smsResponse = acs_client.do_action_with_exception(smsRequest)	#调用短信发送接口,返回json
	# TODO 业务处理
	return smsResponse

def handler(event, context):

	__business_id = uuid.uuid4()
	params='{"product":"糕点"}'
	return send_sms(__business_id,"13000000000","您的短信签名","您申请的短信模板",params)


执行结果数据为json格式,发送成功返回的数据:


 {
   "Message": "OK",
   "RequestId": "6C801F2D-8DC4-4F39-9CBD-F3DC0C28C21B",
   "BizId": "221005030328791139^0",
   "Code": "OK"
} 

发送失败返回的部分数据示例(手机号码错误):


 {
   "Message": "13135656invalid mobile number",
   "RequestId": "45614ADE-587C-4E78-97A7-71DAA2582403",
   "Code": "isv.MOBILE_NUMBER_ILLEGAL"
} 

目前阿里云官方提供了更简单的代码,使用是 CommonRequest替代了 RpcRequest,代码量更减少了,推荐使用官方的方法。

相关实践学习
【文生图】一键部署Stable Diffusion基于函数计算
本实验教你如何在函数计算FC上从零开始部署Stable Diffusion来进行AI绘画创作,开启AIGC盲盒。函数计算提供一定的免费额度供用户使用。本实验答疑钉钉群:29290019867
建立 Serverless 思维
本课程包括: Serverless 应用引擎的概念, 为开发者带来的实际价值, 以及让您了解常见的 Serverless 架构模式
相关文章
|
16天前
|
分布式计算 运维 搜索推荐
立马耀:通过阿里云 Serverless Spark 和 Milvus 构建高效向量检索系统,驱动个性化推荐业务
蝉妈妈旗下蝉选通过迁移到阿里云 Serverless Spark 及 Milvus,解决传统架构性能瓶颈与运维复杂性问题。新方案实现离线任务耗时减少40%、失败率降80%,Milvus 向量检索成本降低75%,支持更大规模数据处理,查询响应提速。
130 57
|
1月前
|
Cloud Native Serverless 流计算
云原生时代的应用架构演进:从微服务到 Serverless 的阿里云实践
云原生技术正重塑企业数字化转型路径。阿里云作为亚太领先云服务商,提供完整云原生产品矩阵:容器服务ACK优化启动速度与镜像分发效率;MSE微服务引擎保障高可用性;ASM服务网格降低资源消耗;函数计算FC突破冷启动瓶颈;SAE重新定义PaaS边界;PolarDB数据库实现存储计算分离;DataWorks简化数据湖构建;Flink实时计算助力风控系统。这些技术已在多行业落地,推动效率提升与商业模式创新,助力企业在数字化浪潮中占据先机。
135 12
|
3月前
|
存储 分布式计算 物联网
美的楼宇科技基于阿里云 EMR Serverless Spark 构建 LakeHouse 湖仓数据平台
美的楼宇科技基于阿里云 EMR Serverless Spark 建设 IoT 数据平台,实现了数据与 AI 技术的有效融合,解决了美的楼宇科技设备数据量庞大且持续增长、数据半结构化、数据价值缺乏深度挖掘的痛点问题。并结合 EMR Serverless StarRocks 搭建了 Lakehouse 平台,最终实现不同场景下整体性能提升50%以上,同时综合成本下降30%。
367 58
|
3月前
|
Kubernetes 监控 Serverless
基于阿里云Serverless Kubernetes(ASK)的无服务器架构设计与实践
无服务器架构(Serverless Architecture)在云原生技术中备受关注,开发者只需专注于业务逻辑,无需管理服务器。阿里云Serverless Kubernetes(ASK)是基于Kubernetes的托管服务,提供极致弹性和按需付费能力。本文深入探讨如何使用ASK设计和实现无服务器架构,涵盖事件驱动、自动扩展、无状态设计、监控与日志及成本优化等方面,并通过图片处理服务案例展示具体实践,帮助构建高效可靠的无服务器应用。
|
3月前
|
Cloud Native 安全 Serverless
云原生应用实战:基于阿里云Serverless的API服务开发与部署
随着云计算的发展,Serverless架构日益流行。阿里云函数计算(Function Compute)作为Serverless服务,让开发者无需管理服务器即可运行代码,按需付费,简化开发运维流程。本文从零开始,介绍如何使用阿里云函数计算开发简单的API服务,并探讨其核心优势与最佳实践。通过Python示例,演示创建、部署及优化API的过程,涵盖环境准备、代码实现、性能优化和安全管理等内容,帮助读者快速上手Serverless开发。
|
3月前
|
SQL 存储 OLAP
阿里云 EMR Serverless StarRocks3.x,极速统一的湖仓新范式
阿里云 EMR Serverless StarRocks3.x,极速统一的湖仓新范式
|
3月前
|
SQL 分布式计算 Serverless
基于阿里云 EMR Serverless Spark 版快速搭建OSS日志分析应用
基于阿里云 EMR Serverless Spark 版快速搭建OSS日志分析应用
|
16天前
|
SQL 分布式计算 Serverless
鹰角网络:EMR Serverless Spark 在《明日方舟》游戏业务的应用
鹰角网络为应对游戏业务高频活动带来的数据潮汐、资源弹性及稳定性需求,采用阿里云 EMR Serverless Spark 替代原有架构。迁移后实现研发效率提升,支持业务快速发展、计算效率提升,增强SLA保障,稳定性提升,降低运维成本,并支撑全球化数据架构部署。
173 56
鹰角网络:EMR Serverless Spark 在《明日方舟》游戏业务的应用
|
1月前
|
人工智能 开发框架 安全
Serverless MCP 运行时业界首发,函数计算让 AI 应用最后一公里提速
作为云上托管 MCP 服务的最佳运行时,函数计算 FC 为阿里云百炼 MCP 提供弹性调用能力,用户只需提交 npx 命令即可“零改造”将开源 MCP Server 部署到云上,函数计算 FC 会准备好计算资源,并以弹性、可靠的方式运行 MCP 服务,按实际调用时长和次数计费,欢迎你在阿里云百炼和函数计算 FC 上体验 MCP 服务。
231 29
|
4月前
|
人工智能 运维 物联网
云大使 X 函数计算 FC 专属活动上线!享返佣,一键打造 AI 应用
如今,AI 技术已经成为推动业务创新和增长的重要力量。但对于许多企业和开发者来说,如何高效、便捷地部署和管理 AI 应用仍然是一个挑战。阿里云函数计算 FC 以其免运维的特点,大大降低了 AI 应用部署的复杂性。用户无需担心底层资源的管理和运维问题,可以专注于应用的创新和开发,并且用户可以通过一键部署功能,迅速将 AI 大模型部署到云端,实现快速上线和迭代。函数计算目前推出了多种规格的云资源优惠套餐,用户可以根据实际需求灵活选择。

热门文章

最新文章