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 CoreMarkdown

Introducing TXTextControl.Markdown.Core: Import and Export Markdown in TX…

We are happy to announce the release of TXTextControl.Markdown.Core, a powerful new component that enables seamless import and export of Markdown files in TX Text Control. This addition enhances…


ASP.NETASP.NET CoreConference

Text Control at NDC Copenhagen Developers Festival 2025

Last week, Text Control participated in the NDC Copenhagen Developers Festival 2025, a leading event for software developers and IT professionals in Scandinavia. We showcased our latest…


ASP.NETASP.NET Core

Creating Trusted Document Containers with PDF/A-3b in .NET C#

TX Text Control allows developers to do more than just generate PDFs. They can also build trusted digital archives that combine human-readable documents and machine-readable data in one secure,…


ASP.NETASP.NET Core

Best Practices for Image Compression when Exporting to PDF in .NET C#

When generating PDFs programmatically, one of the most important factors affecting file size and rendering performance is how images are embedded and compressed. This article explores best…


ASP.NETASP.NET CoreFiltering

Filtering and Sorting Repeating Blocks in MailMerge using C#

TX Text Control MailMerge's ability to filter and sort repeating merge blocks is a key strength, making it ideal for creating dynamic reports, lists, and catalogs.