自己建网站流程,摄影网站大全,网站搜索功能怎样做,网站统计模块原【短信服务】更名【推送服务】
写在最前
如果这个项目让你有所收获#xff0c;记得 Star 关注哦#xff0c;这对我是非常不错的鼓励与支持。
源码地址#xff08;后端#xff09;#xff1a;https://gitee.com/csps/mingyue
源码地址#xff08;前端#xff09;记得 Star 关注哦这对我是非常不错的鼓励与支持。
源码地址后端https://gitee.com/csps/mingyue
源码地址前端https://gitee.com/csps/mingyue-ui
文档地址https://gitee.com/csps/mingyue/wikis
常用邮箱客户端
QQ邮箱 POP3: pop.qq.com使用 SSL端口号995IMAP: imap.qq.com使用 SSL端口号993SMTP: smtp.qq.com使用SSL端口号465或587 网易邮箱 POP3: pop.126.com、pop.yeah.net使用 SSL端口号995IMAP: imap.163.com,、imap.yeah.net使用 SSL端口号993SMTP: smtp.126.com、smtp.163.com使用 SSL端口号465或587 电信189邮箱 POP3: pop.189.cn使用 SSL端口号995IMAP: imap.189.cn使用 SSL端口号993SMTP: smtp.189.cn使用 SSL端口号465或587 微软Outlook邮箱 POP3: outlook.office365.com使用 TLS端口号995IMAP: outlook.office365.com使用 TLS端口号993SMTP: smtp.office365.com使用 STARTTLS端口号587
封装邮件工具
新建模块 mingyue-common-email 邮件模块
新建 Jakarta Mail 配置属性
Data
ConfigurationProperties(prefix email)
public class EmailProperties {/*** 过滤开关*/private Boolean enabled;/*** SMTP 服务器域名*/private String host;/*** SMTP 服务端口*/private Integer port;/*** 是否需要用户名密码验证*/private Boolean auth;/*** 用户名*/private String user;/*** 密码*/private String pass;/*** 发送方遵循 RFC-822 标准*/private String from;/*** 使用 STARTTLS 安全连接STARTTLS 是对纯文本通信协议的扩展。它将纯文本连接升级为加密连接TLS或SSL 而不是使用一个单独的加密通信端口。*/private Boolean starttlsEnable;/*** 使用 SSL 安全连接*/private Boolean sslEnable;/*** SMTP 超时时长单位毫秒缺省值不超时*/private Long timeout;/*** Socket 连接超时值单位毫秒缺省值不超时*/private Long connectionTimeout;}新建 Java Mail 配置类
AutoConfiguration
EnableConfigurationProperties(EmailProperties.class)
public class EmailConfiguration {BeanConditionalOnProperty(value email.enabled, havingValue true)public MailAccount mailAccount(EmailProperties emailProperties) {MailAccount account new MailAccount();account.setHost(emailProperties.getHost());account.setPort(emailProperties.getPort());account.setAuth(emailProperties.getAuth());account.setFrom(emailProperties.getFrom());account.setUser(emailProperties.getUser());account.setPass(emailProperties.getPass());account.setSocketFactoryPort(emailProperties.getPort());account.setStarttlsEnable(emailProperties.getStarttlsEnable());account.setSslEnable(emailProperties.getSslEnable());account.setTimeout(emailProperties.getTimeout());account.setConnectionTimeout(emailProperties.getConnectionTimeout());return account;}}新建邮件工具类 org.springframework.boot.autoconfigure.AutoConfiguration.importscom.csp.mingyue.common.email.config.EmailConfiguration NoArgsConstructor(access AccessLevel.PRIVATE)
public class EmailUtils {private static final MailAccount ACCOUNT SpringUtils.getBean(MailAccount.class);/*** 获取邮件发送实例*/public static MailAccount getMailAccount() {return ACCOUNT;}/*** 获取邮件发送实例 (自定义发送人以及授权码)** param user 发送人* param pass 授权码*/public static MailAccount getMailAccount(String from, String user, String pass) {ACCOUNT.setFrom(StrUtil.blankToDefault(from, ACCOUNT.getFrom()));ACCOUNT.setUser(StrUtil.blankToDefault(user, ACCOUNT.getUser()));ACCOUNT.setPass(StrUtil.blankToDefault(pass, ACCOUNT.getPass()));return ACCOUNT;}/*** 使用配置文件中设置的账户发送文本邮件发送给单个或多个收件人br* 多个收件人可以使用逗号“,”分隔也可以通过分号“;”分隔** param to 收件人* param subject 标题* param content 正文* param files 附件列表* return message-id* since 3.2.0*/public static String sendText(String to, String subject, String content, File... files) {return send(to, subject, content, false, files);}/*** 使用配置文件中设置的账户发送HTML邮件发送给单个或多个收件人br* 多个收件人可以使用逗号“,”分隔也可以通过分号“;”分隔** param to 收件人* param subject 标题* param content 正文* param files 附件列表* return message-id* since 3.2.0*/public static String sendHtml(String to, String subject, String content, File... files) {return send(to, subject, content, true, files);}/*** 使用配置文件中设置的账户发送邮件发送单个或多个收件人br* 多个收件人可以使用逗号“,”分隔也可以通过分号“;”分隔** param to 收件人* param subject 标题* param content 正文* param isHtml 是否为HTML* param files 附件列表* return message-id*/public static String send(String to, String subject, String content, boolean isHtml, File... files) {return send(splitAddress(to), subject, content, isHtml, files);}/*** 使用配置文件中设置的账户发送邮件发送单个或多个收件人br* 多个收件人、抄送人、密送人可以使用逗号“,”分隔也可以通过分号“;”分隔** param to 收件人可以使用逗号“,”分隔也可以通过分号“;”分隔* param cc 抄送人可以使用逗号“,”分隔也可以通过分号“;”分隔* param bcc 密送人可以使用逗号“,”分隔也可以通过分号“;”分隔* param subject 标题* param content 正文* param isHtml 是否为HTML* param files 附件列表* return message-id* since 4.0.3*/public static String send(String to, String cc, String bcc, String subject, String content, boolean isHtml, File... files) {return send(splitAddress(to), splitAddress(cc), splitAddress(bcc), subject, content, isHtml, files);}/*** 使用配置文件中设置的账户发送文本邮件发送给多人** param tos 收件人列表* param subject 标题* param content 正文* param files 附件列表* return message-id*/public static String sendText(CollectionString tos, String subject, String content, File... files) {return send(tos, subject, content, false, files);}/*** 使用配置文件中设置的账户发送HTML邮件发送给多人** param tos 收件人列表* param subject 标题* param content 正文* param files 附件列表* return message-id* since 3.2.0*/public static String sendHtml(CollectionString tos, String subject, String content, File... files) {return send(tos, subject, content, true, files);}/*** 使用配置文件中设置的账户发送邮件发送给多人** param tos 收件人列表* param subject 标题* param content 正文* param isHtml 是否为HTML* param files 附件列表* return message-id*/public static String send(CollectionString tos, String subject, String content, boolean isHtml, File... files) {return send(tos, null, null, subject, content, isHtml, files);}/*** 使用配置文件中设置的账户发送邮件发送给多人** param tos 收件人列表* param ccs 抄送人列表可以为null或空* param bccs 密送人列表可以为null或空* param subject 标题* param content 正文* param isHtml 是否为HTML* param files 附件列表* return message-id* since 4.0.3*/public static String send(CollectionString tos, CollectionString ccs, CollectionString bccs, String subject, String content, boolean isHtml, File... files) {return send(getMailAccount(), true, tos, ccs, bccs, subject, content, null, isHtml, files);}// ------------------------------------------------------------------------------------------------------------------------------- Custom MailAccount/*** 发送邮件给多人** param mailAccount 邮件认证对象* param to 收件人多个收件人逗号或者分号隔开* param subject 标题* param content 正文* param isHtml 是否为HTML格式* param files 附件列表* return message-id* since 3.2.0*/public static String send(MailAccount mailAccount, String to, String subject, String content, boolean isHtml, File... files) {return send(mailAccount, splitAddress(to), subject, content, isHtml, files);}/*** 发送邮件给多人** param mailAccount 邮件帐户信息* param tos 收件人列表* param subject 标题* param content 正文* param isHtml 是否为HTML格式* param files 附件列表* return message-id*/public static String send(MailAccount mailAccount, CollectionString tos, String subject, String content, boolean isHtml, File... files) {return send(mailAccount, tos, null, null, subject, content, isHtml, files);}/*** 发送邮件给多人** param mailAccount 邮件帐户信息* param tos 收件人列表* param ccs 抄送人列表可以为null或空* param bccs 密送人列表可以为null或空* param subject 标题* param content 正文* param isHtml 是否为HTML格式* param files 附件列表* return message-id* since 4.0.3*/public static String send(MailAccount mailAccount, CollectionString tos, CollectionString ccs, CollectionString bccs, String subject, String content, boolean isHtml, File... files) {return send(mailAccount, false, tos, ccs, bccs, subject, content, null, isHtml, files);}/*** 使用配置文件中设置的账户发送HTML邮件发送给单个或多个收件人br* 多个收件人可以使用逗号“,”分隔也可以通过分号“;”分隔** param to 收件人* param subject 标题* param content 正文* param imageMap 图片与占位符占位符格式为cid:$IMAGE_PLACEHOLDER* param files 附件列表* return message-id* since 3.2.0*/public static String sendHtml(String to, String subject, String content, MapString, InputStream imageMap, File... files) {return send(to, subject, content, imageMap, true, files);}/*** 使用配置文件中设置的账户发送邮件发送单个或多个收件人br* 多个收件人可以使用逗号“,”分隔也可以通过分号“;”分隔** param to 收件人* param subject 标题* param content 正文* param imageMap 图片与占位符占位符格式为cid:$IMAGE_PLACEHOLDER* param isHtml 是否为HTML* param files 附件列表* return message-id*/public static String send(String to, String subject, String content, MapString, InputStream imageMap, boolean isHtml, File... files) {return send(splitAddress(to), subject, content, imageMap, isHtml, files);}/*** 使用配置文件中设置的账户发送邮件发送单个或多个收件人br* 多个收件人、抄送人、密送人可以使用逗号“,”分隔也可以通过分号“;”分隔** param to 收件人可以使用逗号“,”分隔也可以通过分号“;”分隔* param cc 抄送人可以使用逗号“,”分隔也可以通过分号“;”分隔* param bcc 密送人可以使用逗号“,”分隔也可以通过分号“;”分隔* param subject 标题* param content 正文* param imageMap 图片与占位符占位符格式为cid:$IMAGE_PLACEHOLDER* param isHtml 是否为HTML* param files 附件列表* return message-id* since 4.0.3*/public static String send(String to, String cc, String bcc, String subject, String content, MapString, InputStream imageMap, boolean isHtml, File... files) {return send(splitAddress(to), splitAddress(cc), splitAddress(bcc), subject, content, imageMap, isHtml, files);}/*** 使用配置文件中设置的账户发送HTML邮件发送给多人** param tos 收件人列表* param subject 标题* param content 正文* param imageMap 图片与占位符占位符格式为cid:$IMAGE_PLACEHOLDER* param files 附件列表* return message-id* since 3.2.0*/public static String sendHtml(CollectionString tos, String subject, String content, MapString, InputStream imageMap, File... files) {return send(tos, subject, content, imageMap, true, files);}/*** 使用配置文件中设置的账户发送邮件发送给多人** param tos 收件人列表* param subject 标题* param content 正文* param imageMap 图片与占位符占位符格式为cid:$IMAGE_PLACEHOLDER* param isHtml 是否为HTML* param files 附件列表* return message-id*/public static String send(CollectionString tos, String subject, String content, MapString, InputStream imageMap, boolean isHtml, File... files) {return send(tos, null, null, subject, content, imageMap, isHtml, files);}/*** 使用配置文件中设置的账户发送邮件发送给多人** param tos 收件人列表* param ccs 抄送人列表可以为null或空* param bccs 密送人列表可以为null或空* param subject 标题* param content 正文* param imageMap 图片与占位符占位符格式为cid:$IMAGE_PLACEHOLDER* param isHtml 是否为HTML* param files 附件列表* return message-id* since 4.0.3*/public static String send(CollectionString tos, CollectionString ccs, CollectionString bccs, String subject, String content, MapString, InputStream imageMap, boolean isHtml, File... files) {return send(getMailAccount(), true, tos, ccs, bccs, subject, content, imageMap, isHtml, files);}// ------------------------------------------------------------------------------------------------------------------------------- Custom MailAccount/*** 发送邮件给多人** param mailAccount 邮件认证对象* param to 收件人多个收件人逗号或者分号隔开* param subject 标题* param content 正文* param imageMap 图片与占位符占位符格式为cid:$IMAGE_PLACEHOLDER* param isHtml 是否为HTML格式* param files 附件列表* return message-id* since 3.2.0*/public static String send(MailAccount mailAccount, String to, String subject, String content, MapString, InputStream imageMap, boolean isHtml, File... files) {return send(mailAccount, splitAddress(to), subject, content, imageMap, isHtml, files);}/*** 发送邮件给多人** param mailAccount 邮件帐户信息* param tos 收件人列表* param subject 标题* param content 正文* param imageMap 图片与占位符占位符格式为cid:$IMAGE_PLACEHOLDER* param isHtml 是否为HTML格式* param files 附件列表* return message-id* since 4.6.3*/public static String send(MailAccount mailAccount, CollectionString tos, String subject, String content, MapString, InputStream imageMap, boolean isHtml, File... files) {return send(mailAccount, tos, null, null, subject, content, imageMap, isHtml, files);}/*** 发送邮件给多人** param mailAccount 邮件帐户信息* param tos 收件人列表* param ccs 抄送人列表可以为null或空* param bccs 密送人列表可以为null或空* param subject 标题* param content 正文* param imageMap 图片与占位符占位符格式为cid:$IMAGE_PLACEHOLDER* param isHtml 是否为HTML格式* param files 附件列表* return message-id* since 4.6.3*/public static String send(MailAccount mailAccount, CollectionString tos, CollectionString ccs, CollectionString bccs, String subject, String content, MapString, InputStream imageMap,boolean isHtml, File... files) {return send(mailAccount, false, tos, ccs, bccs, subject, content, imageMap, isHtml, files);}/*** 根据配置文件获取邮件客户端会话** param mailAccount 邮件账户配置* param isSingleton 是否单例全局共享会话* return {link Session}* since 5.5.7*/public static Session getSession(MailAccount mailAccount, boolean isSingleton) {Authenticator authenticator null;if (mailAccount.isAuth()) {authenticator new UserPassAuthenticator(mailAccount.getUser(), mailAccount.getPass());}return isSingleton ? Session.getDefaultInstance(mailAccount.getSmtpProps(), authenticator) //: Session.getInstance(mailAccount.getSmtpProps(), authenticator);}/*** 发送邮件给多人** param mailAccount 邮件帐户信息* param useGlobalSession 是否全局共享Session* param tos 收件人列表* param ccs 抄送人列表可以为null或空* param bccs 密送人列表可以为null或空* param subject 标题* param content 正文* param imageMap 图片与占位符占位符格式为cid:${cid}* param isHtml 是否为HTML格式* param files 附件列表* return message-id* since 4.6.3*/private static String send(MailAccount mailAccount, boolean useGlobalSession, CollectionString tos, CollectionString ccs, CollectionString bccs, String subject, String content,MapString, InputStream imageMap, boolean isHtml, File... files) {final Mail mail Mail.create(mailAccount).setUseGlobalSession(useGlobalSession);// 可选抄送人if (CollUtil.isNotEmpty(ccs)) {mail.setCcs(ccs.toArray(new String[0]));}// 可选密送人if (CollUtil.isNotEmpty(bccs)) {mail.setBccs(bccs.toArray(new String[0]));}mail.setTos(tos.toArray(new String[0]));mail.setTitle(subject);mail.setContent(content);mail.setHtml(isHtml);mail.setFiles(files);// 图片if (MapUtil.isNotEmpty(imageMap)) {for (Map.EntryString, InputStream entry : imageMap.entrySet()) {mail.addImage(entry.getKey(), entry.getValue());// 关闭流IoUtil.close(entry.getValue());}}return mail.send();}/*** 将多个联系人转为列表分隔符为逗号或者分号** param addresses 多个联系人如果为空返回null* return 联系人列表*/private static ListString splitAddress(String addresses) {if (StrUtil.isBlank(addresses)) {return null;}ListString result;if (StrUtil.contains(addresses, CharUtil.COMMA)) {result StrUtil.splitTrim(addresses, CharUtil.COMMA);} else if (StrUtil.contains(addresses, ;)) {result StrUtil.splitTrim(addresses, ;);} else {result CollUtil.newArrayList(addresses);}return result;}
}邮件登录
引入依赖 mingyue-push 引入 mingyue-common-email !-- 邮件工具 --
dependencygroupIdcom.csp.mingyue/groupIdartifactIdmingyue-common-email/artifactId
/dependency新建邮箱验证码接口
Slf4j
Tag(name 邮箱服务模块)
Validated
RestController
RequestMapping(email)
RequiredArgsConstructor
public class EmailController {private final EmailProperties emailProperties;/*** 邮箱验证码** param email 邮箱*/GetMapping(/code)Operation(summary 邮箱验证码, parameters { Parameter(name email, description 邮箱, required true) })public RVoid emailCode(Valid NotBlank(message 邮箱不能为空) String email) {if (!emailProperties.getEnabled()) {return R.fail(当前系统没有开启邮箱功能);}String key CacheConstants.CAPTCHA_CODE_KEY email;String code RandomUtil.randomNumbers(4);RedisUtils.setCacheObject(key, code, Duration.ofMinutes(Constants.CAPTCHA_EXPIRATION));try {EmailUtils.sendText(email, 登录验证码, 您本次验证码为 code 有效性为 Constants.CAPTCHA_EXPIRATION 分钟请尽快填写。);} catch (Exception e) {log.error(验证码邮箱发送异常 {}, e.getMessage());return R.fail(e.getMessage());}return R.ok();}}Nacos 放行接口
# 安全配置
security:# 不校验白名单ignore:whites:# 放行邮箱验证码- /push/email/codemingyue-push-biz.yml
email:enabled: falsehost: smtp.qq.comport: 465# 是否需要用户名密码验证auth: true# 发送方遵循RFC-822标准from: xxxxxxqq.com# 用户名注意如果使用foxmail邮箱此处user为qq号user: xxxxxxqq.com# 密码注意某些邮箱需要为SMTP服务单独设置密码详情查看相关帮助pass: xxxxxx# 使用 STARTTLS安全连接STARTTLS是对纯文本通信协议的扩展。starttlsEnable: true# 使用SSL安全连接sslEnable: true# SMTP超时时长单位毫秒缺省值不超时timeout: 0# Socket连接超时值单位毫秒缺省值不超时connectionTimeout: 0启动项目发送测试
curl -X GET \http://mingyue-gateway:9100/push/email/code?emailxxxqq.com \-H accept: */*推送邮箱收到以下信息即可
您本次验证码为6508有效性为2分钟请尽快填写。短信登录
邮箱登录接口
/*** 邮箱登录*/
PostMapping(/emailLogin)
Operation(summary 邮箱登录)
public RString emailLogin(RequestBody Valid EmailLoginDto dto) {log.info(------- 进入【邮箱登录】请求: SaHolder.getRequest().getUrl());// 用户登录SaTokenInfo login sysLoginService.emailLogin(dto);if (Objects.isNull(login)) {return R.fail(登录失败);}return R.ok(登录成功, login.getTokenValue());
}短信登录逻辑处理
public SaTokenInfo emailLogin(EmailLoginDto dto) {// 远程调用用户服务RLoginUser userInfoResp remoteUserService.userInfoByEmail(dto.getEmail());if (userInfoResp.getCode() Constants.FAIL) {throw new UserException(userInfoResp.getMsg());}// 校验验证码是否正确if (!checkSmsOrEmailCode(dto.getEmail(), dto.getEmailCode())) {throw new UserException(验证码错误);}LoginUser userInfo userInfoResp.getData();if (dto.getEmail().equals(userInfo.getEmail())) {// 第1步先登录上LoginHelper.login(userInfo);// 第2步获取 Token 相关参数SaTokenInfo tokenInfo StpUtil.getTokenInfo();return tokenInfo;}return null;
}mingyue-ui 添加 email 模块
el-tab-pane :label$t(message.label.two3) nameemailEmail signInSuccesssignInSuccess/
/el-tab-pane启动测试
邮件登录需要启动 MingYueGatewayApplication 网关服务、MingYueAuthApplication 认证服务、MingYueSystemApplication 系统服务、MingYuePushApplication 推送服务 以及 mingyue-ui 小结
邮箱登录的功能也加上了当然不止可以通过邮件发送验证码呦自己去拓展一下吧具体看一下 EmailUtils 邮件工具类。
接下来想给 mingyue-ui 写一个增删改查的前后端交互示例就编写用户管理吧