首页 > 解决方案 > Outlook 更新后 iCal 日历事件不再取消

问题描述

我有一个生成电子邮件的系统,包括嵌入式 iCalendar 事件,这些事件会发送给相关人员。事件是从任务创建的。可以编辑任务,进而更新会议时间等。也可以取消任务,通过取消它再次更新会议。一年多来,这一切都运行良好。但是大约 6 周前更新了办公室,包括对 Outlook 的一个非常明显的更新(现在会议/活动请求的显示方式大不相同,因此 Outlook 团队在该领域进行了一些重要的工作) - 问题是这个更新破坏了 iCalendar 事件取消。初次会议仍然可以正常工作,编辑也是如此。但是当取消而不是嵌入式 iCalendar 事件时,我现在只得到一个标题为:“

我正在使用 PHPMailer 发送电子邮件,并使用此库提供的 ical 功能将生成的 iCalendar 事件附加到电子邮件中。

我已尽我所能进行调试,这并不容易,因为他们似乎也删除了任何查看完整电子邮件源的方法。但是,我试图将 iCalendar 事件简化为绝对的准系统,但没有运气。所以我已经指示 PHPMailer 转储完整的电子邮件。出于调试目的 - 输出如下:

事件创建:

Content-Type: multipart/alternative;
        boundary="b1_ee3827bf9d86f19f6cb13cbcbc05bb33"
Content-Transfer-Encoding: 8bit^M
^M
This is a multi-part message in MIME format.

--b1_ee3827bf9d86f19f6cb13cbcbc05bb33
Content-Type: text/plain; charset=us-ascii

[test] testing iCal


--b1_ee3827bf9d86f19f6cb13cbcbc05bb33
Content-Type: text/html; charset=us-ascii

Details:</b></u><br /><i>Off-Site</i><br /><u><b>Technical Contact Name:</b></u> Test User<br /><u><b>Technical Contact Number:</b></u> 12345<br /><u><b>Technical Contact e-mail:</b></u> anothertest@test.com<br /><u><b>Work to be done:</b></u><br /><p>[test] testing iCal</p>


--b1_ee3827bf9d86f19f6cb13cbcbc05bb33
Content-Type: text/calendar; method=REQUEST; charset=iso-8859-1
Content-Transfer-Encoding: 8bit

BEGIN:VCALENDAR
PRODID:-//Microsoft Corporation//Outlook 10.0 MIMEDIR//EN
VERSION:2.0
METHOD:REQUEST
BEGIN:VTIMEZONE
TZID:Europe/London
BEGIN:STANDARD
DTSTART:20091101T020000
RRULE:FREQ=YEARLY;INTERVAL=1;BYDAY=-1SU;BYMONTH=10
TZOFFSETFROM:+0100
TZOFFSETTO:+0000
TZNAME:GMT
END:STANDARD
BEGIN:DAYLIGHT
DTSTART:20090301T020000
RRULE:FREQ=YEARLY;INTERVAL=1;BYDAY=-1SU;BYMONTH=3
TZOFFSETFROM:+0000
TZOFFSETTO:+0100
TZNAME:BST
END:DAYLIGHT
END:VTIMEZONE
BEGIN:VEVENT
LAST-MODIFIED:20190902T151649
UID:d7f4bed92a83499c81392678cd655aeb
DTSTAMP:20190902T151649
DTSTART;TZID="Europe/London":20190906T090000
DTEND;TZID="Europe/London":20190906T170000
TRANSP:OPAQUE
SEQUENCE:0
SUMMARY:"test task"
LOCATION:
STATUS:CONFIRMED
ORGANIZER;CN="xxxx@xxxx.com":MAILTO:xxxx@xxxx.com
ATTENDEE;CN="xxxx@xxxx.com";CUTYPE=INDIVIDUAL;PARTSTAT=ACCEPTED;MAILTO:xxxx@xxxx.com
X-MICROSOFT-CDO-BUSYSTATUS:BUSY
X-MICROSOFT-CDO-IMPORTANCE:1
X-MICROSOFT-DISALLOW-COUNTER:FALSE
X-MS-OLK-AUTOFILLLOCATION:FALSE
X-MS-OLK-CONFTYPE:0
CLASS:PUBLIC
PRIORITY:5
END:VEVENT
END:VCALENDAR



--b1_ee3827bf9d86f19f6cb13cbcbc05bb33--

更新事件:

Content-Type: multipart/alternative;
        boundary="b1_23a19fb87bb01c1c2ae6e3fede170549"
Content-Transfer-Encoding: 8bit^M
^M
This is a multi-part message in MIME format.

--b1_23a19fb87bb01c1c2ae6e3fede170549
Content-Type: text/plain; charset=us-ascii

[test] testing iCal - updated


--b1_23a19fb87bb01c1c2ae6e3fede170549
Content-Type: text/html; charset=us-ascii

<b>Delivery Details:</b></u><br /><i>Off-Site</i><br /><u><b>Technical Contact Name:</b></u> Test User<br /><u><b>Technical Contact Number:</b></u> 12345<br /><u><b>Technical Contact e-mail:</b></u> anothertest@test.com<br /><u><b>Work to be done:</b></u><br /><p>[test] testing iCal - updated</p>


--b1_23a19fb87bb01c1c2ae6e3fede170549
Content-Type: text/calendar; method=REQUEST; charset=iso-8859-1
Content-Transfer-Encoding: 8bit

