access public variable from Global.asax file

Hi all,

I am implementing log4net to log all errors on my application.

Now i want to be able to easily log from any page in may site. So I have create the following variable in my GLobal.asax file

<script runat="server">
    public static readonly log4net.ILog log = log4net.LogManager.GetLogger

Open in new window

Now when I try to use Global.log I am getting 'Global' does not exist in the current context?

any ideas why?
Who is Participating?
Miguel OzConnect With a Mentor Software EngineerCommented:
Is your application a web app or web site project?
For web app projects VS generates the code behind and a namespace (the default namespace in your project properties ->app tab) and kaufmed's explanation is correct for this case. You can access your variable as:
where WebApplication19 = default namespace.

Sadly for web site projects, you can not access global class like that, thus you need to create your own static class as you just did in your post (I will probably called SiteGlobal just to avoid any confusion with the global class)
please try only with static variable (no readonly)
Miguel OzConnect With a Mentor Software EngineerCommented:
Actually there is no need to do this. Just create a static global class with your logger property as per link below:
Get your problem seen by more experts

Be seen. Boost your question’s priority for more expert views and faster solutions

flynnyAuthor Commented:
thanks for the replies guys.

@jayakrishnabh - would Global still not be recognised in this case though?

@maz_oz2003 - ok so you are suggesting i create a class such as;

using System;
using System.Data;
using System.Linq;
using System.Web;

/// <summary>
/// Contains my site's global variables.
/// </summary>
public static class Global
    public static readonly log4net.ILog log = log4net.LogManager.GetLogger

Open in new window

obviously referencing the log4net dll, or would I still need to add get methods?
jayakrishnabhConnect With a Mentor Commented:
Hope your Global.asax file already contains Global class and this is where you are adding the public static variable inside that class. If yes, you can access that variable anywhere in the application using statement Global.VARIABLE_NAME. In this case you neednot create one more class for adding a variable which is already available with Global class. .Net allows this.  
But the suggested way would be not to alter global.asax and create a new static class for having the logger variable or its implementation.
käµfm³d 👽Connect With a Mentor Commented:
The problem is that you are not declaring the variable in code-behind, but rather in the markup file for Global.asax (note the <script> tag). Markup files in ASP.NET actually inherit from a class in the code-behind file:


<%@ Application Codebehind="Global.asax.cs" Inherits="WebApplication19.Global" Language="C#" %>

This means they are themselves classes. Basically, you are using the wrong class name to get to the variable. However, I don't think you can include any additional tags in the markup for Global.asax. So my question to you would be:  Why are you trying to declare the log4net stuff in the markup file as opposed to the code-behind file?


readonly has nothing to do with why you cannot access the variable.
flynnyAuthor Commented:
excellent thank you for all your help.
Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.

All Courses

From novice to tech pro — start learning today.