|  30.07.2008, 11:51 | #1 | 
| Участник | Проблема запуска MS WORD 
			
			Добрый день! Подскажите столкнулся с такой проблемой: Делаю plug-ins который по событию создания нового account будет создавать документ MS Word) Code: using System; using Microsoft.Crm.Sdk; using Microsoft.Crm.SdkTypeProxy; using Microsoft.Office.Interop.Word; using Microsoft; namespace Microsoft.Crm.Sdk.Walkthrough { public class AccountCreateHandler: IPlugin { public void Execute(IPluginExecutionContext context) { DynamicEntity entity = null; #region Verify execution context // Check if the input parameters property bag contains a target // of the create operation and that target is of type DynamicEntity. if (context.InputParameters.Properties.Contains("Target") && context.InputParameters.Properties["Target"] is DynamicEntity) { // Obtain the target business entity from the input parmameters. entity = (DynamicEntity)context.InputParameters.Properties["Target"]; // Verify that the entity represents an account. if (entity.Name != EntityName.account.ToString()) { return; } } else { return; } #endregion Verify execution context try { //System.Console.WriteLine("Opening a new Word document..."); MSWord.openDocument(); //System.Console.WriteLine("Writing stuff to the document."); MSWord.writeStuff("This is a test."); //System.Console.WriteLine("Saving the document and exiting."); MSWord.closeDocument(@"c:\done_test.doc"); } catch (System.Web.Services.Protocols.SoapException ex) { throw new Exception(ex.Detail.ToString(), ex); } } } class MSWord { public static ApplicationClass word = new ApplicationClass(); public static Document doc = null; public static void openDocument() { word.Visible = true; object file = @"C:\template.dot"; // blank path = new document object newTemplate = false; object docType = 0; object isVisible = false; // add a new document based off of the normal.dot template doc = word.Documents.Add(ref file, ref newTemplate, ref docType, ref isVisible); doc.Activate(); } public static void writeStuff(string what) { System.Console.WriteLine("Total bookmoarks: " + doc.Bookmarks.Count); foreach (Bookmark bk in doc.Bookmarks) { if (bk.Name == "testbook") { bk.Range.Text = "This is a content of bookmark"; } } doc.Tables[1].Rows[1].Cells[1].Range.Text = "Hello word"; //doc.Tables[0].Cell(0, 0).Range.Text = "hello from C#"; word.Selection.TypeText(what); } public static void closeDocument(string path) { object filePath = (object)path; object False = false; object True = true; object blank = ""; object format = WdOpenFormat.wdOpenFormatAuto; //object encoder = Office.MsoEncoding.msoEncodingUSASCII; object unicode = 65001; object missing = System.Reflection.Missing.Value; doc.SaveAs(ref filePath, ref format, ref missing, ref missing, ref missing, ref missing, ref missing, ref missing, ref missing, ref missing, ref missing, ref missing, ref missing, ref missing, ref missing, ref missing); word.Quit(ref missing, ref missing, ref missing); } } } После выполнения лог: # CRM Tracing Version 2.0 # LocalTime: 2008-07-30 00:20:40.4 # Categories: # CallStackOn: No # ComputerName: MOSS # CRMVersion: 4.0.7333.3 # DeploymentType: OnPremise # ScaleGroup: # ServerRole: AppServer, AsyncService, DiscoveryService, WebService, ApiServer, HelpServer, DeploymentService [2008-07-30 00:20:40.4] Process: w3wp |Organization:00000000-0000-0000-0000-000000000000 |Thread: 8(MSCRM:-NotificationManager.NotificationWatcherThreadProc) |Category: Exception |User: 00000000-0000-0000-0000-000000000000 |Level: Error | NotificationManager.NotificationWatcherThreadProc at NotificationManager.NotificationWatcherThreadProc() at ThreadHelper.ThreadStart_Context(Object state) at ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state) at ThreadHelper.ThreadStart() >ThreadAbort Exception in NotificationWatcherThreadProc Thread was being aborted. [2008-07-30 00:20:40.4] Process: w3wp |Organization:00000000-0000-0000-0000-000000000000 |Thread: 8(MSCRM:-NotificationManager.NotificationWatcherThreadProc) |Category: Platform |User: 00000000-0000-0000-0000-000000000000 |Level: Error | NotificationManager.NotificationWatcherThreadProc >NotificationWatcherThreadProc Stopped. Подскажите, в чем может быть проблема. Кучу всего уже пробовал пока 0 решения. Последний раз редактировалось AlekseyS; 31.07.2008 в 13:05. | 
|  | 
|  30.07.2008, 13:51 | #2 | 
| Участник | 
			
			plug-ins не работает    Последний раз редактировалось AlekseyS; 31.07.2008 в 13:05. | 
|  | 
|  30.07.2008, 14:37 | #3 | 
| Учаснег | 
			
			насколько я знаю, формирование документа WORD не работает в контексте сервера, а именно на сервер CRM и выполняется plug-in.
		 | 
|  | 
|  30.07.2008, 17:08 | #4 | 
| Moderator | 
			
			Может на сервере нет Office?
		 
				__________________ http://fixrm.wordpress.com, снятие/наведение порчи. Быстро, дорого, гарантия.   MS Certified Dirty Magic Professional | 
|  | 
|  30.07.2008, 18:52 | #5 | 
| Участник | 
			
			Стоит Office 2007. + в dcomcnfg добавил юзера Network Service | 
|  | 
|  31.07.2008, 13:00 | #6 | 
| Участник | 
			
			Заметил, что если удалить файл шаблон с диска с… то СРМ начинает ругаться что не может найти файл. Значить проблема в запуске самого WORD на сервер? Может кто что посоветует? Если просто на сервере запустить шаблон то все открывает. | 
|  | 
|  31.07.2008, 13:33 | #7 | 
| Moderator | 
			
			Вот ссылка на статью, как работать с Excel через сервер, может быть что-то подчерпнете: http://blogs.msdn.com//crm/archive/2...xcel-2007.aspx 
				__________________ http://fixrm.wordpress.com, снятие/наведение порчи. Быстро, дорого, гарантия.   MS Certified Dirty Magic Professional | 
|  | 
|  01.08.2008, 01:25 | #8 | 
| Участник | 
			
			Отловили ошибку L((((( На строке: doc = word.Documents.Add(ref file, ref newTemplate, ref docType, ref isVisible); зависает и все…L((((( Хелп J П.С. проблема именно с Documents.Add поскольку просто .тхт создает без проблем | 
|  | 
|  01.08.2008, 14:00 | #9 | 
| Участник | 
			
			последний ломтик надежды - запустить аппликейшен пул от другого пользователя, привилегированного. Вот только как это сделать, чтобы не отвалился CRM???
		 | 
|  | 
|  05.08.2008, 00:52 | #10 | 
| Участник | 
			
			Всем спасибо! Решил проблему использовал XmlDocument.
		 | 
|  | 
|  05.08.2008, 08:42 | #11 | 
| Moderator | 
			
			Не поясните более развернуто?
		 
				__________________ http://fixrm.wordpress.com, снятие/наведение порчи. Быстро, дорого, гарантия.   MS Certified Dirty Magic Professional | 
|  | 
|  05.08.2008, 12:52 | #12 | 
| Участник | 
			
			//Create a new annotation object, which represents the notes you see in CRM.  annotation newsgroupsNote = newannotation(); //The annotation's body. It is displayed in the notes view. newsgroupsNote.notetext = "Document"; // - \r\n //The objectid specifies to which business object the annotation belongs. newsgroupsNote.objectid = newLookup(); newsgroupsNote.objectid.type = EntityName.account.ToString(); newsgroupsNote.objectid.Value = newGuid(context.OutputParameters.Properties["id"].ToString()); //The objecttypecode specifies the type of the parent entity. newsgroupsNote.objecttypecode = newEntityNameReference(); newsgroupsNote.objecttypecode.Value = EntityName.account.ToString(); //The subject. newsgroupsNote.subject = "You should look ready document"; //Create the annotation ICrmService service = context.CreateCrmService(true); Guid annotID = service.Create(newsgroupsNote); account ent = (account)service.Retrieve(EntityName.account.ToString(),newGuid(context.OutputParameters.Properties["id"].ToString()), newAllColumns()); annotation oAnnotation = newannotation(); XmlDocument doc = newXmlDocument(); doc.Load(@"..."); ... что то делаем (кому что надо  ) // doc.Save(@"..." + name); // .doc StreamReader reader = newStreamReader(@"..." + name); string input = GetBase64StringFromFile(@"..." + name); TargetUpdateAnnotation tua = newTargetUpdateAnnotation(); Key oKey = newKey(); oKey.Value = annotID; oAnnotation.annotationid = oKey; oAnnotation.filename = oAnnotation.filename = name; oAnnotation.mimetype = "application/xml"; oAnnotation.documentbody = input; CrmNumber oNumber = newCrmNumber(); oNumber.Value = 4; oAnnotation.filesize = oNumber; tua.Annotation = oAnnotation; UpdateRequest req = newUpdateRequest(); req.Target = tua; UpdateResponse resp = (UpdateResponse)service.Execute(req); | 
|  | 
|  05.08.2008, 12:54 | #13 | 
| Участник | 
			
			Вот так и сделали   для 2003 - 2007 worda | 
|  | 
|  05.08.2008, 23:16 | #14 | 
| Moderator | 
			
			Ээээ. Не вкурил где тут создается документ ворд по шаблону? Или вы отказались от первоначального плана в пользу более простого решения - добавления примечания?
		 
				__________________ http://fixrm.wordpress.com, снятие/наведение порчи. Быстро, дорого, гарантия.   MS Certified Dirty Magic Professional | 
|  | 
|  06.08.2008, 23:52 | #15 | 
| Участник | 
			
			просто шаблон в хмл
		 | 
|  | 
|  07.08.2008, 00:00 | #16 | 
| Участник | 
			
			Google: ...Поддержка XML в Word 2003 - одно из наиболее впечатляющих достижений Microsoft Office 2003. Благодаря использованию XML данные Word становятся свободными, незаблокированными, и их легко модифицировать. Кроме того, XML упрощает обмен информацией между документами, базами данных и другими приложениями. http://www.gotdotnet.ru/LearnDotNet/...ces/30939.aspx | 
|  | 
| Теги | 
| word | 
|  | 
| Опции темы | Поиск в этой теме | 
| Опции просмотра | |
| 
 |