This repository is to build a complete solution template for ASP.NET MVC, so that you can quickly finish the architecture of an ASP.NET MVC website.
- Download all the source code and open the solution file(.sln) in Visual Studio.
- On the Visual Studio menu bar, click "File" > "Export Template", and then export EVERY project in this solution to a template.
- Close the solution.
- Create your website from the exported templates. In Visual Studio, "File" > "New" > "Project", you will the exported templates. If you cannot see, you can search "MvcSolution." on the top-right search box. You don't have to create projects for "Admin" or "Api" if your website doesn't include them, but you should create projects for other templates.
- Fix DLL references. Copy the "Libs" folder from the downloaded source code to your newly created solution (remember to match the relative path).
- Replace text "MvcSolution" to yours. In the new whole solution, relace "MvcSolution" to {YourSolution} (tick match case). Other possible relaces may be "mvcsolution", "mvcSolution", "MVCSolution", etc.
- Rename files. Replace file names "MvcSolution" with {YourSolution}.
- Build the new solution and fix errors. Try running.
There are mainly 4 layers: infrastructure, data, services, web. It's easy to understand, isn't it?
This is foundation project of the solution, and it should be referenced by all other projects.
It contains extenstions to .NET Framework, MVC, third party libraries and some helper methods. A few other features are included by default, such as IOC, Logging, Captcha.
This project uses Entity Framework Code First mode to achieve data access. It defines the database and tables(entities). This project should also contain the minimum unit of business logic. In our practices, we put the logics to entity definitions, and IQueryable extensions.
This layer is used to access the database and return results to the Web layer. Any database access should stop at the services layer, which means the Web layer must use services to do data access.
The DbContext instances should be disposed in every service methods.
This layer handle user requests and renders the data in front of the end users.
In this template solution, there are projects in the Web layer. They are:
- MvcSolution.Web: shared project among child websites (if any). You can it WebBase project.
- MvcSolution.Web.Main: the real website that contains global.asax (defining application entrance) and web.config.
- MvcSolution.Web.Admin: actually an MVC area for admin. It’s useful to plug in an area to your website without influencing the existing website.
- MvcSolution.Web.Api: an MVC area for API access.
We used NDB unit test for this solution. It’s useful to test your data access code in a real database.
There are actually two projects in the UnitTests solution folder.
The main unit test architecture, and your every other unit test project should reference it.
I plan to write a separate wiki page to document how to use it, but for now you can refer to the MVCSolution.UnitTests.Services project.
A sample unit test project demonstrating how to use MvcSolution.UnitTestBase.
Grunt is used for professional websites. I don’t recommend you use it if your project doesn’t have too many users.
Please refer to Gruntfile.js to see how grunt is gracefully configured.