Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Adding assembly reference within web.config

I have some general questions about web.config and how it works regarding assembly reference. I've been playing around with the new Razor view engine and had some trouble getting it up and running.

My problem started with a general

The type or namespace name 'XXXXX' does not exist in the namespace 'XXXXX' (are you missing an assembly reference?)

Now I figured this was just a simple Add Reference to the project and I'd be on my way. But even after I added a reference to the missing assembly, my project kept breaking.

I found the solution, and I had to add an assembly reference within the web.config. Once I did this everything worked fine.

First, I want to understand why it took adding a reference to web.config to fix this problem. Why wasn't a project reference just good enough?

Second, when it comes to adding references in web.config, I would like to understand the syntax. When I see markup like this

<add assembly="System.Web.WebPages" />

it seems very clear to me that I'm adding an assembly named System.Web.WebPages. But the full syntax in my web.config is

<add assembly="System.Web.WebPages, Version=1.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" />

Version seems self explanatory, but what is culture and PublicKeyToken used for? Are they required? What happens if I don't know either of them, can I just put anything in?

like image 885
Matt Avatar asked Jan 26 '11 16:01

Matt


People also ask

How do you add references to System Web?

After Googling around a little bit I found that the common answer to this question was to add a reference to System. Web. dll by finding it in the list presented by right-clicking on References in the Solution Explorer and clicking "Add Reference...".


2 Answers

Answering your first question:

There's another SO question here with a useful answer:

What is difference between web.config assemblies element and project file Reference element

Essentially it is to do with differences between Web Projects and non-web projects in Visual Studio (as I understand it).

Answering your second question:

This took quite a bit of digging around but here you go:

Culture - most assemblies should be culture neutral (assuming this is set in the application). However if you do have culture sensitive assemblies then this is where you specify the culture of the assembly.

PublicKeyToken - this is the public key from the public/private key pair that was used to sign the assembly. Having this enables .NET to verify that the assembly it is loading is the correct one.

More useful information here:

http://en.wikipedia.org/wiki/.NET_assembly

like image 126
Sam Huggill Avatar answered Sep 21 '22 18:09

Sam Huggill


An old question, already answered, but I came across it and wanted to add:

The importance of a Public Key Token is that it is absolutely required for a strongly-named assembly. In fact, that's how you get a PKT: Sign the assembly (generate a strong-name key). And you can't store an assembly in the GAC without signing it.

So it's more than just a matter of identifying the assembly... it's a cryptographic way for .NET to validate the signature of an assembly, and to ensure that it hasn't been tampered with.

like image 33
James King Avatar answered Sep 23 '22 18:09

James King