五分鐘快速搭建Serverless免費(fèi)郵件服務(wù)

1. 引言
本文將帶你快速基于 Azure Function 和 SendGrid 構(gòu)建一個(gè)免費(fèi)的Serverless(無服務(wù)器)的郵件發(fā)送服務(wù),讓你感受下Serverless的強(qiáng)大之處。
該服務(wù)可以每月免費(fèi)發(fā)送2,5000封,這是完全白嫖啊,感興趣的,趕緊動(dòng)起你的小手爪,噼里啪啦搞起來呀。
2. 創(chuàng)建 SendGrid 賬號(hào)
你要有一個(gè)Azure賬號(hào),沒有的話,花幾分鐘自行注冊(cè)一個(gè)就好。(我的賬號(hào)注冊(cè)在香港區(qū)域)咱們先來創(chuàng)建一個(gè)SendGrid Accounts,如下圖所示。點(diǎn)擊SendGrid Accounts后,再點(diǎn)擊創(chuàng)建SendGrid account。

填寫完畢后,點(diǎn)擊Review+Create,稍等片刻,提示部署成功,那么恭喜你,可以接著往下玩耍了。如果部署失敗,可能會(huì)因?yàn)镾endGrid屏蔽了某些區(qū)域的賬號(hào)創(chuàng)建,就只能重新注冊(cè)個(gè)Azure賬號(hào)玩耍了。
緊接著,前往剛剛創(chuàng)建的SendGrid Account,點(diǎn)擊Manage會(huì)跳轉(zhuǎn)至SendGrid管理面板。
打開后,會(huì)要求你進(jìn)去郵件驗(yàn)證,自行前往郵箱驗(yàn)證即可。
點(diǎn)擊API Keys,然后點(diǎn)擊Create API Key,填寫API Key Name,選擇 Full Access,點(diǎn)擊Create&View,記下生成的API Key,后面需要用到。
3. 創(chuàng)建第一個(gè)函數(shù)應(yīng)用
回到Azure控制臺(tái),然后搜索函數(shù)應(yīng)用。
打開后點(diǎn)擊添加,按以下圖示進(jìn)行創(chuàng)建。其中務(wù)必選擇以代碼發(fā)布,承載的操作系統(tǒng)選擇Windows。
創(chuàng)建成功后,轉(zhuǎn)到資源,如下圖所示:
依次點(diǎn)擊函數(shù),添加,選擇HTTP trigger模板,填寫函數(shù)名稱,然后指定身份驗(yàn)證級(jí)別。

點(diǎn)擊創(chuàng)建,創(chuàng)建成功后,跳轉(zhuǎn)到函數(shù)頁面,點(diǎn)擊獲取函數(shù)URL,粘貼URL到瀏覽器就可以訪問到你創(chuàng)建的第一個(gè)函數(shù)應(yīng)用。
點(diǎn)擊代碼+測(cè)試,就可以看到模板代碼,如下圖所示:
從截圖來看,這個(gè)和C#的語法并無太大差別,官方稱為C#腳本。緊接著替換 run.csx為以下代碼并點(diǎn)擊保存:
//run.csx
#r "Newtonsoft.Json"
#r "SendGrid"
using System.Net;
using Microsoft.Azure.WebJobs.Host;
using SendGrid.Helpers.Mail;
using Microsoft.Extensions.Primitives;
using Newtonsoft.Json;
public static SendGridMessage Run(Email req, ILogger log)
{
var reqStr = JsonConvert.SerializeObject(req);
log.LogInformation(reqStr);
var message = new SendGridMessage();
message.AddTo(req.To);
message.AddContent("text/html", req.Body);
message.SetFrom(new EmailAddress(req.From));
message.SetSubject(req.Subject);
return message;
}
public class Email
{
public string To { get; set; }
public string From { get; set; }
public string Subject { get; set; }
public string Body { get; set; }
}
然后修改 function.json中的配置如下,并保存。
{
"bindings": [
{
"authLevel": "function",
"name": "req",
"type": "httpTrigger",
"direction": "in",
"methods": [
"get",
"post"
]
},
{
"type": "sendGrid",
"name": "$return",
"direction": "out",
"apiKey": "SendGridAPIKeyAsAppSetting"
}
]
}
注意觀察配置項(xiàng)中需要指定 apiKey,就是我們上面創(chuàng)建SendGrid Account 中對(duì)應(yīng)的ApiKey?;氐缴厦鎰?chuàng)建的Azure Function 應(yīng)用服務(wù),然后按下圖添加上面發(fā)郵件函數(shù)需要的配置項(xiàng),如下所示。
添加完畢后,再回到函數(shù)中就可以測(cè)試運(yùn)行了,如下圖所示:
查收郵件,你將收到來自Azure Function & SendGrid 的免費(fèi)問候。

當(dāng)然,也可以通過Postman自行驗(yàn)證:
4.最后
通過以上的連環(huán)操作,相信你不僅成功薅了一把微軟的羊毛,而且順帶對(duì)Serverless也有了一定的認(rèn)知。如果對(duì)Azure Function感興趣的,不妨參考[官方文檔:https://docs.microsoft.com/en-us/azure/azure-functions/]研究一番,相信你會(huì)發(fā)掘不少玩法,順便再薅它幾把羊毛,哈哈哈!
