How can I embed images in an asp net generated word file


ASP.NET is a popular programming language used for developing web applications. One common requirement in web development is the to embed in various file formats, including Word files. In this article, we will explore different approaches to embed images in an ASP.NET generated Word file.

the Open XML SDK

The Open XML SDK is a powerful library that allows to create and manipulate Office documents programmatically. To embed images in a Word file using ASP.NET, we can leverage the Open XML SDK.

First, we need to add a reference to the Open XML SDK in our ASP.NET project. You can do this by right-clicking on the project in Visual , selecting “Manage NuGet Packages,” and searching for “DocumentFormat.OpenXml.” Install the and you're ready to go.

Next, let's see an example of how to embed an image in a Word file using the Open XML SDK:

using DocumentFormat.OpenXml.Packaging;
using DocumentFormat.OpenXml.Wordprocessing;
using .IO;

public void EmbedImageInWordFile(string imagePath, string outputFilePath)
    using (WordprocessingDocument document = WordprocessingDocument.Create(outputFilePath, WordprocessingDocumentType.Document))
        MainDocumentPart mainPart = document.AddMainDocumentPart();
        mainPart.Document = new Document();

        Body body = mainPart.Document.AppendChild(new Body());
        Paragraph paragraph = body.AppendChild(new Paragraph());
        Run run = paragraph.AppendChild(new Run());
        Drawing drawing = run.AppendChild(new Drawing());

        Inline inline = drawing.AppendChild(new Inline());
        Extent extent = new Extent() { Cx = 1000000, Cy = 1000000 };
        inline.AppendChild(new Graphic(new GraphicData(new Picture(new BlipFill(new Blip()
            Embed = mainPart.GetIdOfPart(mainPart.AddImagePart(ImagePartType.Jpeg)),
            CompressionState = CompressionStateValues.Print
        inline.AppendChild(new EffectExtent() { LeftEdge = 0L, TopEdge = 0L, RightEdge = 0L, BottomEdge = 0L });
        inline.AppendChild(new DocProperties() { Id = (UInt32Value)1U, Name = "Picture" });

        using (FileStream stream = new FileStream(imagePath, FileMode.Open))

In the above example, we create a new Word document using the Open XML SDK. We add a main document part, body, paragraph, run, and drawing elements to the document. Then, we create an inline element and the image format (in this case, JPEG) using the BlipFill and Blip classes.

We also set the compression state to “Print” to ensure the image quality is maintained. Finally, we read the image file from the specified path and feed the data into the image part of the Word document.

Using third-party libraries

If you prefer a simpler approach or need more advanced features, you can consider using third-party libraries specifically designed for working with Office documents in ASP.NET.

One popular library is Aspose.Words, which provides a wide range of features for creating, manipulating, and converting Word documents. Here's an example of how to embed an image using Aspose.Words:

using Aspose.Words;

public void EmbedImageInWordFile(string imagePath, string outputFilePath)
    Document doc = new Document();
    DocumentBuilder  = new DocumentBuilder(doc);



In the above example, we create a new instance of the Document class and a DocumentBuilder to manipulate the document. We then use the InsertImage method to the image from the specified path into the Word document. Finally, we save the document to the desired output file.


Embedding images in an ASP.NET generated Word file can be achieved using various approaches. The Open XML SDK provides a low-level, but powerful, way to manipulate Office documents programmatically. Alternatively, third-party libraries like Aspose.Words offer more advanced features and a simpler API for working with Word documents. Choose the approach that best suits your requirements and integrate it into your ASP.NET application to embed images seamlessly.

Rate this post

Leave a Reply

Your email address will not be published. Required fields are marked *

Table of Contents