【问题标题】:Sending smtp email using C, not accepting username and password使用 C 发送 smtp 电子邮件,不接受用户名和密码
【发布时间】:2012-05-25 21:58:47
【问题描述】:

我正在尝试向我的电子邮件帐户发送一封简单的文本邮件,但由于某种原因我的代码无法正常工作。这就是我到目前为止所拥有的......

int SendStartUpMail(char* mailserver, int port, char* user, char* pass)
{
     SOCKET sslSock;
     SOCKADDR_IN sslInfo;
     SSL_CTX *ctx;
     SSL *ssl;

     char bufferRecv[BUFFER_LEN];
     char bufferSend[BUFFER_LEN];
     int byte;

     sslSock = openConnection(mailserver, port);
     memset( bufferRecv, '\0', BUFFER_LEN );
     byte = recv(sslSock,bufferRecv,BUFFER_LEN,0);
     if(byte == SOCKET_ERROR)
         return -1;
     printf("%s\n",bufferRecv);

     strcpy(bufferSend,"HELO\r\n");
     send(sslSock,bufferSend,strlen(bufferSend),0);
     memset( bufferRecv, '\0', BUFFER_LEN );
     byte = recv(sslSock,bufferRecv,BUFFER_LEN,0);
     if(byte == SOCKET_ERROR)
         return -1;
     printf("%s",bufferRecv);

     strcpy(bufferSend,"STARTTLS\r\n");
     send(sslSock,bufferSend,strlen(bufferSend),0);
     memset( bufferRecv, '\0', BUFFER_LEN );
     byte = recv(sslSock,bufferRecv,BUFFER_LEN,0);
     if(byte == SOCKET_ERROR)
          return -1;
     printf("%s",bufferRecv);

     SSL_library_init();
     ctx = SSL_CTX_new(SSLv3_client_method());
     if ( ctx == NULL )
         return -1;
     ssl = SSL_new(ctx);
     if ( ssl == NULL )
         return -1;
     SSL_set_fd(ssl, sslSock);  

     if ( SSL_connect(ssl) == 1 )
     {
         strcpy(bufferSend,"HELO\r\n");
         SSL_write(ssl,bufferSend,strlen(bufferSend));
         memset( bufferRecv, '\0', BUFFER_LEN );
         SSL_read(ssl,bufferRecv,BUFFER_LEN);
         printf(">%s\n",bufferRecv);

         strcpy(bufferSend,"AUTH LOGIN\r\n");
         SSL_write(ssl,bufferSend,strlen(bufferSend));
         memset( bufferRecv, '\0', BUFFER_LEN );
         SSL_read(ssl,bufferRecv,BUFFER_LEN);
         printf(">%s\n",bufferRecv);

         strcpy(bufferSend,"USER c29tZXVzZXJuYW1lQGdtYWlsLmNvbQ==\r\n");         
         SSL_write(ssl,bufferSend,strlen(bufferSend));
         memset( bufferRecv, '\0', BUFFER_LEN );
         SSL_read(ssl,bufferRecv,BUFFER_LEN);
         printf(">%s\n",bufferRecv);

         strcpy(bufferSend,"PASS c29tZXBhc3N3b3Jk\r\n");         
         SSL_write(ssl, bufferSend,strlen(bufferSend));
         memset( bufferRecv, '\0', BUFFER_LEN );
         SSL_read(ssl,bufferRecv,BUFFER_LEN);
         printf(">%s\n",bufferRecv);
     }
     else
     {
         printf("Error on SSL_connect\n");  
         SSL_free(ssl);
         SSL_CTX_free(ctx);
         close(sslSock); 
         return -1; 
     }
     SSL_free(ssl); 
     SSL_CTX_free(ctx);
     close(sslSock);

}

当我运行这段代码时,我会从 smtp 服务器收到一些消息:

> 220 mx.google.com ESMTP 
> 250 mx.google.com at your service
> 220 2.0.0 Ready to Start TLS
> Conected with RC4-SHA encryption
> 250 mx.google.com at your service
> 334
> 334
> 535-5.7.1 Useername and Password not accepted

正如您所见,他们说我的密码和用户名错误,但我知道,这并没有错。 我在发送之前使用 base64 编码对我的用户名和密码进行编码,我使用此站点对其进行编码http://base64-encoder-online.waraxe.us/ 我使用端口 587。

我的问题是我还有其他事情要做吗??? 谢谢。

我也尝试过使用谷歌两步验证的应用程序专用密码,但仍然无法登录。

我尝试连接到 hotmail,但得到一个不同的错误,而不是错误 535 我得到 ​​p>

451 请求操作中止:处理中的本地错误

【问题讨论】:

  • 您是否在此处显示实际的用户名/密码?它们都以相同的6个字符开头,这看起来有点可疑。
  • 不,我没有在这里使用实际的用户名和密码,但在我的应用程序中,我使用了正确的用户名和密码。我正在同时使用 winsock2 和 openssl
  • @JerryCoffin:据我所知,base64 电子邮件是:“someusername@gmail.com”和密码:“somepassword”,因此 beginning 相同。跨度>
  • @Morpfh:好的——有道理。我想我应该在问之前先解码它们......
  • 如果我删除了身份验证登录,它将无法工作

标签: c email smtp


【解决方案1】:

使用我自己的帐户进行测试,AUTH LOGIN 不起作用,但 AUTH PLAIN 工作正常:

250 ENHANCEDSTATUSCODES
auth plain
334 
c29tZXVzZXJAZ21haWwuY29tAHNvbWV1c2VyQGdtYWlsLmNvbQBzb21lcGFzc3dvcmQ=
235 2.7.0 Accepted

这是someuser@gmail.com\x00someuser@gmail.com\x00somepassword 的base64 编码版本。

【讨论】:

  • 如果我使用 auth plain 我无法解码也许我做错了?我应该把用户名和密码放在一起,就像用'/'分隔吗?
  • 您发送 base64 编码字符串“someuser@gmail.com\x00someuser@gmail.com\x00somepassword”,其中\x00 表示 ASCII“NULL”。
猜你喜欢
  • 2018-03-03
  • 2019-01-20
  • 2020-11-08
  • 1970-01-01
  • 1970-01-01
  • 2015-11-13
  • 2020-01-19
  • 2018-02-07
  • 2016-04-17
相关资源
最近更新 更多