原创

Spring Boot中对接Twilio以实现发送验证码和验证短信码

Twilio介绍

Twilio是一家提供云通信服务的公司,旨在帮助开发者和企业通过简单的API实现各种通信功能。以下是Twilio的一些主要特点和服务介绍:

核心功能

  • 短信服务(SMS):允许用户通过API发送和接收短信,支持全球范围内的短信发送。
  • 语音通话:提供语音通话的API,支持拨打和接听电话,语音识别等功能。
  • 视频通话:支持实时视频通话和视频会议,适用于各种应用场景。
  • 聊天服务:提供多种聊天功能,包括Web聊天、SMS聊天和社交媒体集成。
  • 电子邮件服务:通过SendGrid(Twilio收购的公司)提供电子邮件发送和管理服务。

代码工程

1. 添加依赖

在你的pom.xml中添加Twilio的依赖:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <parent>
        <artifactId>springboot-demo</artifactId>
        <groupId>com.et</groupId>
        <version>1.0-SNAPSHOT</version>
    </parent>
    <modelVersion>4.0.0</modelVersion>

    <artifactId>Twilio</artifactId>

    <properties>
        <maven.compiler.source>8</maven.compiler.source>
        <maven.compiler.target>8</maven.compiler.target>
    </properties>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-autoconfigure</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>com.twilio.sdk</groupId>
            <artifactId>twilio</artifactId>
            <version>8.25.0</version> 
        </dependency>
    </dependencies>
</project>

2. 配置Twilio

application.propertiesapplication.yml中添加Twilio的配置:

twilio.account-sid=你的Twilio账户SID
twilio.auth-token=你的Twilio认证Token
twilio.phone-number=你的Twilio电话号码

3. 创建Twilio配置类

创建一个配置类来初始化Twilio客户端:

package com.et.twilio.config;

import com.twilio.Twilio;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

@Configuration
public class TwilioConfig {

    @Value("${twilio.account-sid}")
    private String accountSid;

    @Value("${twilio.auth-token}")
    private String authToken;

    @Bean
    public void init() {
        Twilio.init(accountSid, authToken);
    }
}

4. 创建服务类

创建一个服务类来处理发送验证码和验证短信码的逻辑:

package com.et.twilio.service;

import com.twilio.rest.api.v2010.account.Message;
import com.twilio.type.PhoneNumber;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Service;

import java.util.HashMap;
import java.util.Map;
import java.util.Random;

@Service
public class SmsService {

    @Value("${twilio.phone-number}")
    private String twilioPhoneNumber;

    private Map<String, String> verificationCodes = new HashMap<>();

    public void sendVerificationCode(String toPhoneNumber) {
        String code = generateVerificationCode();
        verificationCodes.put(toPhoneNumber, code);

        Message.creator(
                new PhoneNumber(toPhoneNumber),
                new PhoneNumber(twilioPhoneNumber),
                "Your verification code is: " + code)
                .create();
    }

    public boolean verifyCode(String phoneNumber, String code) {
        String storedCode = verificationCodes.get(phoneNumber);
        return storedCode != null && storedCode.equals(code);
    }

    private String generateVerificationCode() {
        Random random = new Random();
        return String.format("%06d", random.nextInt(1000000)); // 生成6位验证码
    }
}

5. 创建控制器

创建一个控制器来处理HTTP请求:

package com.et.twilio.controller;

import com.et.twilio.service.SmsService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;

@RestController
@RequestMapping("/api/sms")
public class SmsController {

    @Autowired
    private SmsService smsService;

    @PostMapping("/send")
    public String sendVerificationCode(@RequestParam String phoneNumber) {
        smsService.sendVerificationCode(phoneNumber);
        return "Verification code sent!";
    }

    @PostMapping("/verify")
    public String verifyCode(@RequestParam String phoneNumber, @RequestParam String code) {
        boolean isValid = smsService.verifyCode(phoneNumber, code);
        return isValid ? "Verification successful!" : "Invalid verification code!";
    }
}

6. 测试功能

启动你的Spring Boot应用程序,并使用Postman或其他工具测试以下API:

  • 发送验证码:POST /api/sms/send?phoneNumber=目标手机号
  • 验证验证码:POST /api/sms/verify?phoneNumber=目标手机号&code=验证码

注意事项

  • 确保你的Twilio账户已验证并且可以发送短信。
  • 处理验证码的存储和过期逻辑,以防止滥用。
  • 考虑使用更安全的存储方式(如数据库)来存储验证码,而不是使用内存中的Map。

这样,你就可以在Spring Boot中实现与Twilio的集成,发送和验证短信验证码的功能

正文到此结束
Loading...