zoukankan      html  css  js  c++  java
  • Indy10收发Hotmail邮件

    hotmail开放了pop3,可以使用客户端工具收取邮件了。

    POP 服务器: pop3.live.com (端口 995)
    需要 POP SSL?: 是的
    用户名: Windows Live ID, 比如:livesino@hotmail.com
    密码: 对应 Windows Live ID 的密码
    SMTP 服务器: smtp.live.com (端口 25)
    需要身份验证?: 是的
    需要 TLS/SSL?: 是的

    使用indy,需要SSL认证,到网上查阅 ,看到了Marco Cantù的文章:

    Send mail to GMail using Indy

    Once you've moved your email accounts to GMail (or even entire domains), you have to fix the code you use in your Delphi programs for generating and sending email automatically. In fact, GMail uses the SMTP protocol for sending email, but with a specific form of SSH encryption called TLS.


     

    To make things even more complicated, different clients use different ports and configurations. In particular, Outlook (which providees no TLS support) has different settings. For Indy, you can follow the settings used by other client programs, like those provided for Thunderbird. More info on the various ports in this newsgroup post:

    Gmail uses 25, 465 and 587 for SMTP, but since almost all isps block 25, 465 is the preferred SMTP with SSL for gmail, and 587 is the preferred SMTP with TLS port.


     

    Here is the code of a demo program, with the DFM file and the actual Delphi code (which is the same you'd generally use):


     

      object IdSMTP1: TIdSMTP
        OnStatus = IdSMTP1Status
        IOHandler = IdSSLIOHandlerSocketOpenSSL1
        Host = 'smtp.gmail.com'
        Password = '***'
        Port = 587
        SASLMechanisms = <>
        UseTLS = utUseExplicitTLS
        Username = '****'
      end
      object IdSSLIOHandlerSocketOpenSSL1: TIdSSLIOHandlerSocketOpenSSL
        Destination = 'smtp.gmail.com:587'
        Host = 'smtp.gmail.com'
        MaxLineAction = maException
        Port = 587
        SSLOptions.Method = sslvTLSv1
        SSLOptions.Mode = sslmUnassigned
        SSLOptions.VerifyMode = []
        SSLOptions.VerifyDepth = 0
        OnStatusInfo = IdSSLIOHandlerSocketOpenSSL1StatusInfo
      end
          


     

          IdSMTP1.Connect;
          IdSMTP1.Send(IdMessage1);
          IdSMTP1.Disconnect;
          


     

    Where IdMessage1 is the message you want to send. Of course, you can both send messages to your gmail account or to any other account from you GMail account.

    Notice: If you don't use "explicit TLS" you'll have to make extra initialization calls (like: IdSMTP1.SendCmd('STARTTLS', 220);). Finally, the IdSSLIOHandlerSocketOpenSSL1StatusInfo event handler produces a report like this:

          SSL status: "before/connect initialization"
          SSL status: "before/connect initialization"
          SSL status: "SSLv3 write client hello A"
          SSL status: "SSLv3 read server hello A"
          SSL status: "SSLv3 read server certificate A"
          SSL status: "SSLv3 read server done A"
          SSL status: "SSLv3 write client key exchange A"
          SSL status: "SSLv3 write change cipher spec A"
          SSL status: "SSLv3 write finished A"
          SSL status: "SSLv3 flush data"
          SSL status: "SSLv3 read finished A"
          SSL status: "SSL negotiation finished successfully"
          status: "SSL negotiation finished successfully"
          Cipher: name = [...]; description = [...] SSLv3 Kx=RSA Au=RSA  Enc=3DES(168)
    

    我没有测试gmail,连接hotmail,出错,后来反复尝试,将idpop的useTLS属性改为utUseImplicitTLS就顺利通过了。

    注意:SSL需要下载DLL支持:

    http://www.indyproject.org/Sockets/SSL.EN.aspx

    注意:如果开着瑞星,可能出现收邮件正常,而发邮件失败的问题,用Foxmail在STARTTLS处就停止了,最后也发送失败,这个问题我折腾了好久,最后才发现是瑞星的问题!

  • 相关阅读:
    Java Varargs 可变参数使用
    GitLab 如何删除 Forked from
    Git Clone 的时候遇到 Filename too long 错误
    Spring Boot 如何部署到 Linux 中的服务
    Gradle 如何打包 Spring Boot 如何不添加版本代码
    HDU 5878---预处理+二分查找
    HDU 5881--Tea 思维规律
    HDU 5879---cure
    (转)C/S 与 B/S 区别
    卡特兰数
  • 原文地址:https://www.cnblogs.com/GarfieldTom/p/1597092.html
Copyright © 2011-2022 走看看