[玩转系统] 通过 Telnet 或 OpenSSL 使用 SMTP 身份验证发送电子邮件
作者:精品下载站 日期:2024-12-14 23:03:46 浏览:12 分类:玩电脑
通过 Telnet 或 OpenSSL 使用 SMTP 身份验证发送电子邮件
您可以使用内置的
telnet
用于连接到远程 SMTP 服务器并发送测试电子邮件的命令行工具。这是测试远程 SMTP 服务器最简单、最快的方法,并且不需要安装完整的 SMTP 客户端。但在大多数情况下,SMTP 服务器需要用户身份验证,并且只能通过匿名 SMTP 服务器(SMTP 中继)进行未经身份验证的发送。
在此示例中,我们将向您展示如何对 SMTP 服务器进行身份验证并从 telnet 命令行发送电子邮件。我们将考虑使用常规 SMTP 服务器以及仅通过安全 SST/TLS 协议接受连接的 SMTP 服务器的选项。
使用 Telnet 测试 SMTP 身份验证
为了通过 telnet 对远程 SMTP 主机进行身份验证,必须在其设置中允许基本身份验证。默认情况下,公司网络上的 Exchange 服务器上启用基本身份验证。这种类型的身份验证涉及以 base64 编码形式通过网络发送用户名和密码。
在 Exchange Server 中,您可以在接收连接器设置中启用或禁用基本身份验证。
您可以从 PowerShell 控制台在 Exchange 连接器上启用基本身份验证(您需要在计算机上安装 EMS 或远程连接到 Exchange Server):
Get-ReceiveConnector "ExchRecConnector1" | Set-ReceiveConnector -AuthMechanism Tls, Integrated, BasicAuth, ExchangeServer
注意。请注意,如果攻击者能够访问通信通道,他就可以轻松捕获并解密使用 Base64 编码的用户凭据。因此,仅建议对私有企业网络使用此身份验证方法。
如果您在客户端和 Exchange 主机之间使用不安全的通信通道,建议仅在建立安全 TLS 会话后才允许 BasicAuth。在 EMC 的连接器属性中启用仅在启动 TLS 后提供基本身份验证选项,或使用 PowerShell:
Get-ReceiveConnector "ExchRecConnector1" | Set-ReceiveConnector -AuthMechanism 'Tls, BasicAuth, BasicAuthRequireTLS'
本文的下一部分将介绍通过 TLS/SSL 发送 SMTP 消息的具体细节。
要通过 AUTH LOGIN 在 SMTP 服务器上进行身份验证,您需要将发送电子邮件的用户名和密码转换为 Base64 格式。要将字符串转换为 Base64,可以使用 PowerShell 函数:
[System.Convert]::ToBase64String([System.Text.Encoding]::UTF8.GetBytes("[email protected]"))
或者 Perl MIME::Base64 模块:
perl -MMIME::Base64 -e 'print encode_base64("username");'
或者使用任何在线服务,例如 https://www.base64encode.org。
用户名 [email protected] 在 Base64 中看起来像 dGVzdF91c2VyQHdvc2h1Yi5jb20g
密码 $up3RsTr)ng 在 Base64 中转换为 JHVwM1JzVHIpbmc=
打开命令提示符并使用 Telnet 连接到服务器的端口 25 (SMTP)(我将以蓝色突出显示要输入的命令):
telnet mail.a-d.site 25
如果它是带有 Exchange Server 的主机,它将返回类似以下内容:
220 mail.a-d.site Microsoft ESMTP MAIL Service ready at Thu, 25 Nov 2021 10:22:31 +0300
首先你需要向服务器介绍一下自己:
ehlo sender.a-d.site
服务器将返回支持的身份验证方法和选项的列表。可以看到,列表中有AUTH LOGIN(基本身份验证)。
250-mail.a-d.site Hello [192.168.1.115]
250-SIZE 36700160
250-PIPELINING
250-DSN
250-ENHANCEDSTATUSCODES
250-STARTTLS
250-AUTH LOGIN
250-8BITMIME
250-BINARYMIME
250 CHUNKING
SMTP 服务器上可以使用以下身份验证协议:PLAIN、GSSAPI、DIGEST-MD5、MD5、CRAM-MD5、OAUTH10A、OAUTHBEARER。
例如,来自 SMTP 服务器的此类响应表明支持 3 种身份验证协议。
250 AUTH GSSAPI DIGEST-MD5 PLAIN
基本身份验证方法 PLAIN 和 LOGIN 使用名称和密码的 BASE64 编码。它们之间的区别在于,对于 PLAIN 方法,登录名和密码在一行中发送。当使用LOGIN时,首先发送登录名,然后发送密码。
如果您的 SMTP 服务器支持 PLAIN 身份验证方法,您可以使用 perl 函数或 PowerShell 对用户名和密码进行编码:
perl -MMIME::Base64 -e 'print encode_base64("[System.Convert]::ToBase64String([System.Text.Encoding]::UTF8.GetBytes("授权登录username334 VXNlcm5hbWU6
password"))
[email protected]AUTH PLAIN XDB0ZXN0X3VzZXJAd29zaHViLmNvbVwwKW5n0$up3RsTr)ng")'
dGVzdF91c2VyQHdvc2h1Yi5jb20g
告诉 SMTP 服务器您要使用 LOGIN 方法进行身份验证:
334 UGFzc3dvcmQ6.
服务器将响应:
JHVwM1JzVHIpbmc=
使用 PLAIN 方法进行身份验证时,您可以立即发送用户的凭据:
235 2.7.0 Authentication successful
现在以您之前加密的 Base64 格式复制并粘贴用户名:
535 5.7.8 Error: authentication failed: UGFzc3dvcmQ6
服务器将响应 334 代码:
邮件来自:[email protected]
然后以 Base64 格式复制并粘贴密码:
250 2.1.0 Sender OK
如果用户名和密码正确,服务器将返回:
收件人:[email protected]
如果不:
250 2.1.5 Recipient OK
是时候填写标准电子邮件字段了:
数据
354 Start mail input; end with .
发件人:TestUser
主题:测试通过 Telnet 验证的 BASE SMTP
这是测试
.
250 2.6.0 <[email protected]> [InternalId=6334284] Queued mail for delivery
退出
221 2.0.0 Closing connection.
Connection closed by foreign host.
使用基于 TLS/SSL 的经过身份验证的 SMTP
电子邮件已排队等待发送。
OpenSSL
OpenSSL
sudo apt-get install openssl
稍等片刻后,检查邮件是否已发送至收件人邮箱。
Get-MessageTrackingLog PowerShell cmdlet 可用于搜索存储在本地 Exchange 的邮件跟踪日志中的邮件传递信息。
sudo yum install openssl
大多数 SMTP 提供商不允许纯文本 SMTP 会话。仅允许使用 TLS 加密的 SMTP 连接。仅在初始化 TLS 连接后,您才能使用 LOGIN 和 PLAIN 方法向 SMTP 服务器进行身份验证。 Telnet不支持SSL或TLS,因此需要使用openssl.exe s_client -starttls smtp -connect smtp.a-d.site:25
工具通过TLS连接到SMTP服务器。
我们来看看如何使用
EHLO sender.a-d.site
通过 TLS 连接到 SMTP 服务器并使用 AUTH LOGIN 进行身份验证。
下载并安装 OpenSSL:
在 Windows 上,您可以使用:http://slproweb.com/products/Win32OpenSSL.html
在 Linux 上,OpenSSL 是从基础存储库安装的:
250- smtp.a-d.site 250-PIPELINING 250-SIZE 52428800 250-ETRN 250-AUTH PLAIN LOGIN 250-ENHANCEDSTATUSCODES 250-8BITMIME 250 DSN
- 在 Ubuntu/Debian
使用 TLS 在 Office 365 上进行 SMTP 身份验证
- 在 CentOS/RedHat 上
要使用 SSL/TLS 加密从命令行连接到 SMTP 主机,请使用以下命令:
telnet
与 SMTP 服务器建立安全 SSL 连接后运行 EHLO 命令。
SMTP 服务器将返回:
openssl
$emailto='[email protected]'
$emailfrom='[email protected]'
$smtpserver='smtp.office365.com'
$MailMessage = @{
To = $emailto
From = $emailfrom
Subject = "Testing SMTP TLS on O365"
Body = "This is a test measles "
Smtpserver = $smtpserver
#ErrorAction = "SilentlyContinue"
Port="587"
}
Send-MailMessage @MailMessage -UseSsl -Credential $cred
现在您可以使用 AUTH LOGIN 或 AUTH PLAIN 进行身份验证,并按照上述方式发送电子邮件。
2020 年 10 月底,Microsoft 阻止使用基本身份验证连接到 Exchange Online 中的邮箱。仍然支持对 Office 365 (Microsoft 365/Exchange Online) 中的服务器进行 SMTP 身份验证,但被认为不安全。 Microsoft 为所有新租户禁用 SMTP AUTH。这意味着您将无法使用命令行连接到 Office 365 上的 SMTP 主机
或者
。
要通过 Office 365 SMTP 服务器发送测试电子邮件,您需要使用 Send-MailMessage PowerShell cmdlet。
猜你还喜欢
- 03-30 [玩转系统] 如何用批处理实现关机,注销,重启和锁定计算机
- 02-14 [系统故障] Win10下报错:该文件没有与之关联的应用来执行该操作
- 01-07 [系统问题] Win10--解决锁屏后会断网的问题
- 01-02 [系统技巧] Windows系统如何关闭防火墙保姆式教程,超详细
- 12-15 [玩转系统] 如何在 Windows 10 和 11 上允许多个 RDP 会话
- 12-15 [玩转系统] 查找 Exchange/Microsoft 365 中不活动(未使用)的通讯组列表
- 12-15 [玩转系统] 如何在 Windows 上安装远程服务器管理工具 (RSAT)
- 12-15 [玩转系统] 如何在 Windows 上重置组策略设置
- 12-15 [玩转系统] 如何获取计算机上的本地管理员列表?
- 12-15 [玩转系统] 在 Visual Studio Code 中连接到 MS SQL Server 数据库
- 12-15 [玩转系统] 如何降级 Windows Server 版本或许可证
- 12-15 [玩转系统] 如何允许非管理员用户在 Windows 中启动/停止服务
取消回复欢迎 你 发表评论:
- 精品推荐!
-
- 最新文章
- 热门文章
- 热评文章
[影视] 黑道中人 Alto Knights(2025)剧情 犯罪 历史 电影
[古装剧] [七侠五义][全75集][WEB-MP4/76G][国语无字][1080P][焦恩俊经典]
[实用软件] 虚拟手机号 电话 验证码 注册
[电视剧] 安眠书店/你 第五季 You Season 5 (2025) 【全10集】
[电视剧] 棋士(2025) 4K 1080P【全22集】悬疑 犯罪 王宝强 陈明昊
[软件合集] 25年6月5日 精选软件22个
[软件合集] 25年6月4日 精选软件36个
[短剧] 2025年06月04日 精选+付费短剧推荐33部
[短剧] 2025年06月03日 精选+付费短剧推荐25部
[软件合集] 25年6月3日 精选软件44个
[剧集] [央视][笑傲江湖][2001][DVD-RMVB][高清][40集全]李亚鹏、许晴、苗乙乙
[电视剧] 欢乐颂.5部全 (2016-2024)
[电视剧] [突围] [45集全] [WEB-MP4/每集1.5GB] [国语/内嵌中文字幕] [4K-2160P] [无水印]
[影视] 【稀有资源】香港老片 艺坛照妖镜之96应召名册 (1996)
[剧集] 神经风云(2023)(完结).4K
[剧集] [BT] [TVB] [黑夜彩虹(2003)] [全21集] [粤语中字] [TV-RMVB]
[实用软件] 虚拟手机号 电话 验证码 注册
[资源] B站充电视频合集,包含多位重量级up主,全是大佬真金白银买来的~【99GB】
[影视] 内地绝版高清录像带 [mpg]
[书籍] 古今奇书禁书三教九流资料大合集 猎奇必备珍藏资源PDF版 1.14G
[电视剧] [突围] [45集全] [WEB-MP4/每集1.5GB] [国语/内嵌中文字幕] [4K-2160P] [无水印]
[剧集] [央视][笑傲江湖][2001][DVD-RMVB][高清][40集全]李亚鹏、许晴、苗乙乙
[电影] 美国队长4 4K原盘REMUX 杜比视界 内封简繁英双语字幕 49G
[电影] 死神来了(1-6)大合集!
[软件合集] 25年05月13日 精选软件16个
[精品软件] 25年05月15日 精选软件18个
[绝版资源] 南与北 第1-2季 合集 North and South (1985) /美国/豆瓣: 8.8[1080P][中文字幕]
[软件] 25年05月14日 精选软件57个
[短剧] 2025年05月14日 精选+付费短剧推荐39部
[短剧] 2025年05月15日 精选+付费短剧推荐36部
- 最新评论
-
- 热门tag