Skip to content

A lightweight ASP.NET Core helper library that writes safe console.log/info/warn/error/table output directly to the browser console during Development and UAT.

License

Notifications You must be signed in to change notification settings

livedcode/DotNetCoreOutputToConsole

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

2 Commits
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

DotNetCoreOutputToConsole

A lightweight ASP.NET Core helper library that allows developers to output logs, variables, and errors directly into the browser console using inline <script> injection.

Ideal for Development, Debug, and UAT environments.


πŸ“₯ Download

You can download the full source code from your GitHub repository once uploaded:

https://github.com/<your-account>/DotNetCoreOutputToConsole

If you need a GitHub release ZIP template, just tell me.


✨ Features

  • Write messages directly to browser DevTools console
  • Supports multiple console API functions:
    • console.log
    • console.info
    • console.warn
    • console.error
    • console.trace
    • console.table
  • Automatically JSON-encodes objects (safe for XSS)
  • Easy integration with ASP.NET Core
  • Only runs in:
    • Development
    • Staging
    • UAT
  • Works with:
    • Minimal API
    • MVC
    • Razor Pages

❗ Not Supported

This library does NOT support Blazor Web App, Blazor Server, or Blazor WebAssembly.

Blazor does NOT execute inline <script> inside its rendering pipeline.
To support Blazor, a JSInterop-based version would be required (future extension).


πŸ“¦ Installation

Add the library project reference:

<ProjectReference Include="..\DotNetCoreOutputToConsole\DotNetCoreOutputToConsole.csproj" />

Or include the source project directly in your solution.


βš™ Environment Setup

Set the environment name so console output only appears in safe environments:

ConsoleOutputSettings.CurrentEnvironment = builder.Environment.EnvironmentName;

The library will ONLY output console messages when the environment is:

  • Development
  • Staging
  • UAT

In Production, all calls become no-ops (silently ignored).


πŸš€ Usage Examples

⭐ Minimal API Example

app.MapGet("/test", async ctx =>
{
    await BrowserConsole.Log(ctx.Response, "Hello from Minimal API");
    await BrowserConsole.Info(ctx.Response, new { User = "livecode", Time = DateTime.UtcNow });
    await BrowserConsole.Warn(ctx.Response, "This is a warning");
    await BrowserConsole.Error(ctx.Response, "This is an error");
    await BrowserConsole.Trace(ctx.Response, "Trace message");
    await BrowserConsole.Table(ctx.Response, new[] {
        new { Id = 1, Name = "Item A" },
        new { Id = 2, Name = "Item B" }
    });

    await ctx.Response.WriteAsync("<h3>Console test complete – open DevTools.</h3>");
});

⭐ MVC Example

Controller

public class HomeController : Controller
{
    public IActionResult Index()
    {
        BrowserConsole.Log(Response, "MVC HomeController loaded");
        BrowserConsole.Info(Response, new { Page = "Home/Index", Time = DateTime.UtcNow });
        BrowserConsole.Warn(Response, "This is a test warning from MVC");
        BrowserConsole.Error(Response, new { Error = "Something failed", Code = 500 });

        return View();
    }
}

View (Views/Home/Index.cshtml)

<h2>MVC Console Test Page</h2>
<p>Check your browser console.</p>

⭐ Razor Pages Example

Pages/Index.cshtml.cs

public class IndexModel : PageModel
{
    public void OnGet()
    {
        BrowserConsole.Info(Response, "Razor Page Loaded");
        BrowserConsole.Table(Response, new[] {
            new { Id = 1, Description = "Razor Row 1" },
            new { Id = 2, Description = "Razor Row 2" }
        });
    }
}

Pages/Index.cshtml

@page
@model IndexModel

<h3>Razor Pages Console Test</h3>
<p>Open browser DevTools β†’ Console.</p>

🧩 Console API Supported

