Создание файла VCS через C#, но в outlook или C# мои даты не нравятся
Я пытаюсь создать файл.vcs в C#. В основном, в Outlook, если вы добавляете встречу в календаре, создается файл, который в Outlook выглядит так:
Вы можете экспортировать этот файл, щелкнув по нему правой кнопкой мыши и открыв его в своем любимом текстовом редакторе. Это выглядит примерно так:
BEGIN:VCALENDAR
PRODID:-//Flo Inc.//FloSoft//EN
BEGIN:VEVENT
DTSTART:6/12/2012 12:00:00 PM
DTEND:6/12/2012 1:00:00 PM
LOCATION:Meeting room 1
DESCRIPTION;ENCODING=QUOTED-PRINTABLE:Learn about assets.
SUMMARY:asset management training.
X-MICROSOFT-CDO-BUSYSTATUS:OOF
PRIORITY:5
END:VEVENT
END:VCALENDAR
Так что у меня проблема с фактическим временем в DTSTART и DTEND сверху. Вы можете видеть, что когда я открываю файл outlook, он говорит 11:00 утра (как показано на снимке экрана), но в текстовом файле он у меня как 12:00 вечера.
Итак, у меня есть приложение (обучающее приложение), в котором я динамически создаю один из этих файлов vcs. Используя C#, я собираю тему, местоположение, описание и даты (со временем) примерно так:
protected void btnOutlook_Click(object sender, EventArgs e)
{
string location;
string description;
string subject;
string fromTime;
string toTime;
location = txtLocation.Text;
description = txtDescription.Text;
subject = lblTitle.Text;
fromTime = ddlFromTimeHH.SelectedItem.Text + ":" + ddlFromTimeMM.SelectedItem.Text + ddlFromTimeAMPM.SelectedItem.Text;
toTime = ddlToTimeHH.SelectedItem.Text + ":" + ddlToTimeMM.SelectedItem.Text + ddlToTimeAMPM.SelectedItem.Text;
string begin = lblDate.Text + " " + fromTime;
string end = lblDate.Text + " " + toTime;
string format = "dd/MM/yyyy h:mmtt";
DateTime trainingDateBegin;
DateTime trainingDateEnd;
if (DateTime.TryParseExact(begin, format, CultureInfo.InvariantCulture, DateTimeStyles.None, out trainingDateBegin))
{
//good date
}
if (DateTime.TryParseExact(end, format, CultureInfo.InvariantCulture, DateTimeStyles.None, out trainingDateEnd))
{
//good date
}
OpenVCSFile("vcsFile.aspx?TrainingDateBegin=" + trainingDateBegin + "&TrainingDateEnd=" + trainingDateEnd + "&Location=" + location + "&Subject=" + subject + "&Description=" + description, "Utilities", "toolbar=0,scrollbars=1,location=0,statusbar=0,menubar=0,resizable=0,width=800,height=500,left=10,top=20");
}
Таким образом, в приведенном выше коде fromTime просто становится, например, 7:00 утра, а toTime становится что-то вроде 8:00 утра. Затем я использую DateTime.TryParseExact, чтобы объединить дату со временем, чтобы она стала, например, 06/01/2012 7:00 am
за beginDate
и для endDate
это становится, например, 06/01/2012 8:00 am
,
Пока все хорошо... тогда я просто вызываю функцию OpenVCSFile, которая представляет собой просто некоторый javascript для открытия переданного в url, вот так:
protected void OpenVCSFile(string url, string name, string att)
{
Response.Write("<script language='JavaScript'>");
Response.Write("x=window.open('" + url + "', '" + name + "','" + att + "');");
Response.Write("x.focus();");
Response.Write("</script>");
}
Это тогда вызывает vcsFile.aspx
страница, где я могу заполнить значения внешнего вида...
protected void Page_Load(object sender, EventArgs e)
{
DateTime beginDate;
DateTime endDate;
string location;
string description;
string subject;
beginDate = Convert.ToDateTime(Request.QueryString["TrainingDateBegin"]);
endDate = Convert.ToDateTime(Request.QueryString["TrainingDateEnd"]);
location = Request.QueryString["Location"];
description = Request.QueryString["Description"];
subject = Request.QueryString["Subject"];
MemoryStream mStream = new MemoryStream();
StreamWriter writer = new StreamWriter(mStream);
writer.AutoFlush = true;
//header
writer.WriteLine("BEGIN:VCALENDAR");
writer.WriteLine("PRODID:-//Flo Inc.//FloSoft//EN");
writer.WriteLine("BEGIN:VEVENT");
//BODY
writer.WriteLine("DTSTART:" + beginDate); //why dont the times come out right...
writer.WriteLine("DTEND:" + endDate); //same here
writer.WriteLine("LOCATION:" + location);
writer.WriteLine("DESCRIPTION;ENCODING=QUOTED-PRINTABLE:" + description);
writer.WriteLine("SUMMARY:" + subject);
writer.WriteLine("X-MICROSOFT-CDO-BUSYSTATUS:OOF");
//FOOTER
writer.WriteLine("PRIORITY:5");
writer.WriteLine("END:VEVENT");
writer.WriteLine("END:VCALENDAR");
//MAKE IT DOWNLOADABLE
Response.Clear(); //clears the current output content from the buffer
Response.AppendHeader("Content-Disposition", "attachment; filename=AddToOutlookCalendar.vcs");
Response.AppendHeader("Content-Length", mStream.Length.ToString());
Response.ContentType = "application/download";
Response.BinaryWrite(mStream.ToArray());
Response.End();
}
Кажется, все работает, кроме самой важной части, раздел, где я делаю это:
writer.WriteLine("DTSTART:" + beginDate); //why dont the times come out right...
writer.WriteLine("DTEND:" + endDate); //same here
Дата выглядит точно так, как вы видите на снимке экрана Outlook, но время всегда неправильное... Обычно Outlook открывает его с 10:00 до 11:00. Но это никогда не занимает времени, которое я даю. Например, в моем коде C# вот экран просмотра:
trainingDateBegin {12/6/2012 12:00:00 PM}
trainingDateEnd {12/6/2012 1:00:00 PM}
Таким образом, мое приложение проходит с датой 12/12/2012 со временем 12:00:00 до 12/12/2012 13:00:00. Но тогда, когда генерируется файл vcs, вот результат:
(если изображение не отображается, в основном outlook имеет всю правильную информацию: тему, местоположение, дату начала, дату окончания, НО время неверное. Оно говорит с 11:00 до 12:00. Это почти как использование моих системных часов EST)...
Кто-нибудь знает, что я могу делать неправильно? Простите за длинный пост:(.
1 ответ
Я думаю, что это связано с часовыми поясами; Вы можете добавить часовой пояс или (намного проще) использовать время UTC в своем файле.
Если вы добавите часовой пояс, вам нужно будет использовать vCal версии 2, поскольку Outlook не поддерживает часовые пояса в версии 1.
РЕДАКТИРОВАТЬ: Это пример синтаксиса, взятого из статьи Википедии о VCalendar. Это событие происходит 14 июля 1997 года с 17:00 (UTC) по 15 июля 1997 года 03:59:59 (UTC):
BEGIN:VCALENDAR
VERSION:2.0
PRODID:-//hacksw/handcal//NONSGML v1.0//EN
BEGIN:VEVENT
UID:uid1@example.com
DTSTAMP:19970714T170000Z
ORGANIZER;CN=John Doe:MAILTO:john.doe@example.com
DTSTART:19970714T170000Z
DTEND:19970715T035959Z
SUMMARY:Bastille Day Party
END:VEVENT
END:VCALENDAR