Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
ポートフォリオサイトのお問い合わせフォームをSendgrid + microCMSで作成したお話
Search
Nobuyoshi
December 09, 2021
Programming
1
1.5k
ポートフォリオサイトのお問い合わせフォームをSendgrid + microCMSで作成したお話
ポートフォリオサイトのお問い合わせフォームをSendgrid + microCMSで作成したお話します。
site:
https://uemu-engineer.com/
Nobuyoshi
December 09, 2021
Tweet
Share
More Decks by Nobuyoshi
See All by Nobuyoshi
仕事では採用されなかったホスティングサービス、 せっかくなのでLTで話します
uemura
0
100
Babylon.js × microCMS でフォトギャラリーサイト作った
uemura
0
250
2年ぶりにCSSアニメーションを作ったよ!
uemura
0
900
今年初めてのBabylonJsを触ってみた
uemura
0
270
Three.js(WebGL)で一年以上学習した成果と便利なクラス/ライブラリを紹介
uemura
0
320
Pug / SASS でピクロス(カービィ)を作成
uemura
0
170
僕の好きなcssプロパティ・値5選
uemura
0
480
複雑なHTML_CSS アニメーション 作品一覧 + 苦労したこと
uemura
0
150
Microcms + nuxt.jsで個人ブログサイトをデプロイした件
uemura
0
900
Other Decks in Programming
See All in Programming
MDN Web Docs に日本語翻訳でコントリビュート
ohmori_yusuke
0
400
0→1 フロントエンド開発 Tips🚀 #レバテックMeetup
bengo4com
0
480
QAフローを最適化し、品質水準を満たしながらリリースまでの期間を最短化する #RSGT2026
shibayu36
0
1.8k
Python札幌 LT資料
t3tra
7
1.1k
AI 駆動開発ライフサイクル(AI-DLC):ソフトウェアエンジニアリングの再構築 / AI-DLC Introduction
kanamasa
11
5.2k
dchart: charts from deck markup
ajstarks
3
960
2年のAppleウォレットパス開発の振り返り
muno92
PRO
0
180
Denoのセキュリティに関する仕組みの紹介 (toranoana.deno #23)
uki00a
0
220
AIの誤りが許されない業務システムにおいて“信頼されるAI” を目指す / building-trusted-ai-systems
yuya4
7
4.3k
20251212 AI 時代的 Legacy Code 營救術 2025 WebConf
mouson
0
240
ELYZA_Findy AI Engineering Summit登壇資料_AIコーディング時代に「ちゃんと」やること_toB LLMプロダクト開発舞台裏_20251216
elyza
2
1k
Navigation 3: 적응형 UI를 위한 앱 탐색
fornewid
1
540
Featured
See All Featured
Money Talks: Using Revenue to Get Sh*t Done
nikkihalliwell
0
130
Docker and Python
trallard
47
3.7k
Getting science done with accelerated Python computing platforms
jacobtomlinson
1
93
The Straight Up "How To Draw Better" Workshop
denniskardys
239
140k
ピンチをチャンスに:未来をつくるプロダクトロードマップ #pmconf2020
aki_iinuma
128
55k
Ecommerce SEO: The Keys for Success Now & Beyond - #SERPConf2024
aleyda
1
1.8k
Mobile First: as difficult as doing things right
swwweet
225
10k
The AI Revolution Will Not Be Monopolized: How open-source beats economies of scale, even for LLMs
inesmontani
PRO
3
2.8k
A designer walks into a library…
pauljervisheath
210
24k
RailsConf 2023
tenderlove
30
1.3k
Context Engineering - Making Every Token Count
addyosmani
9
590
A Modern Web Designer's Workflow
chriscoyier
698
190k
Transcript
うえむー ポートフォリオサイトのお問い合わせフォームを Sendgrid + microCMSで作成したお話 うえむー
自己紹介 Name:うえむー フロントエンドエンジニア Job Skill:html / css / scss /
javascript / jQuery / vue.js / php etc... Private Skill:next.js / React.js / nuxt.js / micro cms / go etc... Hobby:プログラミング学習・ボードゲーム・麻雀・筋トレ SNS・ブログサイト Twitter::https://twitter.com/uemuragame5683 ブログサイト:https://nu-blogsite.net/ ポートフォリオサイト:https://uemu-engineer.com/
目次 ・サイト紹介 ・Send Gridについて ・SendGridを登録・API発行 ・実装 ・まとめ
サイト紹介
サイトの紹介 https://uemu-engineer.com/
サイト全体図 domain Frame work CMS Source code control Hosting CDN
お名前.com Mail Platform
Send Gridについて
SendGrid って何? SendGridというのは全世界で利用されているメール配信プラットフォームで す。 クラウドサービスを会員登録するだけで、トランザクションメール・マーケティン グメールをメールサーバー不要で利用できます。 有料プラン・無料プランがあります。
SendGridでフリープランでできること メール送信API ・SMTPリレー ・WebAPI(HTTPS) マーケティングキャンペーン機能 上限2,000件 通数上限 12,000通/月 日本語ドキュメント 日本語での無料サポート
配信結果の把握・サプレッション管理 配信状況の確認(到達 /再送/エラー等) 開封・クリックの測定 配信停止管理 独自ドメイン利用 etc...
改修内容 Mail Platform お問い合わせ フォーム Headless cms 変更前 変更後 Headless
cms お問い合わせ フォーム mail
SenadGridを登録・API発行
SendGridを登録・API発行する 仮登録完了メール受信 されるので本登録 「ユーザー情報を登録」 ボタンを押下すると新規 会員登録に遷移され本 登録 会員登録後、以下の メールが受信されユー ザ名が発行
※審査が通らないと利用できません。 「無料で始める」ボタン を押下して会員登録 「メールアドレス」を入力 して仮登録 1 2 3 4 5
SendGridを登録・API発行する API KEYSをクリッ クします。 以下の様にAPI発行される様になります。
実装編
SendGridをインストール npm install --save @sendgrid/mail package.json "dependencies" : { ...
"@sendgrid/mail" : "^7.4.7", ... }, command sendgrid/mailをnpmでインストールします。 package.jsonにsendgrid/mail をインストールされていることを 確認できます。
envを設定 NS_GRID_API_KEY='SG.XXXXXXX'
[email protected]
next.config.js module.exports = { env: { NS_GRID_API_KEY:
process.env.NS_GRID_API_KEY , NS_FROM: process.env.NS_FROM, }, ... }; .env 発行したAPIKeyを入力します 送信先のアドレスを入力します next.config.jsファイルを開き envの設定を追加します
api/send.tsx export default function handler(req, res) { if(req.method === 'POST')
{ const sgMail = require('@sendgrid/mail'); sgMail.setApiKey(process.env.NS_GRID_API_KEY); const msg = { to: req.body.email, from: process.env.NS_FROM, subject: 'お問合せありがとうございました。', text: req.body.name + '様<br><br>平素より、Nu-。。。' + req.body.body, html: req.body.name + '様<br><br>平素より、Nu-。。。' + req.body.body, }; (async () => { try { await sgMail.send(msg); } catch (error) { console.error(error); if (error.response) { console.error(error.response.body) } } })(); } res.status(200) } トランザクションメールを送信す るために、send.tsxファイルを生 成します。 その後、先ほど設定した APIキー を利用して実装します。
contact.tsx const 関数 = async e => { e.preventDefault(); const
datas = { email: email, name: name, title: title, body: body }; axios({ method: "post", url: "https://XXXXXXXXXXXXXXXXXXXXXXXX.io/api/v1/XXXXXXXX", data: datas, headers: { "Content-Type": "application/json", "X-MICROCMS-API-KEY": process.env.XXXXXXXXXXXXXXX } }) .then(() => { const contact_form = document.getElementsByClassName("c-contact__conform"); const complete_cont = ReactDOMServer.renderToStaticMarkup(<Complete />); contact_form[0].insertAdjacentHTML('afterbegin', complete_cont); axios( { method: "POST", url:'/api/send', data: datas, headers: { "Content-Type": "application/json", }, } ).then(() => { }) }) .catch(err => { console.log(err); }); } import * as React from 'react'; export default function Component() { return ( <> <div className='c-contact__complete'> <p> XXXXXXX </p> </div> </> ); } お問い合わせ内容確認を送信した時のイベント処理のコード でaxiosを利用して実装しました。 まず、microcmsでPOST送信して、送信成功したらトランザク ションメールを送信します。
実装結果 実装した結果、図のように microcmsの管理画面に受信 できて、自動送信できるようになりました。
まとめ SendGridは全世界で利用されている、メール配信プラットフォームである。 SendGridはアカウント登録するだけで、トランザクションメール・マーケティン グメールをメールサーバー不要で利用できる。 APIを発行してenvファイルに設定して、フロントに実装するだけでトランザク ションメールを送信することができる。
Thank YOU!