Search code examples
iiscachinghttp-headersiis-7.5etag

IIS 7.5 remove etag headers from response


I know this question has been asked alot of times, however most of them were in 2009-2010.

I am pretty sure a while back a project I was working on removed them, however I cannot find any way to remove them at the moment.

So has there been any advances in this field? It seems crazy that microsoft has made IIS to not be able to easily configure these headers.

Currently have tried:

  • Adding a blank etag header to the web.config
  • Adding an etag with quotes inside to the web.config
  • Adding a blank etag header directly through IIS
  • Adding a custom module which removes an etag on BeginResponse
  • Same as above but for EndResponse
  • Same as both above but instead of removing an etag, make it empty

I hear there is an ISAPI filter you can get to remove them, but I cannot find it anywhere, and have no experience in writing one from scratch but may end up being the only way to do it.

Just so there is some reason why I want to remove Etags for everything. I let the clients cache everything (expires & last-modified) so once my static files are gotten from the server it never needs to query the server again until it expires. As if you use Etags you still need to make a request to the server for each file to find out if the tag still matches. So using the client cache you only make requests for the content you need.

I also have a versioning system in place so when a change happens the static content is then referenced as my.js?12345 rather than my.js?12344. Anyway the point is I currently believe removing Etags will greatly improve one of the bottlenecks on my current project.


Solution

  • You can use the IIS Rewrite Module 2.0 to remove the ETag. The following rewrite rule should do it:

    <rewrite>
       <outboundRules>
          <rule name="Remove ETag">
             <match serverVariable="RESPONSE_ETag" pattern=".+" />
             <action type="Rewrite" value="" />
          </rule>
       </outboundRules>
    </rewrite>
    

    You can see an example image of the rule configuration in IIS Manager on my blog.