We're going to build a simple web application where people can manage products they want to sell.
- Everyone can browse existing products.
- Only authenticated users can add new products.
- Only a product owner can edit or delete a product.
We are going to build 3 projects. The FrontEnd project will be a Progressive Web Application built using Vuejs, Vue Router and Vuetify, while server side we are going to build two .NET Core 3.0 Web Applications using Visual Studio 2019: one will expose a REST API while the second will take care of Authentication, using Identity Server 4.
- FrontEnd Client
- Javascript (ECMAScript 2015+)
- HTML 5
- CSS 3
- Vue.js 2
- Vue Router
- Vuetify
- Open Id Connect Client
- Fetch API
- Native Camera API
This project will interact with the user through a browser by dinamically constructing an HTML user interface and will talk to the server by using javascript and json.
- REST Service
- .NET Core 3.0 Web API Controller
- Entity Framework Core 3.0
- Sql Server Database
- Identity Server Client Authentication
This project will be responsible to store the data on the server and respond to the client requests through http and json.
- Authentication Server
- Identity Server 4
- Entity Framework Core
This project will take care of the authentication part. It will issue JWT tokens that will be used by the client application to gain access to the server.
- C#
- Javascript (ECMAScript 2015+)
- HTML 5
- CSS 3
- What is REST
- What is .NET Core
- ASP.NET Core
- What is a Web API Controller
- Kestrel
- Middleware
- Environment variables
- ASP.NET Core Configuration
- Dependency Injection
- Entity Framework Core
- PostMan
- CORS
- Vue.js
- Vue Router
- Fetch API
- WebPack
- Vuetify
- Authentication and Authorization
- OAuth 2 and Open Id Connect
- Identity Server 4
- Resource Owner Authorization
Make sure you installed the workload ".NET Core cross-platform development". You can check and install workloads by launching the Visual Studio Installer.
Please see https://www.microsoft.com/net/download/windows
We are going to split our projects into simple steps. Each step will focus on one task and will build on top of the previous step. We will start with simple projects that will become more and more complex along the way. For example, we will not focus on authentication and authorization at first. We will add it at a later step.
This folder contains different subfolder. Each subfolder represents a phase in our project. "Start" folders are the starting points of each step. "Solution" folders are the final versions of each step, given to you just in case you want to check what your project is supposed to become at the end of each lab.
What you have to do is to open a start folder corresponding to the lab you want to try (for example Lab01/Start
in order to begin) and follow the instructions you find on the readme.md
file. When you are done, feel free to compare your work with the solution provided in the Solution folder.
- Open the Labs folder
- Navigate to the Lab01 subfolder
- Navigate to the Start subfolder
- Follow the instructions contained in the readme.md file to continue
- Open
Lab08\Solution\MarketPlace\IdentityServer\IdentityServer.sln
in Visual Studio - Build the project but do not start it from Visual Studio
- Open a command prompt under the
Lab08\Solution\MarketPlace\IdentityServer
folder - Type
dotnet run /seed
- Navigate to
http://localhost:5002
and ensure that the project is up and running
- Open
Lab08\Solution\MarketPlace\Marketplace\MarketPlace.sln
in Visual Studio - Build the project and start it from Visual Studio
- Open
Lab08\Solution\MarketPlace\spaclient
in Visual Studio Code - Open a terminal window
- Type
npm install
- Type
npm run serve
- Username: alice
- Password: Pass123$