I've a working XML Web service written in ASP.Net. Now I need to reference certain assemblies lying in a specific folder e.g. c:\NotMyCode
I do not want to copy/duplicate zillions of dlls in that folder into my bin folder.
I tried to keep the CopyLocal=false
for the assemblies referred in the Web Service. That ended up in a FileNotFound exception for the assembly.
When I switch to CopyLocal=true
, the referenced DLLs are copied over to the bin folder.. and it works.
So my question here is:
How do I reference assemblies that do not lie in my bin folder or a subfolder beneath it ? Do I need to change some security policy files somewhere? I think I'm not the first person to ever want to do something like this.. so I'm assuming someone has already solved this problem.
(I've tried impersonating an admin user in the IIS ASP.net configuration panel, but that didnt work either.)
Update: Can't install it in the GAC either. To give an analogy, this web service is giving a simplified view to a third party app e.g. Starteam. I can't (shouldn't have to.. don't want to..) copy all the binaries in that folder to the bin folder or install it into the GAC
According to the MSDN documentation,
Referenced assemblies outside the application's root directory must have strong names and must either be installed in the global assembly cache or specified using the <codeBase>
element.
So, it might appear that you're out of luck. Here's what I'd try:
- Create an NTFS junction point under your application base directory which points to the directory containing your shared code. This is the key step. For example, in your application base directory, run
linkd SharedCode c:\NotMyCode
. This makes <yourappbase>\SharedCode
effectively be an alias for c:\NotMyCode
.
- Tell ASP.NET to probe for assemblies in this path, using a
<probing>
element, referencing the junction point SharedCode
. Since this is under your application base, it should work. Alternatively, use AppDomainSetup.PrivateBinPath to set the path probed for assemblies.
I'm quite curious to see if this works :-)
You could always use the:
AppDomain.CurrentDomain.AssemblyResolve Event
and call
Assemly.Load(Path.Combine(@"c:\NotMyStuff",args.Name.Substring(0, args.Name.IndexOf(",")) + ".dll"))
See link for more info.
You could always put your referenced assemblies in the GAC, then the location would not matter. You can install the component by dragging it into the GAC (C:\windows\assembly) or running GACUtil.exe.
This article may help. It describes the "Best Practices for Assembly Loading."
At first I thought you could used the <probing privatePath="bin\debug"/>
element in the runtime/assemblyBinding in the web.config, but the probing will only allow you to specify subdirectories under the root location.
I think you can reference specific assembly paths in code as well.
AppDomain.CurrentDomain.AppendPrivatePath("C:\\NotMyCode");
Doing that in your Global.asax Application_Start should do the trick.
You can put in GAC and access it from there.