Products Technologies Demo Docs Blog Support Company

TX Text Control Supports .NET 8 in ASP.NET Core Applications

At the .NET Conf 2023, Microsoft officially announced .NET 8, which is the next long term support (LTS) release after .NET 6. TX Text Control .NET Server supports ASP.NET Core applications built with .NET 8, and this article shows some performance improvements.

TX Text Control Supports .NET 8 in ASP.NET Core Applications

We are pleased to announce Day 0 support for the latest version of the .NET for TX Text Control .NET Server. At the .NET Conf 2023, Microsoft officially announced .NET 8. This new version is supported for 3 years with free support and patches and is the LTS successor to .NET 6.

.NET 8 release schedule

All update notes and especially the performance improvements can be found in a very detailed blog post by Stephen Toub.

Performance Improvements in .NET 8

TX Text Control .NET Server 32.0 supports .NET 8 applications and we have tested our libraries with early versions and the final release version.

Memory and Performance Improvements

To see how the memory footprint and performance improved, we created a simple ASP.NET Core Web App to test the new version.

Creating the Application

Make sure that you downloaded the latest version of Visual Studio 2022 that comes with the .NET 8 SDK. Or download the .NET 8 SDK here:

Download .NET 8.0

  1. In Visual Studio 2022, create a new project by choosing Create a new project.

  2. Select ASP.NET Core Web App (Model-View-Controller) as the project template and confirm with Next.

  3. Choose a name for your project and confirm with Next.

  4. In the next dialog, choose .NET 8 (Long-term support) as the Framework and confirm with Create.

    Creating the .NET 6 project

Adding the NuGet Package

  1. In the Solution Explorer, select your created project and choose Manage NuGet Packages... from the Project main menu.

    Select Text Control Offline Packages from the Package source drop-down.

    Install the latest versions of the following packages:

    • TXTextControl.TextControl.ASP.SDK
    • TXTextControl.Web

    ASP.NET Core Web Application

Configure the Application

  1. Open the Program.cs file located in the project's root folder.

    At the very top of the file, insert the following code:

    using TXTextControl.Web;

    Add the following code after the entry app.UseStaticFiles();:

    // enable Web Sockets
    app.UseWebSockets();
    
    // attach the Text Control WebSocketHandler middleware
    app.UseTXWebSocketMiddleware();

Adding the Control to the View

  1. Find the Index.cshtml file in the Views -> Home folder. Replace the complete content with the following code to add the document editor to the view:

    @using TXTextControl.Web.MVC
    
    @Html.TXTextControl().TextControl().Render()
    
    <input type="button" onclick="loadDocument()" value="Generate Document" />
    
    @section Scripts {
        <script>
            function loadDocument() {
                $.get('@Url.Action("LoadDocument")', function (data) {
                    TXTextControl.loadDocument(TXTextControl.StreamType.InternalUnicodeFormat, data);
                });
            }
        </script>
    }

    This code adds the Document Editor and a button to the view that loads a document generated in a server-side controller method.

  2. Find the HomeController.cs file in the Controllers folder. Insert the following method to the file:

    [HttpGet]
    [Route("Home/LoadDocument")]
    public IActionResult LoadDocument()
    {
        byte[] document;
    
        using (var tx = new TXTextControl.ServerTextControl())
        {
            tx.Create();
            tx.Load("App_Data/invoice.tx", TXTextControl.StreamType.InternalUnicodeFormat);
    
            var jsonData = System.IO.File.ReadAllText("App_Data/data.json");
    
            using (var mailMerge = new MailMerge { TextComponent = tx })
            {
                mailMerge.MergeJsonData(jsonData, true);
            }
    
            tx.Save(out document, TXTextControl.BinaryStreamType.InternalUnicodeFormat);
        }
    
        return new JsonResult(document);
    }
  3. Create a folder named App_Data in the root of your project. Copy the files contained in this ZIP file into this folder.

Executing the Application

When the button is clicked, the MailMerge class is used to merge the JSON data into a template, which is then returned to the editor. The Visual Studio Diagnostic Tools are used to monitor memory usage and document merge time. These values will be compared to the same application that is running with .NET 6.

Start the application by pressing F5 and click the Generate Document button. The document is loaded and the merge process is started. The following screenshots shows the memory usage and the merge time:

.NET 8

In .NET 8, the maximum amount of memory that the application will use is 285 MB or process memory. The ServerGarbageCollection option is set to true for this demo. More information on the differences is available here: Workstation and server garbage collection.

The time it takes to load the template, merge the JSON data, and export the document, resulting in a 25-page document, is approximately 1.9 seconds.

Memory usage and merge time

.NET 6

The same application running with .NET 6 uses 451 MB of process memory. The average time to create the document using the same template and data is approximately 2.4 seconds.

Memory usage and merge time

Conclusion

NET 8 uses approximately 35% less process memory than .NET 6 for this particular benchmark application. The time it takes to generate the document in the controller method is reduced by about 18%.

Stay in the loop!

Subscribe to the newsletter to receive the latest updates.

ASP.NET

Integrate document processing into your applications to create documents such as PDFs and MS Word documents, including client-side document editing, viewing, and electronic signatures.

ASP.NET Core
Angular
Blazor
JavaScript
React
  • Angular
  • Blazor
  • React
  • JavaScript
  • ASP.NET MVC, ASP.NET Core, and WebForms

Learn more Trial token Download trial

Related Posts

ASP.NETASP.NET CoreDigital Signatures

Why Digitally Signing your PDFs is the Only Reliable Way to Prevent Tampering

PDF documents are widely used for sharing information because of their fixed layout and cross-platform compatibility. However, it is crucial to ensure the integrity and authenticity of these…


ASP.NETASP.NET CorePDF/UA

PDF/UA vs. PDF/A-3a: Which Format Should You Use for Your Business Application?

In this blog post, we will explore the differences between PDF/UA and PDF/A-3a, helping you choose the right format for your business needs. We will discuss the key features, benefits, and use…


ASP.NETASP.NET CorePDF/UA

Validating PDF/UA Documents in .NET C#

Creating accessible and compliant PDF documents is becoming an increasingly important requirement across industries. In this blog post, we explore how to validate PDF/UA documents using Text…


ASP.NETASP.NET CoreMarkdown

Bringing MailMerge Power to Markdown: Fluid Placeholders in TX Text Control…

The latest beta version of the TX Text Control Markdown NuGet package introduces support for fluid placeholders, also known as Mustache or Handlebars syntax. This powerful feature enables…


ASP.NETAIASP.NET Core

Automating PDF/UA Accessibility with AI: Describing DOCX Documents Using TX…

This article shows how to use TX Text Control together with the OpenAI API to automatically add descriptive texts (alt text and labels) to images, links, and tables in a DOCX. The resulting…