Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 7921237
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: June 3, 20262026-06-03T16:30:37+00:00 2026-06-03T16:30:37+00:00

Ive built a plugin architecture in C#.NET that dynamically loads DLLs from a predefined

  • 0

Ive built a plugin architecture in C#.NET that dynamically loads DLLs from a predefined physical file path. I am aware of assemblies possibly existing in memory location in two locations thus making it unreliable to verify a member (interface) in the assembly using something like…

if(plugin is T)
    // cache the assembly

… so currently I am using the interface name to compare, then activating an instance from that. But, this has limitations too because the interface ‘IPlugin’ is a very common interface name which lots of third party assemblies use, (i.e. log4net, etc)

Take the following code (which is does not work):

foreach (Type t in assembly.GetTypes())
{
    type = t;

    if (!type.IsInterface)
    {
        var plugin = type.GetInterface(typeof(T).Name);

        if (plugin != null)
            if (plugin is T)
            {
                T p = (T)Activator.CreateInstance(type);

                if (!this.Plugins.Select(sp => sp.Name).Contains(p.Name))
                    this.Plugins.Add(p);
            }
    }
}

My question: What is the best (reliable) way to verify the dynamically loaded DLL matches the IPlugin interface?

One thought is to hard code the IPlugin’s public key token and verify that, but I am wondering if there is a more formal way. As an example, I can imagine a potential security hole with assemblies spoofing the IPlugin name, or public key token… so perhaps there is a good way to test that the DLL loaded matches the signature of the assembly loading it.

Please let me know if more clarity is required.

Very grateful!

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-06-03T16:30:39+00:00Added an answer on June 3, 2026 at 4:30 pm

    Use IsAssignableFrom:

    var yourIPlugin = typeof(IPlugin);
    foreach (Type t in assembly.GetTypes())
    {
        if (yourIPlugin.IsAssignableFrom(t))
        {
                T p = (T)Activator.CreateInstance(t);
                if (!this.Plugins.Select(sp => sp.Name).Contains(p.Name))
                    this.Plugins.Add(p);
        }
    }
    

    IsAssignableFrom uses a type to see if another type can be assigned from it. It takes fully into consideration the actual type, not just the name of the type. So even if your assembly, or other assemblies, contain types named IPlugin, only the one from yourIPlugin would be found.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I have a small template that ive built for the purpose of implementing an
I have a project (built from an AppFuse template) that requires Maven 2.2.1. So
Back in the day I built a twitter widget plugin that used the now-deprecated:
Simple question: see title. I'm using .NET 3.5. Elaboration: I'm building a plugin that
I've built a JQuery plugin that will apply to a page built in a
I've built a very basic jQuery plugin that essentially positions a sprite image left
I'm trying to call a system stored procedure in a plugin that I've built.
There exists an iframe plugin currently built into CKEditor that allows iframes to be
I've built a custom UI for my table that has a darker UI and
I've built a dedicated server applications that ships with the application. As of now

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.