Function Method in Library Example Usage
console.log BrowserConsole.Log() await BrowserConsole.Log(Response, "msg");
console.info BrowserConsole.Info() await BrowserConsole.Info(Response, obj);
console.warn BrowserConsole.Warn() await BrowserConsole.Warn(Response, "warn");
console.error BrowserConsole.Error() await BrowserConsole.Error(Response, ex);
console.trace BrowserConsole.Trace() await BrowserConsole.Trace(Response, "trace");
console.table BrowserConsole.Table() await BrowserConsole.Table(Response, list);

All methods serialize objects to JSON and safely embed them into <script> blocks, which are then executed by the browser.


πŸ” Security Notes

  • Objects are JSON-encoded before being written into the script.
  • Output is restricted to non-production environments via ConsoleOutputSettings.
  • If writing to the response fails (stream closed, headers sent, etc.), the library will silently ignore the error so it never breaks your application behavior.

πŸ“ Project Structure

A typical solution layout:

DotNetCoreOutputToConsole/
β”‚
β”œβ”€β”€ src/
β”‚   β”œβ”€β”€ DotNetCoreOutputToConsole/
β”‚   β”‚   β”œβ”€β”€ DotNetCoreOutputToConsole.csproj
β”‚   β”‚   β”œβ”€β”€ BrowserConsole.cs
β”‚   β”‚   └── Config/
β”‚   β”‚       └── ConsoleOutputSettings.cs
β”‚   β”‚
β”‚   β”œβ”€β”€ DotNetCoreOutputToConsole.Tests/
β”‚   β”‚   β”œβ”€β”€ DotNetCoreOutputToConsole.Tests.csproj
β”‚   β”‚   β”œβ”€β”€ BrowserConsoleTests.cs
β”‚   β”‚   └── Config/
β”‚   β”‚       └── ConsoleOutputSettingsTests.cs
β”‚   β”‚
β”‚   β”œβ”€β”€ MinimalApiConsoleTestApp/
β”‚   β”‚   β”œβ”€β”€ MinimalApiConsoleTestApp.csproj
β”‚   β”‚   └── Program.cs
β”‚   β”‚
β”‚   β”œβ”€β”€ MvcConsoleTestApp/
β”‚   β”‚   β”œβ”€β”€ MvcConsoleTestApp.csproj
β”‚   β”‚   β”œβ”€β”€ Program.cs
β”‚   β”‚   β”œβ”€β”€ Controllers/
β”‚   β”‚   β”‚   └── HomeController.cs
β”‚   β”‚   └── Views/
β”‚   β”‚       └── Home/
β”‚   β”‚           └── Index.cshtml
β”‚   β”‚
β”‚   └── RazorPagesConsoleTestApp/
β”‚       β”œβ”€β”€ RazorPagesConsoleTestApp.csproj
β”‚       β”œβ”€β”€ Program.cs
β”‚       └── Pages/
β”‚           β”œβ”€β”€ Index.cshtml
β”‚           └── Index.cshtml.cs
β”‚
└── README.md

πŸ§ͺ Unit Tests

Unit tests (in DotNetCoreOutputToConsole.Tests) may include:

  • Verifying console script injection content contains the correct function (log/info/warn/error/trace/table).
  • Ensuring no content is written when environment is Production.
  • Verifying that different message types (string, object, collections) serialize correctly to JSON.

Example snippet:

[Fact]
public async Task Log_WritesConsoleLogScriptInDev()
{
    ConsoleOutputSettings.CurrentEnvironment = "Development";

    var ctx = new DefaultHttpContext();
    ctx.Response.Body = new MemoryStream();

    await BrowserConsole.Log(ctx.Response, "Test message");

    ctx.Response.Body.Seek(0, SeekOrigin.Begin);
    var html = new StreamReader(ctx.Response.Body).ReadToEnd();

    Assert.Contains("console.log", html);
    Assert.Contains("Test message", html);
}

πŸ‘€ Author

livecode


πŸ“ License

MIT License β€” see LICENSE.


⭐ Support This Project

If this library makes your ASP.NET Core debugging easier, consider giving it a ⭐ on GitHub!