Настройка в .NET 6 или выше
Файл Startup.cs
В файле Startup.cs проекта .NET Core эти строки кода определяют конфигурацию конвейера middleware с использованием метода MapWhen. Предоставленное предикат проверяет, заканчиваться ли путь входящего запроса на DocImage.axd. Внутри этого блока вызывается метод UseDoconut с объектом DoconutOptions в качестве аргумента.
app.MapWhen(
context => context.Request.Path.ToString().EndsWith("DocImage.axd"),
appBranch =>
{
appBranch.UseDoconut(new DoconutOptions { UnSafeMode = false, ShowDoconutInfo = false });
}
);Добавить пространства имён Doconut
В вашем проекте добавьте следующие using statements:
using Doconut;
using Doconut.Configs;
using Doconut.Formats;
using Doconut.Clouds;Создать экземпляр объекта Viewer
Эта строка создает новый экземпляр класса Viewer, позволяя вам создать объект viewer в вашем коде.
var docViewer = new Viewer(_cache, _accessor, licenseFilePath);Настроить объект DocOptions
Пример инициализации объекта DocOptions с конкретными настройками:
var documentOptions = new DocOptions
{
Password = "",
ImageResolution = 200,
TimeOut = 30
};Настроить объект конфигурации
Инициализировать новый объект PdfConfig с конкретными настройками для обработки PDF‑документов:
var config = new PdfConfig { DefaultRender = true, ExtractHyperlinks = true };Открыть ваш документ
Эта строка вызывает метод OpenDocument объекта viewer, передавая путь к файлу документа, расположенного на сервере, и ранее сконфигурированные объекты PdfConfig и DocOptions в качестве параметров.
var token = docViewer.OpenDocument(pathToFile, config, documentOptions);Добавить viewer в ваш HTML
<div id="div_ctlDoc"></div>Добавить CSS и JavaScript файлы
Добавьте следующие CSS и JavaScript файлы на страницу. Эти скрипты включены в ZIP‑файл с образцами кода.
<!-- Main Viewer Related Scripts -->
<script src="scripts/splitter.js"></script>
<script src="scripts/docViewer.js"></script>
<script src="scripts/documentLinks.js"></script>
<!-- Viewer functions -->
<script src="scripts/docViewer.UI.js?v=1"></script>Добавить лицензии в ваш проект
Автоматическое обнаружение лицензии
Чтобы инициализировать docViewer с автоматическим обнаружением лицензии, используйте следующую строку:
var docViewer = new Viewer(_cache, _accessor);Добавить ручную лицензию по умолчанию
Вы можете вручную указать путь к единственному файлу лицензии по умолчанию при инициализации viewer.
var licenseFilePath = Path.Combine(_hostingEnvironment.WebRootPath, "path/to/your/license");
var docViewer = new Viewer(_cache, _accessor, licenseFilePath);Добавить лицензию через поток
Этот метод использует перегрузку Viewer.DoconutLicense(Stream licenseStream) для добавления лицензии через поток.
using (var licenseStream = new FileStream("path/to/your/license", FileMode.Open))
{
Viewer.DoconutLicense(licenseStream);
}Добавить лицензию через XML‑документ
Этот метод использует перегрузку Viewer.DoconutLicense(XMLDocument licence) для добавления лицензии через XML‑документ.
var xmlDoc = new XmlDocument();
xmlDoc.Load("path/to/your/license.xml");
Viewer.DoconutLicense(xmlDoc);Ручное добавление нескольких плагин‑лицензий
Если требуется указать несколько лицензий, можно предоставить список путей к файлам при инициализации viewer.
List<string> licenseFilePaths = new List<string>
{
Path.Combine(_hostingEnvironment.WebRootPath, "Doconut.Viewer.lic"),
Path.Combine(_hostingEnvironment.WebRootPath, "Doconut.Viewer.Annotation.lic"),
Path.Combine(_hostingEnvironment.WebRootPath, "Doconut.Viewer.Search.lic")
};
var docViewer = new Viewer(_cache, _accessor, licenseFilePaths);Добавить плагин‑лицензию через поток
Этот метод использует перегрузку Viewer.SetLicensePlugin(Stream pluginLicence) для добавления плагин‑лицензии через поток.
using (var pluginLicenseStream = new FileStream("path/to/your/plugin-license.lic", FileMode.Open))
{
Viewer.SetLicensePlugin(pluginLicenseStream);
}Добавить плагин‑лицензию через XML‑документ
Этот метод использует перегрузку Viewer.SetLicensePlugin(XMLDocument xmlPluginLicence) для добавления плагин‑лицензии через XML‑документ.
var pluginXmlDoc = new XmlDocument();
pluginXmlDoc.Load("path/to/your/plugin-license.xml");
Viewer.SetLicensePlugin(pluginXmlDoc);Необходимые пакеты NuGet
Чтобы ваш проект полностью соответствовал .NET Core Standard, необходимо включить следующие пакеты NuGet, перечисленные в алфавитном порядке.
- MessagePack - Version 2.5.140
- Microsoft.Bcl.AsyncInterfaces - Version 8.0.0
- Microsoft.Extensions.Caching.Abstractions - Version 8.0.0
- Microsoft.Extensions.Configuration - Version 8.0.0
- Microsoft.Extensions.Configuration.Abstractions - Version 8.0.0
- Microsoft.Extensions.Configuration.FileExtensions - Version 8.0.0
- Microsoft.Extensions.Configuration.Json - Version 8.0.0
- Microsoft.Extensions.FileProviders.Abstractions - Version 8.0.0
- Microsoft.Extensions.FileProviders.Physical - Version 8.0.0
- Microsoft.Extensions.FileSystemGlobbing - Version 8.0.0
- Microsoft.Extensions.Primitives - Version 8.0.0
- System.Buffers - Version 4.5.1
- System.Formats.Asn1 - Version 8.0.0
- System.Numerics.Vectors - Version 4.5.0
- System.Security.Cryptography.Cng - Version 5.0.0
- System.Security.Cryptography.Pkcs - Version 8.0.0
- System.Text.Encoding.CodePages - Version 8.0.0
- System.Text.Encodings.Web - Version 8.0.0
- System.Text.Json - Version 8.0.3
- System.Threading.Tasks.Extensions - Version 4.5.4
Параметры конфигурации рендеринга
Вы можете настроить поведение рендеринга с помощью следующих параметров:
- CadConfig: используется для файлов DWG, DXF и DGN.
- EmailConfig: используется для файлов EML, EMLX и MSG.
- EpubConfig: используется для файлов EPUB.
- ExcelConfig: используется для файлов Excel и CSV.
- MhtConfig: используется для файлов MHT.
- PptConfig: используется для файлов PowerPoint.
- ProjectConfig: используется для файлов MPP.
- PsdConfig: используется для файлов PSD.
- TxtConfig: используется для файлов TXT.
- TiffConfig: используется для файлов TIFF.
Конфигурация параметров рендеринга
Параметры рендеринга настраиваются через свойство DefaultRender:
- DefaultRender = true : Эта опция обеспечивает более высокое качество рендеринга, но использует больше памяти и процессорного времени сервера.
- DefaultRender = false : Эта опция обеспечивает более быстрый рендеринг за счёт небольшого снижения качества.
Как добавить аннотацию изображения
В C#
1. Откройте документ и получите размеры первой страницы. 2. Инициализируйте AnnotationManager с размерами страницы. 3. Создайте ImageAnnotation, указывая путь к изображению в imgUrl, и задайте позицию и размер внутри Rectangle. 4. Добавьте аннотацию в менеджер и загрузите её в документ viewer для отображения.
var token = docViewer.OpenDocument(pathToFile, config, documentOptions);
var firstPage = docViewer.GetThumbnailDimensions(1, 0, 100, false);
var pageWidth = firstPage.Width;
var pageHeight = firstPage.Height;
using (var annMgr = docViewer.GetAnnotationManager(pageWidth, pageHeight))
{
string imgUrl = "img/sample.png";
var imgAnn = new ImageAnnotation(
1,
new Rectangle(600, 700, 750, 300),
imgUrl
);
annMgr.Add(imgAnn);
docViewer.LoadAnnotationXML(annMgr.GetAnnotationXml());
}В JavaScript
1. Убедитесь, что YourController доступен. 2. Создайте новый ImageAnnotation, указывая путь к изображению с помощью SetNote. 3. Добавьте и отрисуйте аннотацию, чтобы она отобразилась в документе.
function ImageStamp() {
if (null != objctlDoc.YourController()) {
var objStampImage = new ImageAnnotation({ left: 200, top: 200, width: 260, height: 55 });
objctlDoc.YourController().AddAnnotation(null, objStampImage, null);
objStampImage.SetNote('/images/Approved_Stamp.png');
objStampImage.Paint();
}
}Пользовательские шрифты в документах Word
Свойство FontFolders в классе WordConfig указывает пользовательские каталоги, где приложение будет искать шрифты. Это особенно полезно для обработки Word‑документов, которые используют шрифты, не установленные в системных каталогах по умолчанию.
var config = new WordConfig
{
FontFolders = new string[] { "C:\\CustomFonts", "D:\\SharedFonts" }
};Важное обновление для Doconut 25.2.0
Необходимо обновить пакет System.Text.Json до версии 8.0.5 во всех ваших проектах. Это обновление критически важно для совместимости с новыми функциями и устранения важных уязвимостей безопасности.
Кодировка Email
Свойство EmailEncoding в классе EmailConfig задаёт предпочтительную кодировку для темы и тела письма.
var emailConfig = new EmailConfig {
EmailEncoding = Encoding.UTF8 // Set preferred email encoding
};Кодировка темы и тела письма
Свойства SubjectEncoding и BodyEncoding в классе EmailConfig определяют кодировку, используемую для темы и тела письма соответственно.
var emailConfig = new EmailConfig {
SubjectEncoding = Encoding.UTF8, // Set encoding for the subject
BodyEncoding = Encoding.UTF8 // Set encoding for the body
};Поддержка культуры Word Viewer
Свойство DocumentCulture в классе WordConfig позволяет явно задать культуру для файлов DOC и DOCX. Это гарантирует, что локализованный контент — такие как даты, валюты и числа — будет отображаться точно так же, как в Microsoft Word. Особенно полезно для языков со специфическими требованиями к форматированию.
var config = new WordConfig { DocumentCulture = "he-IL" }; // Hebrew (Israel)
var config = new WordConfig { DocumentCulture = "ar-SA" }; // Arabic (Saudi Arabia)
var config = new WordConfig { DocumentCulture = "th-TH" }; // Thai (Thailand)
var config = new WordConfig { DocumentCulture = "ja-JP" }; // Japanese (Japan)Скачать необходимые CSS и JS файлы
Чтобы Doconut функционировал корректно, необходимо включить в проект определённые CSS и JS файлы. Вы можете скачать ZIP‑файл со всеми необходимыми файлами по ссылке ниже: