javascript - 如何在 imap-simple 中检索“已发送”邮箱
问题描述
我在节点 js 中使用imap-simple 。我想找回已发送的gmail邮箱。我的代码如下:
getSent(searchCriteria: string[], callBack: any) {
imaps.connect(this.imapConfig).then(function (connection) {
return connection.openBox('SENT').then(function () {
var fetchOptions = {
bodies: ['HEADER', 'TEXT', ''],
markSeen: false
};
return connection.search(searchCriteria, fetchOptions).then(function (results) {
let mails = results.map(res => {
return {
part: res.parts.find(part => part.which === ''),
attributes: res.attributes
};
});
mails = [].concat(...mails);
mails = mails.map(mail => {
return new Promise((resolve, reject) => {
var id = mail.attributes.uid;
var idHeader = "Imap-Id: " + id + "\r\n";
simpleParser(idHeader + mail.part.body, (error, mail) => {
if (error)
reject(error);
else {
resolve(new Email({
sentDate: mail.date,
from: mail.from.text,
to: mail.to.text,
messageId: mail.messageId,
body: mail.html,
subject: mail.subject
}));
}
});
})
});
Promise.all(mails).then(response => {
callBack({
success: true,
emails: response,
error: undefined
});
}, error => {
callBack({
success: false,
emails: [],
error: error
});
});
}, function (error) {
callBack({
success: false,
emails: [],
error: error
});
});
}, function (error) {
callBack({
success: false,
emails: [],
error: error
});
});
}, function (error) {
callBack({
success: false,
emails: [],
error: error
});
});
}
如果我如下调用 getSent 方法
this.getSent(['ALL'], response => {
});
我收到以下错误 “错误:未知邮箱:已发送(失败)”
我尝试connection.openBox('[Gmail]/Sent Mail')
,但我得到了类似的错误
'错误:未知邮箱:[Gmail]/已发送邮件(失败)'
我使用 gmail。
解决方案
我使用 getBoxes 方法获得了所有文件夹名称。然后我看到文件夹名称以阿塞拜疆语言出现。
connection.getBoxes().then(response => {
var r = response;
});
问题出在谷歌设置中。我用阿塞拜疆语的谷歌。如果使用谷歌不同的语言,文件夹名称会自动翻译成该语言。我将谷歌语言更改为英语,问题解决了。这对我有用。谢谢大家。
我用[Gmail]/Sent Mail
.
我的代码的正确版本如下:
getSent(searchCriteria: string[], callBack: any) {
imaps.connect(this.imapConfig).then(function (connection) {
return connection.openBox('[Gmail]/Sent Mail').then(function () {
var fetchOptions = {
bodies: ['HEADER', 'TEXT', ''],
markSeen: false
};
return connection.search(searchCriteria, fetchOptions).then(function (results) {
let mails = results.map(res => {
return {
part: res.parts.find(part => part.which === ''),
attributes: res.attributes
};
});
mails = [].concat(...mails);
mails = mails.map(mail => {
return new Promise((resolve, reject) => {
var id = mail.attributes.uid;
var idHeader = "Imap-Id: " + id + "\r\n";
simpleParser(idHeader + mail.part.body, (error, mail) => {
if (error)
reject(error);
else {
resolve(new Email({
sentDate: mail.date,
from: mail.from.text,
to: mail.to.text,
messageId: mail.messageId,
body: mail.html,
subject: mail.subject
}));
}
});
})
});
Promise.all(mails).then(response => {
callBack({
success: true,
emails: response,
error: undefined
});
}, error => {
callBack({
success: false,
emails: [],
error: error
});
});
}, function (error) {
callBack({
success: false,
emails: [],
error: error
});
});
}, function (error) {
callBack({
success: false,
emails: [],
error: error
});
});
}, function (error) {
callBack({
success: false,
emails: [],
error: error
});
});
}
推荐阅读
- spring - 如何使用外部jar和jar打包部署spring boot app
- c - 是否可以在 exec() 输出的 fifo 上写入?
- ios - Swift:使用参数捕获错误情况但可以访问错误对象
- google-cloud-platform - 在 ubuntu 谷歌云平台上安装 RethinkDb
- layout - 如何更改 Bootstrap 4 布局以删除空格并使其响应
- typo3 - TYPO3 中的前端本地化设置:config.yaml 与 TypoScript
- javascript - 如何解决“拒绝访问:无效令牌,错误代码”的问题?
- google-apps-script - 在谷歌表格脚本上获取格式的日期
- reactjs - 单击按钮时如何使用 useRef 挂钩关注 Material UI TextField?
- c++ - 在冒泡排序中使用递归