Skip to main content

How to Automatically change the version of css and js files in Asp.Net | C#.Net



Introduction:
In my previous article I have explained about how to get all files in a directory using C#.Net and Asp.Net. In this article I am going to explain about how to automatically update the version of css and js when file gets changed.

Explanation:
When you update JavaScript or CSS files that are already cached in users' browsers, most likely many users won’t get that for some time because of the caching at the browser. You need some way to force browser to download the latest files. There’s no way to do that effectively across all browsers unless you change the file name or you change the URL of the files by introducing some unique query string. Most web developers use the query string approach and use a version suffix to send the new file to the browser. For example:
<script type="text/javascript" src="js/jquery-1.4.1.min.js?v=1" ></script>
<script type="text/javascript" src="js/myscript.js?v=1" ></script>
<link rel="stylesheet" type="text/css" href="css/style.css?v=1"/>
In order to do this, developers have to go to all the pages and then increase the version number. If you forget to do this on some page, that page may break because browser uses old cached script. To avoid this we should change the css and js version automatically whenever changes occur.
To achieve this  include Update.cs in App_Code and Include the below code in Global.asax file.
protected void Application_BeginRequest(object sender, EventArgs e)
{
    if (Request.IsLocal)
        System.Threading.Thread.Sleep(50);
    var request = Request;
    var url = request.Url;
    var applicationPath = request.ApplicationPath;
    string fullurl = url.ToString();
    string baseUrl = url.Scheme + "://" + url.Authority + applicationPath.TrimEnd('/') + '/';
    string currentRelativePath = request.AppRelativeCurrentExecutionFilePath;
    if (request.HttpMethod == "GET")
    {
        if (currentRelativePath.EndsWith(".aspx"))
        {
            var folderPath = currentRelativePath.Substring(2, currentRelativePath.LastIndexOf('/') - 1);
            Response.Filter = new Dotnetpickles.Update(
                    Response,
                    relativePath =>
                    {
                        if (Context.Cache[relativePath] == null)
                        {
                            try
                            {
                                var physicalPath = Server.MapPath(relativePath);
                                var version = "?v=" +
                                    new System.IO.FileInfo(physicalPath).LastWriteTime
                                    .ToString("yyyyMMddhhmmss");
                                Context.Cache.Add(relativePath, version, null,
                                    DateTime.Now.AddMinutes(1), TimeSpan.Zero,
                                    CacheItemPriority.Normal, null);
                                return version;
                            }
                            catch
                            {
                                return "";
                            }

                        }
                        else
                        {
                            return Context.Cache[relativePath] as string;
                        }
                    },
                    "",
                    "",
                    "",
                    baseUrl,
                    applicationPath,
                    folderPath);
        }
        else
        {

        }
    }
}

The code will get the last modified date of the css and js file and add it as a version of the file. So every time you update the file automatically version will get updated. If you view the source of the page you can better understand it. Below is the screenshot of the output.


Do you like this article? Help us to improve. Please post your comments below.

Download Source Code:



Comments

  1. It is good solution but not working properly. I have used the same code as given above but some where it gets break the code and append version info in the type attribute of link and also add version info to the type attribute of hidden element that should not happen.

    Please help me to resolve this issue.

    Thanks

    ReplyDelete

Post a Comment

Popular posts from this blog

Code To Convert rupees(numbers) into words using C#.Net

Introduction: In my previous article I have explained about how to validate emailid using javascript . In this article I am going to explain about code used to convert rupees(numbers) into words using C#.Net . Explanation: For explanation purpose I have a page. It has a textbox to input the numbers. And when you click on the convert to words button then it will convert the input numbers into words and shows it in the below label. Below is the C# code used to do this functionality. public static string NumbersToWords( int inputNumber) {     int inputNo = inputNumber;     if (inputNo == 0)         return "Zero" ;     int [] numbers = new int [4];     int first = 0;     int u, h, t;     System.Text. StringBuilder sb = new System.Text. StringBuilder ();     if (inputNo < 0)     {         sb.Append( "Minus " );         inputNo = -inputNo;     }     string [] words0 = { "" , "One " ,

C# code to send mail using smtp from gmail,yahoo mail and live mail

Introduction: In my previous article I have explained about   How to bind/Unbind events in jQuery . In this article I am going to explain about how to send mail from ASP.Net using gmail,yahoomail and live mail credentials. Explanation: First Include the below namespaces in your code behind file. using System; using System.Net; using System.Net.Mail;

Geckofx Browser in Winform Application

Bored with IE browser in your winform application ? Want to do everything as you doing in your Firefox or Chrome Browser ? Play with automation ? Then here is your choice . Introduction:  GeckoFX is a Windows Forms control written in clean, commented C# that embeds the Mozilla Gecko browser control in any Windows Forms Application. It also contains a simple class model providing access to the HTML and CSS DOM . GeckoFX was originally created by Andrew Young for the fast-growing visual CSS editor, Stylizer . It is now released as open-source under the Mozilla Public License.  You can download it here :   Geckofx 22.0 And the supporting file Xulrunner here :   Xulrunner Files Hope you have downloaded above two files. Here our journey going to start. Create your winform application in visual studio and do the following: right click the toolbox -> Choose items -> Browse the "Geckofx-winforms.dll" and click "yes" for “Load it anyw