To follow this tutorial, you will need the following:
- .NET SDK 8 installed on your machine
- Basic knowledge of .NET, ASP.NET Core and C#
- An IDE or text editor; we’ll use Visual Studio 2022 for this tutorial, but a lightweight IDE such as Visual Studio Code will work just as well
Overview
To allow files to be uploaded, you will:
- Create ASP.NET Core Razor views that allow the user to select a file to upload
- Create ASP.NET Core controllers to work with uploaded files
Of course, you will also want to do something with each uploaded file! In this tutorial, we’re going to write C# code to show information about the file, and also to scan it for malware using Verisys Antivirus API.
Verisys Antivirus API is a language-agnostic REST API that allows you to easily add malware scanning to mobile apps, web apps and backend processing.
By scanning user-generated content and file uploads, Verisys Antivirus API can stop dangerous malware at the edge, before it reaches your servers, applications - or end users.
Project Setup
First, we need to create a new ASP.NET Core MVC project.
Prefer the command line? You can create a new project simply by running:
|
|
-
Start Visual Studio and select File > New > Project
-
Select the template named ASP.NET Core Web App (Model-View-Controller) and click Next
data:image/s3,"s3://crabby-images/4ec35/4ec356f156bd4063f30c04fea0dfe25d1f2e3f64" alt="Visual Studio project template selection"
- Enter Web for the Project Name, choose a location to save the project, then click Next
data:image/s3,"s3://crabby-images/27c22/27c22ae29d83684bd43a94a32337d426ef759e16" alt="Visual Studio project name"
- For the Framework, select .NET 8.0 (Long Term Support), then click Create
data:image/s3,"s3://crabby-images/15ad1/15ad1a162f73072aa5d0314e215112347367f916" alt="Visual Studio project SDK"
- The new project will be created, and you should see this folder structure in Visual Studio’s Solution Explorer:
data:image/s3,"s3://crabby-images/47dce/47dcedafb0b90f8bd4bca1c14efbdd2b103ac388" alt="Folder structure visible in Solution Explorer"
Running the App
Now we’ve created a new project, let’s make sure it runs!
- Press CTRL+F5, or click the Start Without Debugging button:
data:image/s3,"s3://crabby-images/37a76/37a76a045fd2af5f8943989ecaad49f7be2c165a" alt="Start without debugging"
- The first time you run the project, you will be asked to install an SSL/TLS certificate - click Yes on both popups:
data:image/s3,"s3://crabby-images/7f271/7f271f6ff51ff1ceff97f0824a1535099386f5f4" alt="Installation of SSL/TLS certificate"
data:image/s3,"s3://crabby-images/677f3/677f363ab66f6557123efaddc493df058e46692f" alt="Installation of SSL/TLS certificate"
- Visual Studio will then run the app, opening it in the default browser:
data:image/s3,"s3://crabby-images/71374/713746c6671d8e6c34fbc5b0f72c28982662b0e2" alt="ASP.NET Core web app running in a browser"
- While running your project, Visual Studio will open a terminal as well as the browser - this is for the default web server, Kestrel. If you press
CTRL-C
, it will shut down the web server and stop running your project.
data:image/s3,"s3://crabby-images/67ee3/67ee3c5421cf94ca83b5b99582ddaec106fa9e49" alt="Terminal output"
File Upload
To enable file uploads, we need to add:
- View models, to encapsulate information about uploaded files
- A view with a form that allows users to select and upload a file
- A view to show information about the uploaded file
- A controller, to show the views and handle the uploaded file
- We’ll also update the main layout view, just to add links to our new pages
Let’s get started!
- First, create file
Models/FileModels.cs
, with content:
|
|
- Next, create a folder
Views/Upload
, and inside a view fileViews/Upload/Index.cshtml
with content:
|
|
Note the form’s encoding type (enctype
) property is set to multipart/form-data
- this is required for uploading files.
- Next, create view file
Views/Upload/Result.cshtml
with content:
|
|
- Create a controller file
Controllers/UploadController.cs
with content:
|
|
- Finally, update the content of
Views/Shared/_Layout.cshtml
to add links to our new pages:
|
|
It really is that simple!
Testing File Uploads
Now weโre ready to test file uploads! ๐
-
Begin by running the project again, either by pressing CTRL+F5, or by click the Start Without Debugging button
-
Your browser should open automatically, showing a page that looks like this:
data:image/s3,"s3://crabby-images/a70d6/a70d6feb64441ba14ec7bae06510cc4a81742606" alt="ASP.NET Core web app running in a browser"
- Click the link Upload File, and you should see one of the new views we created:
data:image/s3,"s3://crabby-images/dcac4/dcac476336bbd56257ff6a3aaab6c33eb16d7c8b" alt="Upload file form"
-
Press Choose File to select a file to upload, then and press the Upload File button
-
If everything was set up correctly, you should see information about the file being shown in a web page:
data:image/s3,"s3://crabby-images/1fdfc/1fdfc3541003a1904811244769b59ae6000be195" alt="Successful file upload"
Note that the Malware Status is shown as Unknown - we’ll fix that in the next section.
Malware Scanning
Now we’re going to use Verisys Antivirus API to scan uploaded files for malware. Following a similar pattern as for the previous section, we need to add:
- Registration of an HTTP client with the Dependency Injection (DI) container
- A view with a form that allows users to select and upload a file for scanning
- A view to show the results of the malware scan
- A controller, to show the views and send the uploaded file to Verisys Antivirus API
Let’s get started!
- In file
Program.cs
, replace linebuilder.Services.AddControllersWithViews();
with:
|
|
X-API-Key
in the above code will need to be replaced with a real API key to scan files for real. Don’t have an API key? Subscribe now!- Create a folder
Views/Scan
, and inside a view fileViews/Scan/Index.cshtml
with content:
|
|
- Next, create view file
Views/Scan/Result.cshtml
with content:
|
|
- Finally, create a controller file
Controllers/ScanController.cs
with content:
|
|
Testing Malware Scanning
Now weโre ready to test malware scanning! ๐
-
Begin by running the project again, either by pressing CTRL+F5, or by click the Start Without Debugging button
-
Your browser should open automatically, showing a page that looks like this:
data:image/s3,"s3://crabby-images/a70d6/a70d6feb64441ba14ec7bae06510cc4a81742606" alt="ASP.NET Core web app running in a browser"
- Click the link Scan File, and you should see one of the new views we created:
data:image/s3,"s3://crabby-images/1e15a/1e15afc3c3077d03255381ca5b62d71b084093b1" alt="Scan file form"
-
Press Choose File to select a file to upload, then and press the Upload File button
-
If everything was set up correctly, you should see malware scan results from Verisys Antivirus API being shown in a web page:
data:image/s3,"s3://crabby-images/fa21a/fa21a0acf6f4ff4f4fc721c8662525e7fa39d6fd" alt="Scan result of a clean, virus-free file"
data:image/s3,"s3://crabby-images/1e159/1e159d6ab5de04e6f38683368ddb1bdca4e45906" alt="Scan result of an infected file"