- 工信部备案号 滇ICP备05000110号-1
- 滇公网安备53011102001527号
- 增值电信业务经营许可证 B1.B2-20181647、滇B1.B2-20190004
- 云南互联网协会理事单位
- 安全联盟认证网站身份V标记
- 域名注册服务机构许可:滇D3-20230001
- 代理域名注册服务机构:新网数码
- CN域名投诉举报处理平台:电话:010-58813000、邮箱:service@cnnic.cn
我们知道smtp是邮件传输协议,传输过程中往往需要加密
直接使用TLS/SSL加密当然简单明白,但是为了兼容传统的传输方式,出现了StartTLS
简单说就是先使用明文通信,如果双方支持加密的话升级为TLS加密通信
当然,前提是邮箱服务器支持StartTLS(各服务商支持并不相同),目前来看,还是老老实实tls吧
放一下标准库里的StartTLS实现
// StartTLS sends the STARTTLS command and encrypts all further communication.
// Only servers that advertise the STARTTLS extension support this function.
func (c Client) StartTLS(config tls.Config) error {
if err := c.hello(); err != nil {
return err
} , , err := c.cmd(220, "STARTTLS")
if err != nil {
return err
}
c.conn = tls.Client(c.conn, config)
c.Text = textproto.NewConn(c.conn)
c.tls = true
return c.ehlo()
}如果服务端仅支持TLS,c.hello()会无法收到正确信息,c.cmd()报错
售前咨询
售后咨询
备案咨询
二维码

TOP