使用云服务器,项目部署在tomcat上,发送邮件出现Invalid message received with signature 18245,修改465,

防火墙,高级设置,添加入站规则,本地端口-UDP-465

使用mailutils发送。
百度查很多说是端口问题,让加127.0.0.1,然并卵。云服务器可能会禁用25端口,所以不能使用普通的smtp发送邮件
在这里插入图片描述

import java.util.Properties;
import javax.mail.Authenticator;
import javax.mail.Message;
import javax.mail.MessagingException;
import javax.mail.PasswordAuthentication;
import javax.mail.Session;
import javax.mail.Transport;
import javax.mail.internet.AddressException;
import javax.mail.internet.InternetAddress;
import javax.mail.internet.MimeMessage;
import javax.mail.internet.MimeMessage.RecipientType;

public class MailUtils 
{
	public static void sendMail(String email, String emailMsg)
			throws AddressException, MessagingException {
		// 1.创建一个程序与邮件服务器会话对象 Session
		Properties props = new Properties();
		props.setProperty("mail.transport.protocol", "SMTP");
		props.setProperty("mail.smtp.host", "smtp.163.com");
		props.setProperty("mail.smtp.auth", "true");// 指定验证为true
		props.setProperty("mail.smtp.socketFactory.fallback", "false");
        props.setProperty("mail.smtp.port", "465");
        props.setProperty("mail.smtp.socketFactory.port", "465");
        props.setProperty("mail.smtp.socketFactory.class", "javax.net.ssl.SSLSocketFactory");
        
/*
 *  p.setProperty("mail.smtp.host", FROM_MAIL_SMTP);
     p.setProperty("mail.smtp.socketFactory.class", SSL_FACTORY);
 
 */
		// 创建验证器   username  password 是那个通行密码
		Authenticator auth = new Authenticator() {
			public PasswordAuthentication getPasswordAuthentication() {
				return new PasswordAuthentication("username", "password");
			}
		};

		Session session = Session.getInstance(props, auth);

		// 2.创建一个Message,它相当于是邮件内容
		Message message = new MimeMessage(session);

		message.setFrom(new InternetAddress("username@163.com")); // 设置发送者

		message.setRecipient(RecipientType.TO, new InternetAddress(email)); // 设置发送方式与接收者

		message.setSubject("用户激活");
		// message.setText("这是一封激活邮件,请<a href='#'>点击</a>");

		message.setContent(emailMsg, "text/html;charset=utf-8");

		// 3.创建 Transport用于将邮件发送

		Transport.send(message);
	}
}
### 解决服务器部署后前端页面遇到的 `Invalid CORS request` 错误 #### 修改Nginx配置文件处理跨域问题 当遇到由于前端域名和后端API服务域名不同而导致的跨域错误时,可以在Nginx中通过设置响应头来允许特定来源访问资源。具体来说,在Nginx配置中的location部分增加如下指令可以有效解决问题[^1]: ```nginx location /api/ { proxy_pass http://backend; add_header 'Access-Control-Allow-Origin' '*'; add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS'; add_header 'Access-Control-Allow-Headers' 'DNT,X-CustomHeader,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Authorization'; } ``` #### 使用Webpack Dev Server进行本地开发环境下的代理 对于基于Vue CLI构建的应用程序而言,在开发阶段可以通过调整webpack dev server的相关选项来进行接口反向代理操作,从而避免因跨域带来的麻烦。这通常是在项目的根目录下找到config/index.js文件并编辑其中的proxyTable属性实现[^2]: ```javascript module.exports = { // ... devServer: { proxy: { '/api': { target: 'http://localhost:3000', changeOrigin: true, pathRewrite: {'^/api' : ''} } } } }; ``` #### 配置CORS策略的最佳实践建议 为了更好地管理和控制哪些外部站点能够安全地调用Web API,应当遵循一些最佳做法: - **最小权限原则**:只授予必要的权限给可信第三方网站; - **预检请求支持**:确保服务器能正确回应带有OPTIONS方法的HTTP预检请求; - **敏感头部字段过滤**:防止泄露过多信息到不受信任的地方。 #### 常见问题排查指南 如果仍然遇到了无法解析的跨域问题,则可以从以下几个方面入手调查原因: - 检查浏览器开发者工具网络面板里具体的失败详情; - 审视目标服务器返回的状态码及其携带的消息体内容; - 查看防火墙或云服务商的安全组设定是否存在阻止行为;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值