BEGIN:VCALENDAR
PRODID:-//Microsoft Corporation//Outlook 10.0 MIMEDIR//EN
VERSION:2.0
METHOD:REQUEST
BEGIN:VTIMEZONE
TZID:Europe/London
BEGIN:STANDARD
DTSTART:20091101T020000
RRULE:FREQ=YEARLY;INTERVAL=1;BYDAY=-1SU;BYMONTH=10
TZOFFSETFROM:+0100
TZOFFSETTO:+0000
TZNAME:GMT
END:STANDARD
BEGIN:DAYLIGHT
DTSTART:20090301T020000
RRULE:FREQ=YEARLY;INTERVAL=1;BYDAY=-1SU;BYMONTH=3
TZOFFSETFROM:+0000
TZOFFSETTO:+0100
TZNAME:BST
END:DAYLIGHT
END:VTIMEZONE
BEGIN:VEVENT
CATEGORIES:Louis Marchant
LAST-MODIFIED:20190902T152651
UID:d7f4bed92a83499c81392678cd655aeb
DTSTAMP:20190902T152651
DTSTART;TZID="Europe/London":20190907T090000
DTEND;TZID="Europe/London":20190907T170000
TRANSP:OPAQUE
SEQUENCE:2
SUMMARY:"test event"
LOCATION:
STATUS:CONFIRMED
ORGANIZER;CN="xxxx@xxxx.com":MAILTO:xxxx@xxxx.com
ATTENDEE;CN="xxxx@xxxx.com";CUTYPE=INDIVIDUAL;PARTSTAT=ACCEPTED;MAILTO:xxxx@xxxx.com
X-MICROSOFT-CDO-BUSYSTATUS:BUSY
X-MICROSOFT-CDO-IMPORTANCE:1
X-MICROSOFT-DISALLOW-COUNTER:FALSE
X-MS-OLK-AUTOFILLLOCATION:FALSE
X-MS-OLK-CONFTYPE:0
CLASS:PUBLIC
PRIORITY:5
END:VEVENT
END:VCALENDAR



--b1_23a19fb87bb01c1c2ae6e3fede170549--

取消事件 - 不再工作的事件:

Content-Type: multipart/alternative;
        boundary="b1_87ddce1a469e89e0c0caa7b0a82efd5e"
Content-Transfer-Encoding: 8bit^M
^M
This is a multi-part message in MIME format.

--b1_87ddce1a469e89e0c0caa7b0a82efd5e
Content-Type: text/plain; charset=us-ascii

Meeting Cancelled


--b1_87ddce1a469e89e0c0caa7b0a82efd5e
Content-Type: text/html; charset=us-ascii

Meeting Cancelled


--b1_87ddce1a469e89e0c0caa7b0a82efd5e
Content-Type: text/calendar; method=REQUEST; charset=iso-8859-1
Content-Transfer-Encoding: 8bit

BEGIN:VCALENDAR
PRODID:-//Microsoft Corporation//Outlook 10.0 MIMEDIR//EN
VERSION:2.0
METHOD:CANCEL
BEGIN:VTIMEZONE
TZID:Europe/London
BEGIN:STANDARD
DTSTART:20091101T020000
RRULE:FREQ=YEARLY;INTERVAL=1;BYDAY=-1SU;BYMONTH=10
TZOFFSETFROM:+0100
TZOFFSETTO:+0000
TZNAME:GMT
END:STANDARD
BEGIN:DAYLIGHT
DTSTART:20090301T020000
RRULE:FREQ=YEARLY;INTERVAL=1;BYDAY=-1SU;BYMONTH=3
TZOFFSETFROM:+0000
TZOFFSETTO:+0100
TZNAME:BST
END:DAYLIGHT
END:VTIMEZONE
BEGIN:VEVENT
CATEGORIES:Louis Marchant
LAST-MODIFIED:20190902T152921
UID:d7f4bed92a83499c81392678cd655aeb
DTSTAMP:20190902T152921
DTSTART;TZID="Europe/London":20190907T090000
DTEND;TZID="Europe/London":20190907T170000
TRANSP:OPAQUE
SEQUENCE:2
SUMMARY:"Louis Marchant - Offsite - 2 Circles Communication Limited 602"
LOCATION:
STATUS:CANCELLED
ORGANIZER;CN="xxxx@xxxx.com":MAILTO:xxxx@xxxx.com
ATTENDEE;CN="xxxx@xxxx.com";CUTYPE=INDIVIDUAL;PARTSTAT=ACCEPTED;MAILTO:xxxx@xxxx.com
X-MICROSOFT-CDO-BUSYSTATUS:BUSY
X-MICROSOFT-CDO-IMPORTANCE:1
X-MICROSOFT-DISALLOW-COUNTER:FALSE
X-MS-OLK-AUTOFILLLOCATION:FALSE
X-MS-OLK-CONFTYPE:0
CLASS:PUBLIC
PRIORITY:5
END:VEVENT
END:VCALENDAR



--b1_87ddce1a469e89e0c0caa7b0a82efd5e--

任何见解都会有所帮助,因为我的想法很新鲜。尽管我怀疑这可能只是不再可能,尽管我显然希望情况并非如此。

标签: outlookphpmailericalendar

解决方案


PHPMailer 的 iCal 支持有一些限制,其中一些与它在不同客户端中支持的极其不一致的方式有关。本期讨论了其中的一些问题。

一个单独的问题与除 之外的 iCal 事件REQUEST有关,特别是在 Outlook 中。此问题在您的示例中可见:

Content-Type: text/calendar; method=REQUEST; charset=iso-8859-1

METHOD:CANCEL

请注意,这两个方法名称不匹配;这是因为 PHPMailer 目前只支持REQUEST-type 消息,而且 Outlook 很可能不喜欢这种不匹配。我在第二期的建议是 PHPMailer 可以扫描属性中提供的 iCal 数据的内容ICal并提取方法值,然后在用于该元素的内容类型标头中使用它。

PHPMailer 目前不这样做 - 但如果您愿意添加对它的支持并提交拉取请求,那将是非常受欢迎的。


推荐阅读