Skip to content
An addictive .NET IoC container
Branch: develop
Clone or download
Type Name Latest commit message Commit time
Failed to load latest commit information.
bench/Autofac.Benchmarks Updated test framework packages. Apr 19, 2019
build Update to use Unicode copyright symbol Apr 9, 2019
src/Autofac Updated analyzer packages and resolved new analysis issues. Apr 19, 2019
test Centralized concurrency tests. Apr 19, 2019
.editorconfig Sorted/tidied JSON files for easier diff across files and conflict re… Jun 7, 2016
.gitattributes Brought over scripts for k build. Feb 4, 2015
.gitignore Ignoring local benchmark results. Feb 8, 2017
.mailmap Mailmap update for Ivan Feric Jun 2, 2014
Autofac.sln Started splitting tests up between API/Spec and internals/unit. Mar 8, 2019
Autofac.snk Updated all URLs to https where possible (headers, packages, docs). Dec 13, 2018
build.ps1 Merge branch 'develop' into decorators May 23, 2018
global.json Update .NET Core SDK to 2.2.101. Jan 13, 2019


Autofac is an IoC container for Microsoft .NET. It manages the dependencies between classes so that applications stay easy to change as they grow in size and complexity. This is achieved by treating regular .NET classes as components.

Build status MyGet publish status Autofac on Stack Overflow Join the chat at NuGet

Get Packages

You can get Autofac by grabbing the latest NuGet packages. If you're feeling adventurous, continuous integration builds are on MyGet.

Release notes are available on the wiki.

Get Help

Need help with Autofac? We have a documentation site as well as API documentation. We're ready to answer your questions on Stack Overflow or check out the discussion forum.

Get Started

Our Getting Started tutorial walks you through integrating Autofac with a simple application and gives you some starting points for learning more.

Super-duper quick start:

Register components with a ContainerBuilder and then build the component container.

var builder = new ContainerBuilder();

builder.Register(c => new TaskController(c.Resolve<ITaskRepository>()));
builder.RegisterInstance(new TaskController());

var container = builder.Build();

Resolve services from a lifetime scope - either the container or a nested scope:

var taskController = container.Resolve<TaskController>();

There is a growing number of application integration libraries that make using Autofac with your application a snap. Support for several popular frameworks is also available through the "Extras" packages.

Intrigued? Check out our Getting Started walkthrough!


Autofac is licensed under the MIT license, so you can comfortably use it in commercial applications (we still love contributions though).

File issues in the repo with the associated feature/code.

Contributing / Pull Requests

Refer to the Contributor Guide for setting up and building Autofac source.

You can’t perform that action at this time.