EasilyNET.Mongo.AspNetCore
1.9.0-preview2
This is a prerelease version of EasilyNET.Mongo.AspNetCore.
There is a newer version of this package available.
See the version list below for details.
See the version list below for details.
dotnet add package EasilyNET.Mongo.AspNetCore --version 1.9.0-preview2
NuGet\Install-Package EasilyNET.Mongo.AspNetCore -Version 1.9.0-preview2
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="EasilyNET.Mongo.AspNetCore" Version="1.9.0-preview2" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add EasilyNET.Mongo.AspNetCore --version 1.9.0-preview2
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: EasilyNET.Mongo.AspNetCore, 1.9.0-preview2"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install EasilyNET.Mongo.AspNetCore as a Cake Addin #addin nuget:?package=EasilyNET.Mongo.AspNetCore&version=1.9.0-preview2&prerelease // Install EasilyNET.Mongo.AspNetCore as a Cake Tool #tool nuget:?package=EasilyNET.Mongo.AspNetCore&version=1.9.0-preview2&prerelease
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
EasilyNET.Mongo.AspNetCore
- 一个 MongoDB 驱动的服务包,方便使用 MongoDB 数据库.
- 数据库中字段名驼峰命名,ID,Id 自动转化成 ObjectId.
- 可配置部分类的 Id 字段不存为 ObjectId,而存为 string 类型.
- 自动本地化 MongoDB 时间类型
- 添加.Net6 Date/Time Only 类型支持(TimeOnly 理论上应该是兼容原 TimeSpan 数据类型).
- 添加 SkyWalking-APM 探针支持,未依赖 Agent,所以需要手动传入参数.
使用
- Nuget 安装 EasilyNET.Mongo.AspNetCore
- 推荐同时安装 EasilyNET.MongoSerializer.AspNetCore 包,添加了对 .Net6+ 的 Date/Time Only 类型
- 在系统环境变量或者 Docker 容器中设置环境变量名称为: CONNECTIONSTRINGS_MONGO = mongodb 链接字符串 或者在 appsettings.json 中添加,
- 现在你也可以参考 example.api 项目查看直接传入相关数据.
- 添加 APM 探针支持,根据 SkyApm.Diagnostics.MongoDB
{
"ConnectionStrings": {
"Mongo": "mongodb链接字符串"
},
// 或者使用
"CONNECTIONSTRINGS_MONGO": "mongodb链接字符串"
}
方法 1. 使用默认依赖注入方式
var builder = WebApplication.CreateBuilder(args);
// 添加Mongodb数据库服务
builder.Services.AddMongoContext<DbContext>(builder.Configuration, c =>
{
// 配置数据库名称,覆盖掉连接字符串中的数据库名称
c.DatabaseName = "test23";
// 配置不需要将Id字段存储为ObjectID的类型.使用$unwind操作符的时候,ObjectId在转换上会有一些问题.
c.ObjectIdToStringTypes = new()
{
typeof(MongoTest2)
};
// 是否使用HoyoMongo的一些默认转换配置.包含如下内容:
// 1.小驼峰字段名称 如: pageSize ,linkPhone
// 2.忽略代码中未定义的字段
// 3.将ObjectID字段 _id 映射到实体中的ID或者Id字段,反之亦然.在存入数据的时候将Id或者ID映射为 _id
// 4.将枚举类型存储为字符串, 如: Gender.男 存储到数据中为 男,而不是 int 类型
c.DefaultConventionRegistry = true;
// 配置自定义Convention
c.ConventionRegistry= new()
{
{
$"{SnowId.GenerateNewId()}",
new() { new IgnoreIfDefaultConvention(true) }
}
};
// 通过ClientSettings来配置一些使用特殊的东西
c.ClientSettings = cs =>
{
// 新版的MongoDB驱动默认为V3,老项目会出现一些问题,可设置V2来兼容老项目
cs.LinqProvider = LinqProvider.V2;
// 对接 SkyAPM 的 MongoDB探针或者别的事件订阅器
cs.ClusterConfigurator = cb => cb.Subscribe(new ActivityEventSubscriber());
};
});
// 添加.NET6+新的TimeOnly和DateOnly数据类型的序列化方案和添加动态类型支持
builder.Services.RegisterSerializer().RegisterDynamicSerializer();
// 注册别的序列化方案
builder.Services.RegisterSerializer(new DoubleSerializer(BsonType.Double));
...
var app = builder.Build();
方法 2. 使用 EasilyNET.AutoDependencyInjection
- 项目添加 EasilyNET.AutoDependencyInjection Nuget 包
- 创建 EasilyNETMongoModule.cs 并继承 AppModule 类
public class EasilyNETMongoModule : AppModule
{
/// <summary>
/// 配置和注册服务
/// </summary>
/// <param name="context"></param>
public override void ConfigureServices(ConfigureServicesContext context)
{
var config = context.Services.GetConfiguration();
// 使用 IConfiguration 的方式注册例子,使用链接字符串,仅需将config替换成连接字符即可.
//context.Services.AddMongoContext<DbContext>(config, c =>
//{
// // 配置数据库名称,覆盖掉连接字符串中的数据库名称
// c.DatabaseName = "test23";
// // 配置不需要将Id字段存储为ObjectID的类型.使用$unwind操作符的时候,ObjectId在转换上会有一些问题.
// c.ObjectIdToStringTypes = new()
// {
// typeof(MongoTest2)
// };
// // 是否使用HoyoMongo的一些默认转换配置.包含如下内容:
// // 1.小驼峰字段名称 如: pageSize ,linkPhone
// // 2.忽略代码中未定义的字段
// // 3.将ObjectID字段 _id 映射到实体中的ID或者Id字段,反之亦然.在存入数据的时候将Id或者ID映射为 _id
// // 4.将枚举类型存储为字符串, 如: Gender.男 存储到数据中为 男,而不是 int 类型
// c.DefaultConventionRegistry = true;
// c.ConventionRegistry= new()
// {
// {
// $"{SnowId.GenerateNewId()}",
// new() { new IgnoreIfDefaultConvention(true) }
// }
// };
// // 通过ClientSettings来配置一些使用特殊的东西
// c.ClientSettings = cs =>
// {
// // 新版的MongoDB驱动默认为V3,老项目会出现一些问题,可设置V2来兼容老项目
// cs.LinqProvider = LinqProvider.V2;
// // 对接 SkyAPM 的 MongoDB探针或者别的事件订阅器
// cs.ClusterConfigurator = cb => cb.Subscribe(new ActivityEventSubscriber());
// };
//});
//context.Services.AddMongoContext<DbContext2>(config);
//context.Services.RegisterSerializer(new GuidSerializer(GuidRepresentation.Standard));
//context.Services.RegisterSerializer().RegisterDynamicSerializer();
// 例子二:使用MongoClientSettings配置
context.Services.AddMongoContext<DbContext>(new MongoClientSettings
{
Servers = new List<MongoServerAddress> { new("127.0.0.1", 27018) },
Credential = MongoCredential.CreateCredential("admin", "guest", "guest"),
// 新版驱动使用V3版本,有可能会出现一些Linq表达式客户端函数无法执行,需要调整代码,但是工作量太大了,所以可以先使用V2兼容.
LinqProvider = LinqProvider.V3,
// 对接 SkyAPM 的 MongoDB探针
ClusterConfigurator = cb => cb.Subscribe(new DiagnosticsActivityEventSubscriber())
}, c =>
{
// 配置数据库名称,覆盖掉连接字符串中的数据库名称
c.DatabaseName = "test23";
// 配置不需要将Id字段存储为ObjectID的类型.使用$unwind操作符的时候,ObjectId在转换上会有一些问题.
c.ObjectIdToStringTypes = new()
{
typeof(MongoTest2)
};
// 是否使用HoyoMongo的一些默认转换配置.包含如下内容:
// 1.小驼峰字段名称 如: pageSize ,linkPhone
// 2.忽略代码中未定义的字段
// 3.将ObjectID字段 _id 映射到实体中的ID或者Id字段,反之亦然.在存入数据的时候将Id或者ID映射为 _id
// 4.将枚举类型存储为字符串, 如: Gender.男 存储到数据中为 男,而不是 int 类型
c.DefaultConventionRegistry = true;
c.ConventionRegistry= new()
{
{
$"{SnowId.GenerateNewId()}",
new() { new IgnoreIfDefaultConvention(true) }
}
};
});
context.Services.AddMongoContext<DbContext2>(config, c =>
{
c.DefaultConventionRegistry = true;
c.ConventionRegistry = new()
{
{
$"{SnowId.GenerateNewId()}",
new() { new IgnoreIfDefaultConvention(true) }
}
};
});
//context.Services.RegisterSerializer().RegisterDynamicSerializer();
}
}
- 创建 AppWebModule.cs 并添加 EasilyNETMongoModule
/**
* 要实现自动注入,一定要在这个地方添加
*/
[DependsOn(
typeof(DependencyAppModule),
typeof(EasilyNETMongoModule)
)]
public class AppWebModule : AppModule
{
/// <summary>
/// 注册和配置服务
/// </summary>
/// <param name="context"></param>
public override void ConfigureServices(ConfigureServicesContext context)
{
base.ConfigureServices(context);
_ = context.Services.AddHttpContextAccessor();
}
/// <summary>
/// 注册中间件
/// </summary>
/// <param name="context"></param>
public override void ApplicationInitialization(ApplicationContext context)
{
base.ApplicationInitialization(context);
var app = context.GetApplicationBuilder();
_ = app.UseAuthorization();
}
}
- 最后在 Program.cs 中添加如下内容
var builder = WebApplication.CreateBuilder(args);
// Add services to the container.
// 自动注入服务模块
builder.Services.AddApplication<AppWebModule>();
var app = builder.Build();
// Configure the HTTP request pipeline.
if (app.Environment.IsDevelopment()) _ = app.UseDeveloperExceptionPage();
// 添加自动化注入的一些中间件.
app.InitializeApplication();
app.MapControllers();
app.Run();
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net6.0 is compatible. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 is compatible. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
net6.0
- EasilyNET.Mongo.Core (>= 1.9.0-preview2)
- Microsoft.Extensions.Configuration.Abstractions (>= 6.0.0)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 6.0.0)
-
net7.0
- EasilyNET.Mongo.Core (>= 1.9.0-preview2)
- Microsoft.Extensions.Configuration.Abstractions (>= 7.0.0)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 7.0.0)
-
net8.0
- EasilyNET.Mongo.Core (>= 1.9.0-preview2)
- Microsoft.Extensions.Configuration.Abstractions (>= 8.0.0-rc.2.23479.6)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 8.0.0-rc.2.23479.6)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
4.25.124.223 | 0 | 1/24/2025 |
4.25.116.110 | 67 | 1/16/2025 |
4.25.115.121 | 46 | 1/15/2025 |
4.25.114.172 | 50 | 1/14/2025 |
4.25.109.111 | 39 | 1/9/2025 |
4.25.108.182 | 48 | 1/8/2025 |
4.25.108.160 | 53 | 1/8/2025 |
4.25.1.1 | 90 | 1/1/2025 |
3.24.1224.141 | 82 | 12/24/2024 |
3.24.1216.116 | 98 | 12/16/2024 |
3.24.1206.100 | 92 | 12/6/2024 |
3.24.1205.171 | 105 | 12/5/2024 |
3.24.1202.150 | 82 | 12/2/2024 |
3.24.1126.231 | 83 | 11/26/2024 |
3.24.1126.172 | 93 | 11/26/2024 |
3.24.1126.114 | 90 | 11/26/2024 |
3.24.1126.104 | 87 | 11/26/2024 |
3.24.1125.181 | 85 | 11/25/2024 |
3.24.1125.104 | 92 | 11/25/2024 |
3.24.1121.183 | 83 | 11/21/2024 |
3.24.1120.183 | 83 | 11/20/2024 |
3.24.1119.31 | 88 | 11/18/2024 |
3.24.1115.143 | 83 | 11/15/2024 |
3.24.1113.100 | 85 | 11/13/2024 |
3.24.1112.125 | 354 | 11/12/2024 |
3.24.1107.140 | 92 | 11/7/2024 |
3.24.1107.54 | 89 | 11/7/2024 |
3.24.1107.34 | 82 | 11/7/2024 |
3.24.1105.111 | 94 | 11/5/2024 |
3.24.1103.31 | 87 | 11/2/2024 |
3.24.1103 | 94 | 11/2/2024 |
3.24.1031.135 | 89 | 10/31/2024 |
3.24.1031.112 | 81 | 10/31/2024 |
3.24.1031.104 | 88 | 10/31/2024 |
3.24.1029.142 | 88 | 10/29/2024 |
3.24.1025.30 | 193 | 10/24/2024 |
3.24.1022.142 | 74 | 10/22/2024 |
3.24.1018.204 | 142 | 10/18/2024 |
3.24.1018.175 | 131 | 10/18/2024 |
3.24.1018.166 | 136 | 10/18/2024 |
3.24.1018.93 | 137 | 10/18/2024 |
3.24.1017.42 | 102 | 10/16/2024 |
3.24.1016.161 | 101 | 10/16/2024 |
3.24.1015.231 | 85 | 10/15/2024 |
3.24.1015.14 | 87 | 10/14/2024 |
3.24.1012.114 | 92 | 10/12/2024 |
3.24.1009.115 | 96 | 10/9/2024 |
3.24.1008.160 | 83 | 10/8/2024 |
3.24.1008.133 | 89 | 10/8/2024 |
3.24.1007.185 | 91 | 10/7/2024 |
3.24.1003.33 | 101 | 10/2/2024 |
3.24.1002.162 | 99 | 10/2/2024 |
3.24.929.143 | 233 | 9/29/2024 |
3.24.929.141 | 95 | 9/29/2024 |
3.24.929.131 | 72 | 9/29/2024 |
3.24.929.122 | 63 | 9/29/2024 |
3.24.926.184 | 68 | 9/26/2024 |
3.24.926.182 | 64 | 9/26/2024 |
3.24.926.175 | 65 | 9/26/2024 |
3.24.924.160 | 70 | 9/24/2024 |
3.24.924.133 | 70 | 9/24/2024 |
3.24.924.124 | 59 | 9/24/2024 |
3.24.924.10 | 69 | 9/23/2024 |
3.24.924.1 | 66 | 9/23/2024 |
3.24.923.234 | 62 | 9/23/2024 |
3.24.923.232 | 65 | 9/23/2024 |
3.24.923.155 | 64 | 9/23/2024 |
3.24.919.92 | 68 | 9/19/2024 |
3.24.914.125 | 234 | 9/14/2024 |
3.24.914.115 | 87 | 9/14/2024 |
3.24.914.111 | 66 | 9/14/2024 |
3.24.911.95 | 66 | 9/11/2024 |
3.24.908.215 | 60 | 9/8/2024 |
3.24.904.200 | 215 | 9/4/2024 |
3.24.828.163 | 72 | 8/28/2024 |
3.24.820.173 | 71 | 8/20/2024 |
3.24.814.92 | 79 | 8/14/2024 |
3.24.812.115 | 72 | 8/12/2024 |
3.24.802.100 | 51 | 8/2/2024 |
3.24.801.162 | 59 | 8/1/2024 |
3.24.801.160 | 58 | 8/1/2024 |
3.24.801.155 | 60 | 8/1/2024 |
3.24.730.164 | 49 | 7/30/2024 |
3.24.730.91 | 51 | 7/30/2024 |
3.24.724.91 | 52 | 7/24/2024 |
3.24.718.105 | 69 | 7/18/2024 |
3.24.716.95 | 64 | 7/16/2024 |
3.24.712.94 | 62 | 7/12/2024 |
3.24.710.14 | 64 | 7/9/2024 |
3.24.709.105 | 64 | 7/9/2024 |
3.24.704.94 | 67 | 7/4/2024 |
3.24.701.90 | 67 | 7/1/2024 |
3.24.628.114 | 74 | 6/28/2024 |
3.24.627.145 | 60 | 6/27/2024 |
3.24.620.160 | 69 | 6/20/2024 |
3.24.613.115 | 61 | 6/13/2024 |
3.24.612.95 | 65 | 6/12/2024 |
3.24.528.90 | 66 | 5/28/2024 |
3.24.522.84 | 74 | 5/22/2024 |
3.24.512.213 | 70 | 5/12/2024 |
3.24.508.112 | 87 | 5/8/2024 |
2.2024.428.71 | 66 | 4/28/2024 |
2.2024.427.1128 | 69 | 4/27/2024 |
2.2.72 | 140 | 4/14/2024 |
2.2.71 | 79 | 4/12/2024 |
2.2.8 | 63 | 4/26/2024 |
2.2.6 | 72 | 4/10/2024 |
2.2.5 | 85 | 3/26/2024 |
2.2.4 | 85 | 3/25/2024 |
2.2.3 | 80 | 3/24/2024 |
2.2.2 | 80 | 3/21/2024 |
2.2.1 | 81 | 3/20/2024 |
2.2.0 | 82 | 3/13/2024 |
2.1.9 | 84 | 2/21/2024 |
2.1.8 | 72 | 2/18/2024 |
2.1.7 | 83 | 2/16/2024 |
2.1.6 | 100 | 2/14/2024 |
2.1.5 | 79 | 2/14/2024 |
2.1.4 | 159 | 2/9/2024 |
2.1.3 | 127 | 2/8/2024 |
2.1.2 | 147 | 2/5/2024 |
2.1.1.2 | 202 | 12/26/2023 |
2.1.1.1 | 127 | 12/26/2023 |
2.1.1 | 133 | 12/25/2023 |
2.1.0 | 168 | 12/17/2023 |
2.0.11 | 202 | 12/6/2023 |
2.0.1 | 206 | 11/15/2023 |
2.0.0 | 150 | 11/14/2023 |
1.9.1 | 122 | 11/1/2023 |
1.9.0 | 113 | 10/19/2023 |
1.9.0-preview2 | 289 | 10/12/2023 |
1.9.0-preview1 | 80 | 10/12/2023 |
1.8.9 | 152 | 10/11/2023 |
1.8.8 | 131 | 10/11/2023 |
1.8.7-rc2 | 103 | 9/21/2023 |
1.8.7-rc1 | 89 | 9/12/2023 |
1.8.6 | 131 | 8/31/2023 |
1.8.5 | 800 | 8/25/2023 |
1.8.4 | 126 | 8/24/2023 |
1.8.3 | 129 | 8/23/2023 |
1.8.2 | 208 | 8/22/2023 |
1.8.1 | 145 | 8/18/2023 |
1.8.0 | 125 | 8/15/2023 |
1.7.9 | 163 | 8/11/2023 |
1.7.8 | 109 | 8/11/2023 |
1.7.7 | 155 | 8/10/2023 |
1.7.6 | 138 | 8/9/2023 |
1.7.5 | 194 | 8/9/2023 |
1.7.4 | 230 | 8/3/2023 |
1.7.3 | 146 | 8/1/2023 |
1.7.2 | 133 | 7/31/2023 |
1.7.1 | 137 | 7/27/2023 |
1.7.0 | 144 | 7/25/2023 |
1.6.9 | 137 | 7/25/2023 |
1.6.8 | 132 | 7/24/2023 |
1.6.7 | 151 | 7/20/2023 |
1.6.6 | 159 | 7/19/2023 |
1.6.5 | 113 | 7/19/2023 |
1.6.4 | 131 | 7/17/2023 |
1.6.3 | 116 | 7/17/2023 |
1.6.2 | 170 | 7/12/2023 |
1.6.1 | 166 | 6/30/2023 |
1.6.0 | 103 | 6/30/2023 |