Открытие документа Word из Sharepoint, замена текста и передача пользователю

Я хочу иметь возможность хранить шаблонный текстовый документ в Sharepoint и использовать его в качестве основы для создания текстового документа, содержащего данные, введенные в шаблон.

Я могу получить текст моего документа Word, используя следующий код:

    SPSite sc = SPContext.Current.Site; 
    SPWeb web = sc.AllWebs["MySite"];             

    string contents = web.GetFileAsString("Documents/MyTemplateWord.doc"); 

    web.Dispose(); 

Затем я могу заменить строку в переменной «contents». Это прекрасно работает.

Теперь я хочу «открыть» этот новый контент как текстовый документ.

Мой код для этого выглядит следующим образом:

string attachment = "attachment; filename=MyWord.doc"; 
    HttpContext.Current.Response.Clear(); 
    HttpContext.Current.Response.ClearHeaders(); 
    HttpContext.Current.Response.ClearContent(); 
    HttpContext.Current.Response.AddHeader("content-disposition", attachment); 
    HttpContext.Current.Response.ContentType = "text/ms-word"; 
    HttpContext.Current.Response.Write(outputText); 
    HttpContext.Current.Response.End(); 

Однако я получаю сообщение об ошибке и не знаю, как ее решить.

Ошибка: Sys.WebForms.PageRequestManagerParserErrorException: сообщение, полученное от сервера, не может быть проанализировано. Распространенными причинами этой ошибки являются изменения ответа вызовами Response.Write(), фильтрами ответа, HttpModules или включенной трассировкой сервера. Подробности: Ошибка синтаксического анализа рядом с 'ࡱ>

Теперь ясно, что у него есть проблемы с разбором «строкового» содержимого.

Что я делаю неправильно? Есть ли другой способ, которым я должен это делать?


person ozz    schedule 28.11.2011    source источник


Ответы (2)


Вы не читаете строку, вы конвертируете двоичные данные в строку. (Помните, что docx — это zip-файл, содержащий данные xml). Природа вашего подхода к замене текста ошибочна в этом отношении.

Если бы не желание найти/заменить текст, то рекомендовал бы

using(SPWeb web = new SPSite("<Site URL>").OpenWeb())
{
    SPFile file = web.GetFile("<URL for the file>");
    byte[] content = file.OpenBinary();
    HttpContext.Current.Response.Write(content);
}

http://support.microsoft.com/kb/929265 Использование BinaryWrite для получения данных твоя страница.

Однако, поскольку вы используете Word, я бы рекомендовал загрузить документ в экземпляр объекты Microsoft.Office.Interop.Word. Однако использование Word Interop может быть чем-то вроде вампира времени.

person Nat    schedule 28.11.2011

1- добавьте сборку docx в ваш пакет shaepoint https://docx.codeplex.com

2- с помощью Новакода;

3- обратите внимание на следующую кнопку загрузки образца

  protected void ButtonExportToWord_Click(object sender, EventArgs e)
        { 
            byte[] bytesInStream;

            using (Stream tplStream =
                SPContext.Current.Web.GetFile("/sitename/SiteAssets/word_TEMPLATE.docx").OpenBinaryStream())
            {
                using (MemoryStream ms = new MemoryStream((int)tplStream.Length))
                {
                    CopyStream(tplStream, ms);
                    ms.Position = 0L;

                    DocX doc = DocX.Load(ms);
                    ReplaceTextProxy(doc,"#INC#", "11111111");

                    doc.InsertParagraph("This is my test paragraph");

                    doc.Save();
                    bytesInStream = ms.ToArray();
                }
            }

            Page.Response.Clear();
            Page.Response.AddHeader("Content-Disposition", "attachment; filename=" +
                CurrentFormId + ".docx");
            Page.Response.AddHeader("Content-Length", bytesInStream.ToString());
            Page.Response.ContentType = "Application/msword";
            Page.Response.BinaryWrite(bytesInStream);

            Page.Response.Flush();
            Page.Response.Close();
            //Page.Response.End();// it throws an error
        }

        private void ReplaceTextProxy(DocX doc, string oldvalue, string newValue)
        {
            doc.ReplaceText(oldvalue,newValue,false, RegexOptions.None, null, null,
                        MatchFormattingOptions.SubsetMatch);
        }
person Iman    schedule 31.03.2014