.NET开发基础知识1-10

1. 依赖注入(Dependency Injection)

  • 技术知识:依赖注入是一种设计模式,它允许将对象的依赖关系从对象本身中分离出来,通过构造函数、属性或方法参数等方式注入到对象中。这样可以提高代码的可测试性、可维护性和可扩展性。
  • 案例:在一个简单的后台管理系统中,有一个用户服务接口 IUserService 和其实现类 UserService。通过依赖注入,我们可以将 UserService 注入到控制器中。

    dotnet-core-dependency-injection.NET Core 依赖注入示例

    生成 Program.cs

using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting;// 定义用户服务接口
public interface IUserService
{string GetUserName();
}// 实现用户服务接口
public class UserService : IUserService
{public string GetUserName(){return "John Doe";}
}// 定义用户控制器
public class UserController
{private readonly IUserService _userService;public UserController(IUserService userService){_userService = userService;}public string GetUser(){return _userService.GetUserName();}
}var builder = WebApplication.CreateBuilder(args);// 注册服务
builder.Services.AddScoped<IUserService, UserService>();var app = builder.Build();app.Run(async context =>
{var serviceProvider = app.Services;var userController = serviceProvider.GetRequiredService<UserController>();var userName = userController.GetUser();await context.Response.WriteAsync($"User Name: {userName}");
});app.Run();

2. 中间件(Middleware)

  • 技术知识:中间件是处理 HTTP 请求和响应的组件,它们按顺序依次执行,可以对请求进行预处理,也可以对响应进行后处理。
  • 案例:创建一个简单的日志中间件,记录每个请求的信息。
using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
using Microsoft.Extensions.Hosting;
using System;
using System.Threading.Tasks;// 定义日志中间件
public class LoggingMiddleware
{private readonly RequestDelegate _next;public LoggingMiddleware(RequestDelegate next){_next = next;}public async Task InvokeAsync(Microsoft.AspNetCore.Http.HttpContext context){Console.WriteLine($"Request received at {DateTime.Now}: {context.Request.Path}");await _next(context);Console.WriteLine($"Response sent at {DateTime.Now}");}
}var builder = WebApplication.CreateBuilder(args);
var app = builder.Build();// 使用日志中间件
app.UseMiddleware<LoggingMiddleware>();app.Run(async context =>
{await context.Response.WriteAsync("Hello, World!");
});app.Run();

3. 路由(Routing)

  • 技术知识:路由是将 HTTP 请求映射到相应的处理程序(如控制器的动作方法)的过程。
  • 案例:创建一个简单的控制器,并使用路由来处理不同的请求。
using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
using Microsoft.AspNetCore.Mvc;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting;// 定义控制器
[ApiController]
[Route("[controller]")]
public class WeatherForecastController : ControllerBase
{[HttpGet]public IActionResult Get(){return Ok("This is a weather forecast.");}
}var builder = WebApplication.CreateBuilder(args);
builder.Services.AddControllers();var app = builder.Build();app.UseRouting();app.UseEndpoints(endpoints =>
{endpoints.MapControllers();
});app.Run();

4. 实体框架核心(Entity Framework Core)

  • 技术知识:Entity Framework Core 是一个跨平台的对象关系映射(ORM)框架,它允许开发人员使用面向对象的方式操作数据库。
  • 案例:创建一个简单的数据库上下文和实体类,并进行数据的增删改查操作。
