Search code examples
c#.netasp.net-mvc-3shared-librariesclass-library

What is an easily maintainable way to share a common .net class library over many corporate asp.net mvc 3 web applications?


I've been struggling to do this in a way that fulfills all of my requirements.

Here is what we have in our library:

  • Base classes for controllers and services
  • Business objects (stores, departments, etc)
  • Common Partial Views (Login, Error, etc)
  • Base class for HttpApplication
  • General common code (read an INI file, create a db conn, etc)

The one requirement that has been giving me trouble is as follows:

  • Lives in one place on a server. (i.e. copy local = false)

This breaks because:

  • The DLL containing the HttpApplication class must be in the same directory as the web apps dll to launch. I haven't found a way around that. I'm ok with duplicating this code in every app, but would rather not.
  • The shared views don't like to work if I use Assembly.LoadFrom() to load the dll from the shared location. (I've been using this method to precompile my views)
  • Any namespace shortcuts in web.config break at runtime with compilation errors because the web.config is parsed before the assembly is loaded.

My question to you folks is how do you handle your common code in a similar environment?

The GAC seems to be more trouble than its worth, and we want all of our apps to be using the same code, and not have multiple apps on multiple versions and have to maintain all of that. Are there design patters/best practices that can guide us in this regard?

Also, as a bonus, if you can solve any of the problems above, that would be great, too.

Thanks!

Edit: I guess a question that follows is whether or not we should even have a directory with the common dll(s) on the server, or if they should only be deployed as projects are deployed/updated?


Solution

  • Firstly, you will want to separate out what you're trying to achieve. Don't create 1 library that does everything or you will have a Big Ball of Mud. Don't be afraid to create several maintainable libraries to achieve what you're after. Is there a specific reason it needs to be stored in one location?

    For example, several of the items you mention are MVC or web specific. If you have items that can be reused by MVC, create a class library that contains MVC base classes you inherit and reference them in your project. Use the single responsibility principle as much as possible.

    Regarding the other items you mentioned, like database connectivity, if it's reusable, abstract it out in a data access class library and reference it. Other simple operations like reading an ini file or creating a file, create another library and abstract it to easy to use methods.

    I prefer to copy the library dlls locally. You never know when you will need to make changes to the library, but you don't want all of your projects to stop compiling. When you're ready to implement a new version of the library, copy the dll in and recompile.