6

In my .net solution, I have two different projects: An MVC core web application project and a class library project. In web application project, database connection string is in appsettings.json file. I would like to access that connection string from class library project. Is it possible? If yes, how? If there is any better approach to get connection string, please let me know.

4
  • Are you running .Net Core? Your question doesn't seem to match the tags. Commented Apr 13, 2017 at 10:17
  • stackoverflow.com/questions/15174601/… make your connection string global by using DAL class Commented Apr 13, 2017 at 10:19
  • Yes I am. My web application is a MVC core application and my class library is a standard class library. Commented Apr 13, 2017 at 10:20
  • Why not use a function in your class library like getConnectionString() ? Commented Apr 13, 2017 at 11:17

2 Answers 2

3

To make simple and trivial example you could create a class in your class library that will represent singleton or ambient context to provide connection string:

public static class ConnectionString
{
    public static string Value {get; set;}
}

And then in you app Startup class you set it's value:

var builder = new ConfigurationBuilder()
...
var configuration = builder.Build();
ConnectionString.Value = configuration["connectionString"]; // Or how you do it in your code.

And then you will be able to use it in your class library.

In real-world applications it is better to inject either connection string or settings that exposes connection string via constructor using Dependency injection technics.

Sign up to request clarification or add additional context in comments.

1 Comment

@GhanshyamBaravaliya, sure the approach does not depend on a platform. But it makes the config ambient context which is considered an anti-pattern.
0

Don't worry when your class library is called from the Web application, the connection string will be retrieved from the Web application app settings file.

For more info, see Get connection String

Comments

Your Answer

By clicking “Post Your Answer”, you agree to our terms of service and acknowledge you have read our privacy policy.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.