- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在 libcurl 中编写了一段可以正常工作的代码,但我想进行一些更改。
我想知道如何使用消息中的声明变量发送消息。
为了进行此更改,我认为我不会使用数组,而是必须更改大部分代码。
我不知道如何最好地做到这一点,有人知道如何最好地做到这一点吗?
代码:
typedef struct
{
int lines_read;
} UploadStatus;
size_t payload_source(void *ptr, size_t size, size_t nmemb, void *userp)
{
if((size == 0) || (nmemb == 0) || ((size * nmemb) < 1)) return 0;
UploadStatus *upload = (UploadStatus*) userp;
const char *payload[] =
{
"Message Test\r\n",
"\r\n", /* empty line to divide headers from body, see RFC5322 */
"Test",
NULL
};
const char *data = payload[upload->lines_read];
if(data)
{
size_t len = strlen(data);
memcpy(ptr, data, len);
upload->lines_read++;
return len;
}
return 0;
}
int main(void)
{
CURLcode res = CURLE_OK;
struct curl_slist *recipients = NULL;
UploadStatus upload_ctx = {0};
const char *from = "test@gmail.com";
const char *to = "UrTxtEmail"; // see http://www.emailtextmessages.com/
CURL *curl = curl_easy_init();
if(curl)
{
// set username and password
curl_easy_setopt(curl, CURLOPT_USERNAME, from);
curl_easy_setopt(curl, CURLOPT_PASSWORD, "password");
curl_easy_setopt(curl, CURLOPT_URL, "smtp://smtp.gmail.com:587/");
// start with normal connection, and upgrade to TLS using STARTTLS
curl_easy_setopt(curl, CURLOPT_USE_SSL, (long) CURLUSESSL_ALL);
curl_easy_setopt(curl, CURLOPT_SSL_VERIFYPEER, 0L);
curl_easy_setopt(curl, CURLOPT_SSL_VERIFYHOST, 0L);
curl_easy_setopt(curl, CURLOPT_MAIL_FROM, from);
recipients = curl_slist_append(recipients, to);
curl_easy_setopt(curl, CURLOPT_MAIL_RCPT, recipients);
curl_easy_setopt(curl, CURLOPT_READFUNCTION, payload_source);
curl_easy_setopt(curl, CURLOPT_READDATA, &upload_ctx);
curl_easy_setopt(curl, CURLOPT_UPLOAD, 1L);
// useful for debugging encryped traffic
curl_easy_setopt(curl, CURLOPT_VERBOSE, 1L);
// send the message
res = curl_easy_perform(curl);
if(res != CURLE_OK) fprintf(stderr, "curl_easy_perform() failed: %s\n", curl_easy_strerror(res));
curl_slist_free_all(recipients);
curl_easy_cleanup(curl);
}
return (int) res;
}
我想如何发送消息的示例:
time_t clock;
struct tm *tm;
time(&clock);
tm = localtime(&clock);
"Message Test\r\n",
"\r\n", /* empty line to divide headers from body, see RFC5322 */
"Day %d Welcome %s", tm->tm_mday, user_name
消息输出:
Message Test
Day 22 Welcome Lucas
最佳答案
我为你做了一个例子,你可以用它来实现你想要的。
要准确地获得您想要的内容,您可以更改我在下面制作的payload_template,使其看起来像这样
const char payload_template[] =
"Date: %s\r\n"
"To: %s\r\n"
"From: %s\r\n"
"Message-ID: <%s@example.com>\r\n"
"Subject: Message Test\r\n"
"\r\n"
"Day %d Welcome %s\r\n\r\n";
接下来是对 sprintf() 的修改
sprintf(payload_text, payload_template, time_buffer, to,
smtp_from, message_id, tm->tm_mday, user_name);
如果您想使用该示例,则必须添加生成 tm 结构体和 user_name 的代码。下面是我的完整示例,它基于 libcurl 的示例。
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <curl/curl.h>
struct upload_status {
const char *readptr;
size_t sizeleft;
};
static size_t payload_source(void *ptr, size_t size, size_t nmemb, void *userp)
{
struct upload_status *upload_ctx = (struct upload_status *)userp;
const char *data;
size_t bytes_to_copy = upload_ctx->sizeleft < size*nmemb ? upload_ctx->sizeleft : size*nmemb;
bytes_to_copy = upload_ctx->sizeleft < 10 ? upload_ctx->sizeleft : 10;
if(size*nmemb < 1)
return 0;
if(upload_ctx->sizeleft)
{
memcpy((char*)ptr, (char*)upload_ctx->readptr, bytes_to_copy);
upload_ctx->readptr+=bytes_to_copy;
upload_ctx->sizeleft-=bytes_to_copy;
return bytes_to_copy;
}
return 0;
}
int send_mail(const char* to, const char* message)
{
CURL *curl;
CURLcode res = CURLE_OK;
struct curl_slist *recipients = NULL;
struct upload_status upload_ctx;
// TODO Change these
const char* smtp_from = "mr.christer@example.com";
const char* smtp_username = "mr.christers_username";
const char* smtp_password = "secret";
const char* smtp_server_url = "smtp://mail.example.com:25";
curl = curl_easy_init();
if(curl)
{
// Time
time_t rawtime;
struct tm * timeinfo;
char time_buffer[128];
time(&rawtime);
timeinfo = localtime (&rawtime);
strftime (time_buffer, 128, "%a, %d %b %Y %H:%M:%S %z", timeinfo);
// END Time
// This is what our message will look like, but with details filled in.
const char payload_template[] =
"Date: %s\r\n"
"To: %s\r\n"
"From: %s\r\n"
"Message-ID: <%s@example.com>\r\n"
"Subject: Hello from Mr.Christer at Stackoverflow\r\n"
"\r\n"
"%s\r\n\r\n";
// TODO You must make this unique for every message sent.
// Generate it according to spec.
char message_id[] = "126cfbe1fd5413ba4d604c50a74bfc80471cec367b1604ade4d081f31c3f4f34";
size_t payload_text_len = strlen(payload_template) +
strlen(time_buffer) +
strlen(to) + strlen(smtp_from) +
strlen(message_id) + strlen(message) + 1;
char* payload_text = malloc(payload_text_len);
memset(payload_text, 0, payload_text_len);
sprintf(payload_text, payload_template, time_buffer, to,
smtp_from, message_id, message);
upload_ctx.readptr = payload_text;
upload_ctx.sizeleft = (long)strlen(payload_text);
/* Set username and password */
curl_easy_setopt(curl, CURLOPT_USERNAME, smtp_username);
curl_easy_setopt(curl, CURLOPT_PASSWORD, smtp_password);
curl_easy_setopt(curl, CURLOPT_URL, smtp_server_url);
// If you are not using SSL/TLS you are safe commenting three lines below
curl_easy_setopt(curl, CURLOPT_USE_SSL, (long)CURLUSESSL_ALL);
curl_easy_setopt(curl, CURLOPT_SSL_VERIFYPEER, 0L);
curl_easy_setopt(curl, CURLOPT_SSL_VERIFYHOST, 0L);
curl_easy_setopt(curl, CURLOPT_MAIL_FROM, smtp_from);
recipients = curl_slist_append(recipients, to);
// More recipients
//recipients = curl_slist_append(recipients, CC);
curl_easy_setopt(curl, CURLOPT_MAIL_RCPT, recipients);
curl_easy_setopt(curl, CURLOPT_READFUNCTION, payload_source);
curl_easy_setopt(curl, CURLOPT_READDATA, &upload_ctx);
curl_easy_setopt(curl, CURLOPT_UPLOAD, 1L);
curl_easy_setopt(curl, CURLOPT_VERBOSE, 1L);
/* Send the message */
res = curl_easy_perform(curl);
/* Check for errors */
if(res != CURLE_OK)
printf("curl_easy_perform() failed %s\n", curl_easy_strerror(res));
/* Free the list of recipients */
curl_slist_free_all(recipients);
/* Always cleanup */
curl_easy_cleanup(curl);
free(payload_text);
}
return (int)res;
}
int main(void)
{
return send_mail("friend@example.com", "Hello friend!");
}
祝你好运,请告诉我这是否是正确的答案。我已尽力提供信息。
关于c - 如何发送带有变量声明的电子邮件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48383627/
我在覆盖 ReSwift Pod 中的函数时遇到问题。我有以下模拟类(class): import Foundation import Quick import Nimble import RxSwi
我有一个类似于下面的继承结构。我正在采用 Printable 协议(protocol)并努力覆盖 description 属性。我遇到了一个谷歌此时似乎不知道的奇怪错误,提示为第三类,并引用了第二类和
我有一个类“Cat”和 Cat 类的一个子类“DerivedCat”。 Cat 有一个函数 meow(),而 DerivedCat 覆盖了这个函数。 在应用程序中,我声明了一个 Cat 对象: Cat
Kotlin 变量 变量是用于存储数据值的容器。 要创建一个变量,使用 var 或 val,然后使用等号(=)给它赋值: 语法 var 变量名 = 值 val 变量名 = 值 示例 va
C 中的所有标识符在使用前都需要声明,但我找不到它在 C99 标准中表示的位置。 我觉得也是指宏定义,不过定义的只是宏展开顺序。 最佳答案 C99:TC3 6.5.1 §2,脚注 79 明确指出: T
今天我的博客提要显示错误: This page contains the following errors: error on line 2 at column 6: XML declaration
在编写 IIF 语句、表和下面给出的语句时出现错误。 陈述: SELECT IIF(EMP_ID=1,'True','False') from Employee; table : CREATE TAB
我正在创建一个登录 Activity ,我希望它在按下登录按钮时显示进度对话框,我声明、初始化并调用了它,但它没有显示。但是当我在创建时调用进度对话框时,它出现了 这是我的代码: public cla
当我输入声明语句时: Vector distance_vector = new Vector(); 我收到错误(在两种情况下都在“双”下划线): Syntax error on token "doub
我正在本地部署在docker-for-desktop中。这样我将来可以迁移到kubernetes集群。 但是我面临一个问题。使用永久卷时,docker容器/ pod中的目录将被覆盖。 我正在拉最新的S
我有一个 MyObject 类型的对象 obj,我声明了它的实例。 MyObject obj; 但是,我没有初始化它。 MyObject 的类看起来像: public class MyObject {
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 已关闭 9 年前。 Improv
这个问题已经有答案了: Android: Issue during Arraylist declaration (1 个回答) 已关闭 9 年前。 有时我会看到 ArrayList 声明如下 Arra
我对java比较陌生,经过大量搜索,我无法将相关问题的任何解决方案与我的解决方案配对。我正在尝试实现一种非常简单的方法来写入/读取数组,但编译器无法识别它。 “键盘”也是一个“无法识别的变量”。这是数
简短:何时分配内存 - 在声明或初始化时? 长整型:int x;将占用与int z = 10;相同的内存。 此外,这对于包含更多数据的自定义对象将如何工作。假设我有这个对象: public class
我需要使用此程序更好地理解函数定义、声明和正确调用。我真的需要了解如何使用它们。您能否向我展示编写此程序的正确方法(所有三个都正确并进行解释)? #include #include quad_eq
这是我的主要功能以及我要传递的内容。 int main(void){ struct can elC[7]; // Create an array of stucts Initiali
我想知道是否有更好的方法来完成此任务; 我有一个对象 - 其中一个属性是字典。我有一组逗号分隔值。我需要过滤 Dictionary 并仅获取 Dictionary 值至少与其中一个值匹配的那些元素 这
下面的using-declarations有什么意义 using eoPop::size; using eoPop::operator[]; using eoPop::back; using eoPo
我的问题更像是一个关于 for 循环样式的好奇问题。在阅读别人的一些旧代码时,我遇到了一种我以前从未见过的风格。 var declaredEarlier = Array for(var i=0, le
我是一名优秀的程序员,十分优秀!