using Microsoft.EntityFrameworkCore;
using System;
using System.Collections.Generic;
using System.Linq;// 定义实体类
public class Blog
{public int BlogId { get; set; }public string Url { get; set; }public List<Post> Posts { get; } = new List<Post>();
}public class Post
{public int PostId { get; set; }public string Title { get; set; }public string Content { get; set; }public int BlogId { get; set; }public Blog Blog { get; set; }
}// 定义数据库上下文
public class BloggingContext : DbContext
{public DbSet<Blog> Blogs { get; set; }public DbSet<Post> Posts { get; set; }protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder){optionsBuilder.UseSqlServer(@"Server=(localdb)\mssqllocaldb;Database=Blogging;Trusted_Connection=True;");}
}class Program
{static void Main(){using (var db = new BloggingContext()){// 添加博客db.Blogs.Add(new Blog { Url = "http://blogs.msdn.com/adonet" });var count = db.SaveChanges();Console.WriteLine("{0} records saved to database", count);// 查询博客var blogs = db.Blogs.OrderBy(b => b.Url).ToList();foreach (var blog in blogs){Console.WriteLine("Blog: {0}", blog.Url);}}}
}

5. 认证和授权(Authentication and Authorization)

  • 技术知识:认证是验证用户身份的过程,授权是确定用户是否有权限访问特定资源的过程。
  • 案例:使用 JWT(JSON Web Token)进行认证和授权。
using Microsoft.AspNetCore.Authentication.JwtBearer;
using Microsoft.AspNetCore.Authorization;
using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting;
using Microsoft.IdentityModel.Tokens;
using System.Text;var builder = WebApplication.CreateBuilder(args);// 添加 JWT 认证服务
builder.Services.AddAuthentication(JwtBearerDefaults.AuthenticationScheme).AddJwtBearer(options =>{options.TokenValidationParameters = new TokenValidationParameters{ValidateIssuer = true,ValidateAudience = true,ValidateLifetime = true,ValidateIssuerSigningKey = true,ValidIssuer = "YourIssuer",ValidAudience = "YourAudience",IssuerSigningKey = new SymmetricSecurityKey(Encoding.UTF8.GetBytes("YourSecretKey"))};});// 添加授权服务
builder.Services.AddAuthorization(options =>
{options.FallbackPolicy = new AuthorizationPolicyBuilder().RequireAuthenticatedUser().Build();
});builder.Services.AddControllers();var app = builder.Build();app.UseAuthentication();
app.UseAuthorization();app.MapControllers();app.Run();

6. 配置管理(Configuration Management)

  • 技术知识:配置管理允许将应用程序的配置信息(如数据库连接字符串、API 密钥等)与代码分离,方便在不同环境中进行配置。

  • 案例:使用 appsettings.json 文件进行配置管理。

Program.cs

using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting;var builder = WebApplication.CreateBuilder(args);// 读取配置文件
var configuration = builder.Configuration;
var connectionString = configuration.GetConnectionString("DefaultConnection");// 可以使用 connectionString 进行数据库连接等操作var app = builder.Build();app.Run(async context =>
{await context.Response.WriteAsync($"Connection String: {connectionString}");
});app.Run();

appsettings.json

{"ConnectionStrings": {"DefaultConnection": "Server=(localdb)\\mssqllocaldb;Database=MyDatabase;Trusted_Connection=True;"},"Logging": {"LogLevel": {"Default": "Information","Microsoft.AspNetCore": "Warning"}},"AllowedHosts": "*"
}

7. 日志记录(Logging)

  • 技术知识:日志记录是记录应用程序运行时信息的过程,有助于调试和监控应用程序。
  • 案例:使用内置的日志记录器记录信息。
using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting;
using Microsoft.Extensions.Logging;var builder = WebApplication.CreateBuilder(args);// 添加日志服务
builder.Logging.AddConsole();var app = builder.Build();var logger = app.Services.GetRequiredService<ILogger<Program>>();
logger.LogInformation("Application started.");app.Run(async context =>
{logger.LogInformation("Request received.");await context.Response.WriteAsync("Hello, World!");logger.LogInformation("Response sent.");
});app.Run();

8. 异步编程(Asynchronous Programming)

  • 技术知识:异步编程允许应用程序在执行耗时操作(如数据库查询、网络请求等)时不阻塞线程,提高应用程序的性能和响应能力。
  • 案例:使用 async 和 await 关键字进行异步数据库查询。
using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting;
using Microsoft.Extensions.Logging;var builder = WebApplication.CreateBuilder(args);// 添加日志服务
builder.Logging.AddConsole();var app = builder.Build();var logger = app.Services.GetRequiredService<ILogger<Program>>();
logger.LogInformation("Application started.");app.Run(async context =>
{logger.LogInformation("Request received.");await context.Response.WriteAsync("Hello, World!");logger.LogInformation("Response sent.");
});app.Run();

9. 单元测试(Unit Testing)

  • 技术知识:单元测试是对应用程序中的最小可测试单元(如方法、类等)进行测试的过程,有助于确保代码的正确性和可维护性。
  • 案例:使用 xUnit 框架对一个简单的服务进行单元测试。
using Xunit;// 定义一个简单的服务
public class CalculatorService
{public int Add(int a, int b){return a + b;}
}public class CalculatorServiceTests
{[Fact]public void Add_TwoNumbers_ReturnsSum(){// Arrangevar calculator = new CalculatorService();int a = 2;int b = 3;// Actint result = calculator.Add(a, b);// AssertAssert.Equal(5, result);}
}

10. Web API 开发

  • 技术知识:Web API 是一种允许不同应用程序之间进行通信的接口,通常使用 HTTP 协议进行数据传输。
  • 案例:创建一个简单的 Web API 控制器,提供数据查询和添加功能。
using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
using Microsoft.AspNetCore.Mvc;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting;
using System.Collections.Generic;// 定义数据模型
public class Product
{public int Id { get; set; }public string Name { get; set; }
}// 定义控制器
[ApiController]
[Route("api/[controller]")]
public class ProductsController : ControllerBase
{private static List<Product> _products = new List<Product>();[HttpGet]public IActionResult Get(){return Ok(_products);}[HttpPost]public IActionResult Post([FromBody] Product product){_products.Add(product);return CreatedAtAction(nameof(Get), new { id = product.Id }, product);}
}var builder = WebApplication.CreateBuilder(args);
builder.Services.AddControllers();var app = builder.Build();app.UseRouting();app.UseEndpoints(endpoints =>
{endpoints.MapControllers();
});app.Run();

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/74976.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

每日一题 MySQL基础知识----(三)

数据库常用基础知识&#xff1a;代码讲解和实验 1.创建数据库student 02&#xff0c;创建一个名为student02的数据库 CREATE DATABASE student02; 2.在student02中创建一张 students表&#xff0c;并且具有学生的编号id&#xff0c;姓名name&#xff0c;年龄age&#xff0c;生…

MySQL多表查询实验

1.数据准备 -- 以下语句用于创建 students 表&#xff0c;该表存储学生的基本信息 -- 定义表名为 students CREATE TABLE students (-- 定义学生的唯一标识符&#xff0c;类型为整数&#xff0c;作为主键&#xff0c;且支持自动递增student_id INT PRIMARY KEY AUTO_INCREMENT…

windows第二十章 单文档应用程序

文章目录 单文档定义新建一个单文档应用程序单文档应用程序组成&#xff1a;APP应用程序类框架类&#xff08;窗口类&#xff09;视图类&#xff08;窗口类&#xff0c;属于框架的子窗口&#xff09;文档类&#xff08;对数据进行保存读取操作&#xff09; 直接用向导创建单文档…

C++ 初阶总复习 (16~30)

C 初阶总复习 &#xff08;16~30&#xff09; 目的16. 2009. volatile关键字的作用17. 2010.什么是多态 简单介绍下C的多态18. 2011. 什么是虚函数 介绍下C中虚函数的原理19. 2012 构造函数可以是虚函数嘛20. 2013.析构函数一定要是虚函数嘛&#xff1f;21. 2015. 什么是C中的虚…

第一天 Linux驱动程序简介

目录 一、驱动的作用 二、裸机驱动 VS linux驱动 1、裸机驱动 2、linux驱动 三、linux驱动位于哪里&#xff1f; 四、应用编程 VS 内核编程 1、共同点 2、不同点 五、linux驱动分类 1、字符设备 2、块设备 3、网络设备 六、Linux驱动学习难点与误区 1、学习难点 …

PaddleX产线集成功能的使用整理

一、环境搭建 1.1 安装paddle-gpu 需要根据安装机器的cuda的版本&#xff0c;选择合适的版本进行安装 #安装paddle-gpu 官网链接 https://www.paddlepaddle.org.cn/install/quick?docurl/documentation/docs/zh/install/pip/linux-pip.html python -m pip install paddle…

docker-compese 启动mysql8.0.36与phpmyadmin,并使用web连接数据库

1、找一个文件夹&#xff0c;比如 E:\zqy\file\mysql&#xff0c;cd到这个目录下创建文件docker-compose.yml 2、将下面的代码块复制到docker-compose.yml文件中 version: 3.3 services:mysql:image: mysql:8.0.36container_name: mysqlrestart: alwaysports:- 3306:3306netw…

解决 Gradle 构建错误:Could not get unknown property ‘withoutJclOverSlf4J’

解决 Gradle 构建错误&#xff1a;Could not get unknown property ‘withoutJclOverSlf4J’ 在构建 Spring 源码或其他基于 Gradle 的项目时&#xff0c;可能会遇到如下错误&#xff1a; Could not get unknown property withoutJclOverSlf4J for object of type org.gradle…

mcp 接freecad画齿轮

from mcp.server.fastmcp import FastMCP import freecad.gears.commands import os from freecad import app from freecad import part mcp FastMCP("Demo")mcp.tool() def create_gear(num_teeth20,height10,double_helix True):"""创建一个渐开线…

【大前端系列19】JavaScript核心:Promise异步编程与async/await实践

JavaScript核心&#xff1a;Promise异步编程与async/await实践 系列: 「全栈进化&#xff1a;大前端开发完全指南」系列第19篇 核心: 深入理解Promise机制与async/await语法&#xff0c;掌握现代异步编程技术 &#x1f4cc; 引言 在JavaScript的世界中&#xff0c;异步编程是无…

如何排查java程序的宕机和oom?如何解决宕机和oom?

排查oom 用jmap生成我们的堆空间的快照Heap Dump&#xff08;堆转储文件&#xff09;&#xff0c;来分析我们的内存占用 用可视化工具&#xff0c;例如java中的jhat分析Heap Dump文件 &#xff0c;它分析完会通过一个浏览器打开一个可视化页面展示分析结果 根据oom的类型来调…

什么是 OLAP 数据库?企业如何选择适合自己的分析工具

引言&#xff1a;为什么企业需要 OLAP 数据库&#xff1f; 你是否曾经经历过这样的场景&#xff1a; 市场部门急需一份用户行为分析报告&#xff0c;数据团队告诉你&#xff1a;“数据太大了&#xff0c;报表要跑 4 个小时”&#xff1b;业务负责人在会议中提出一个临时性分析…

测试:认识Bug

目录 一、软件测试的生命周期 二、bug 一、软件测试的生命周期 软件测试贯穿于软件的生命周期。 需求分析&#xff1a; ⽤⼾⻆度&#xff1a;软件需求是否合理 技术⻆度&#xff1a;技术上是否可⾏&#xff0c;是否还有优化空间 测试⻆度&#xff1a;是否存在业务逻辑错误、…

综合实验2

1、sw1和sw2之间互为备份 [sw1]interface Eth-Trunk 0 &#xff08;创建聚合接口&#xff09; [sw1-Eth-Trunk0]trunkport g0/0/1 &#xff08;将物理接口划入到聚合接口中&#xff09; [sw1-Eth-Trunk0]trunkport g0/0/2 [sw2]interface Eth-Trunk 0 [sw2-Eth-T…

【ArcGIS】ArcGIS10.6彻底卸载和ArcGIS10.2安装全过程

卸载python3后,解决了ArcGIS与python3冲突问题后,软件可以正常打开使用了 但是还是出现了问题 用ArcGIS 进行空间分析时,中间操作没有任何报错和问题,但是就是没有运行结果 在别人的软件上操作一遍可以出现运行结果 关闭确有这个,但真的不是我给它的运行时间不够,反反复复试…

Django之旅:第五节--Mysql数据库操作(一)

Django开发操作数据库更简单&#xff0c;内部提供了ORM框架 一、安装第三方模块 pip install mysqlclient注&#xff1a;最新的django框架需要使用mysqlclient模块&#xff0c;之前pymysql模块与django框架有编码兼容问题。 二、ORM 1、ORM可以帮助我们做两件事&#xff1a;…

docker部署mongodb数据库

1、下载 MongoDB 镜像 使用Docker部署MongoDB 之前&#xff0c;我们需要从 Docker Hub 上下载 MongoDB 镜像。这里我们下载最新版本的 MongoDB 镜像&#xff0c;使用以下命令进行下载&#xff1a; docker pull mongo:latest 下载完成后&#xff0c;我们就拥有了最新版本的 Mon…

Enhanced PEC-YOLO:电力施工场景安全装备检测的轻量化算法解析

目录 一、核心概述 二、核心创新点 1. ​C2F_Faster_EMA模块 2. ​SPPF_CPCA多尺度模块 3. ​BiFPN颈部网络

【人工智能】解锁大模型潜力:Ollama 与 DeepSeek 的分布式推理与集群部署实践

《Python OpenCV从菜鸟到高手》带你进入图像处理与计算机视觉的大门! 解锁Python编程的无限可能:《奇妙的Python》带你漫游代码世界 随着大语言模型(LLM)的快速发展,其推理能力在自然语言处理、代码生成等领域展现出巨大潜力。然而,单机部署难以满足高并发、低延迟的需…

RTMP推流服务器nginx在linux上的编译部署

RTMP&#xff08;Real-Time Messaging Protocol&#xff09;推流确实需要服务器支持‌。RTMP推流服务器的主要功能是接收来自推流客户端的数据流&#xff0c;对其进行处理和转发。服务器会根据RTMP协议与客户端建立连接&#xff0c;处理推流数据&#xff08;如转码、录制等&…