문서에서 관리 코드 확장 제거
Microsoft Office Word 또는 Microsoft Office Excel에 대한 문서 수준 사용자 지정의 일부인 문서 또는 통합 문서에서 프로그래밍 방식으로 사용자 지정 어셈블리를 제거할 수 있습니다. 그러면 사용자가 문서를 열고 내용을 볼 수 있지만 문서에 추가한 사용자 정의 UI(사용자 인터페이스)는 표시되지 않으며 코드가 실행되지 않습니다.
적용 대상: 이 항목의 정보는 Excel 및 Word의 문서 수준 프로젝트에 적용됩니다. 자세한 내용은 Office 애플리케이션 및 프로젝트 형식에 따라 사용 가능한 기능을 참조하세요.
Visual Studio Tools for Office Runtime에서 제공하는 RemoveCustomization
메서드 중 하나를 사용하여 사용자 지정 어셈블리를 제거할 수 있습니다. 사용하는 메서드는 런타임에 사용자 지정을 제거할지 여부(즉, Word 문서 또는 Excel 통합 문서가 열려 있는 동안 사용자 지정 코드를 실행)나 닫힌 문서 또는 Microsoft Office가 설치되지 않은 서버에 있는 문서에서 사용자 지정을 제거하려는 경우에 따라 다릅니다.
런타임 시 사용자 지정 어셈블리를 제거하려면
사용자 지정 코드에서 RemoveCustomization 메서드(Word의 경우) 또는 RemoveCustomization 메서드(Excel의 경우)를 호출합니다. 이 메서드는 사용자 지정이 더 이상 필요하지 않은 후에만 호출해야 합니다.
코드에서 이 메서드를 호출하는 위치는 사용자 지정을 사용하는 방법에 따라 달라집니다. 예를 들어 고객이 문서 자체만(사용자 지정 아님) 필요한 다른 클라이언트에게 문서를 보낼 준비가 될 때까지 사용자 지정의 기능을 사용하는 경우 고객이 클릭할 때
RemoveCustomization
을 호출하는 일부 UI를 제공할 수 있습니다. 또는 사용자 지정에서 문서를 처음 열 때 데이터로 채우지만 사용자 지정에서 고객이 직접 액세스하는 다른 기능을 제공하지 않는 경우, 사용자 지정이 문서 초기화를 완료하는 즉시 RemoveCustomization을 호출할 수 있습니다.
닫힌 문서 또는 서버의 문서에서 사용자 지정 어셈블리를 제거하려면
콘솔 애플리케이션이나 Windows Forms 프로젝트와 같이 Microsoft Office가 필요하지 않은 프로젝트에서 Microsoft.VisualStudio.Tools.Applications.ServerDocument.dll 어셈블리에 대한 참조를 추가합니다.
코드 파일의 맨 위에 다음 Imports 또는 using 문을 추가합니다.
ServerDocument 클래스의 정적 RemoveCustomization 메서드를 호출하고 매개 변수에 대한 솔루션 문서 경로를 지정합니다.
다음 코드 예제에서는 바탕 화면에 있는 WordDocument1.docx라는 문서에서 사용자 지정 설정을 제거한다고 가정합니다.
string documentPath = System.Environment.GetFolderPath( Environment.SpecialFolder.Desktop) + @"\WordDocument1.docx"; int runtimeVersion = 0; try { runtimeVersion = ServerDocument.GetCustomizationVersion(documentPath); if (runtimeVersion == 3) { ServerDocument.RemoveCustomization(documentPath); System.Windows.Forms.MessageBox.Show("The customization has been removed."); } } catch (FileNotFoundException) { System.Windows.Forms.MessageBox.Show("The specified document does not exist."); } catch (IOException) { System.Windows.Forms.MessageBox.Show("The specified document is read-only."); } catch (InvalidOperationException ex) { System.Windows.Forms.MessageBox.Show("The customization could not be removed.\n" + ex.Message); }
프로젝트를 빌드하고 사용자 지정을 제거할 컴퓨터에서 애플리케이션을 실행합니다. 컴퓨터에 Visual Studio 2010 Tools for Office Runtime이 설치되어 있어야 합니다.