翼度科技»论坛 编程开发 .net 查看内容

ASP.NET6 + Mongo + OData

7

主题

7

帖子

21

积分

新手上路

Rank: 1

积分
21
准备工作


  • Docker环境
  • Mongo数据库
  • 配置Mongo数据库
ASP.NET6 集成Mongo

安装MongoDB.Driver
  1. {
  2.     "Logging": {
  3.         "LogLevel": {
  4.             "Default": "Information",
  5.             "Microsoft.AspNetCore": "Warning"
  6.             }
  7.     },
  8.     "BookStoreDatabase": {
  9.         "ConnectionString": "mongodb://localhost",
  10.         "DatabaseName": "BookStore",
  11.         "BooksCollectionName": "Books"
  12.         },
  13.     "AllowedHosts": "*"
  14. }
复制代码
  1. public class BookStoreDatabaseSettings
  2. {
  3.     public string ConnectionString { get; set; } = null!;
  4.     public string DatabaseName { get; set; } = null!;
  5.     public string BooksCollectionName { get; set; } = null!;
  6. }
复制代码
  1. using MongoDB.Bson;
  2. using MongoDB.Bson.Serialization.Attributes;
  3. namespace MongoExample.Models;
  4. public class Book
  5. {
  6.     [BsonId]
  7.     [BsonRepresentation(BsonType.ObjectId)]
  8.     public string? Id { get; set; }
  9.     [BsonElement("Name")]
  10.     public string BookName { get; set; } = null!;
  11.    
  12.     public decimal Price { get; set; }
  13.     public string Category { get; set; } = null!;
  14.     public string Author { get; set; } = null!;
  15. }
复制代码
  1. using MongoDB.Driver;
  2. using MongoExample.Models;
  3. using Microsoft.Extensions.Options;
  4. namespace MongoExample.Services;
  5. public class BookService
  6. {
  7.     private readonly IMongoCollection<Book> _bookCollection;
  8.     public BookService(IOptions<BookStoreDatabaseSettings> bookStoreDatabaseSettings)
  9.     {
  10.         var mongoClient = new MongoClient("mongodb://admin:000000@localhost:27017");
  11.         var mongoDatabase = mongoClient.GetDatabase(bookStoreDatabaseSettings.Value.DatabaseName);
  12.         _bookCollection = mongoDatabase.GetCollection<Book>(bookStoreDatabaseSettings.Value.BooksCollectionName);
  13.     }
  14.     public async Task<List<Book>> GetBooksAsync() => await _bookCollection.Find(_ => true).ToListAsync();
  15.     public async Task<Book> GetBookAsync(string id) => await _bookCollection.Find(x=>x.Id == id).FirstOrDefaultAsync();
  16.     public async Task CreateAsync(Book book) => await _bookCollection.InsertOneAsync(book);
  17.     public async Task UpdateAsync(string id, Book updatedBook) => await _bookCollection.ReplaceOneAsync(x=>x.Id == id, updatedBook);
  18.     public async Task RemoveAsync(string id) => await _bookCollection.DeleteOneAsync(x=>x.Id ==id);
  19. }
复制代码
  1. using Microsoft.AspNetCore.Mvc;
  2. using Microsoft.AspNetCore.OData.Query;
  3. using MongoExample.Models;
  4. using MongoExample.Services;
  5. namespace MongoExample.Controllers;
  6. [ApiController]
  7. [Route("/api/[controller]")]
  8. public class BooksController : ControllerBase
  9. {
  10.     private readonly BookService _bookService;
  11.     public BooksController(BookService bookService)
  12.     {
  13.         this._bookService = bookService;
  14.     }
  15.     [HttpGet]
  16.     [EnableQuery]
  17.     public async Task<List<Book>> Get() => await _bookService.GetBooksAsync();
  18.     [HttpGet("{id:length(24)}")]
  19.     public async Task<ActionResult<Book>> GetBook(string id)
  20.     {
  21.         var book = await _bookService.GetBookAsync(id);
  22.         if (book == null)
  23.         {
  24.             return NotFound();
  25.         }
  26.         return book;
  27.     }
  28.     [HttpPost]
  29.     public async Task<ActionResult> Create(Book book)
  30.     {
  31.         await _bookService.CreateAsync(book);
  32.         return CreatedAtAction("Get", new { id = book.Id }, book);
  33.     }
  34.     [HttpPut("{id:length(24)}")]
  35.     public async Task<IActionResult> Update(string id, Book updatedBook)
  36.     {
  37.         var book = await _bookService.GetBookAsync(id);
  38.         if (book == null)
  39.         {
  40.             return NotFound();
  41.         }
  42.         updatedBook.Id = book.Id;
  43.         await _bookService.UpdateAsync(id, updatedBook);
  44.         return NoContent();
  45.     }
  46.     [HttpDelete("{id:length(24)}")]
  47.     public async Task<IActionResult> Delete(string id)
  48.     {
  49.         var book = await _bookService.GetBookAsync(id);
  50.         if (book == null)
  51.         {
  52.             return NotFound();
  53.         }
  54.         await _bookService.RemoveAsync(id);
  55.         return NoContent();
  56.     }
  57. }
复制代码
ASP.NET6 集成OData

VS22022基于.NET6基础上创建的asp.net core web api模板已经合并了Startup和Program类, 所有的服务注入,中间件注入都合并在了Program类中, 好久没写C#了,这个类这次变化有点大。
安装OData

合并后的模板只有Program.cs类,没有了Startup类,也就是之前的服务注入都是通过ConfigServices方法,IServiceCollection实现。 如果不习惯的话也可以自己手动创建一个Startup类,然后在Program类中调用该类。
  1. using Microsoft.AspNetCore.OData;
  2. using MongoExample.Models;
  3. using MongoExample.Services;
  4. var builder = WebApplication.CreateBuilder(args);
  5. builder.Services.AddControllers();
  6. builder.Services.AddEndpointsApiExplorer();
  7. builder.Services.AddSwaggerGen();
  8. builder.Services.Configure<BookStoreDatabaseSettings>(builder.Configuration.GetSection("BookStoreDatabase"));
  9. builder.Services.AddSingleton<BookService>();
  10. //这里注入OData查询方法
  11. builder.Services.AddControllers().AddOData(options => options.Select().Filter().OrderBy());
  12. var app = builder.Build();
  13. if (app.Environment.IsDevelopment())
  14. {
  15.     app.UseSwagger();
  16.     app.UseSwaggerUI();
  17. }
  18. app.UseAuthorization();
  19. app.MapControllers();
  20. app.Run();
复制代码
测试OData Query

查询Category和BookName字段
http://localhost:5220/api/books?$select=Category,BookName
响应JSON值
  1. [{"Category":"Computer","BookName":"Design Patters"},{"Category":"Software","BookName":"Java In Action"},{"Category":"Software","BookName":"C# In Action"}]
复制代码
查询Category和BookName字段并且用Category倒叙排列
  1. [{"Category":"Software","BookName":"Java In Action"},{"Category":"Software","BookName":"C# In Action"},{"Category":"Computer","BookName":"Design Patters"}]
复制代码
来源:https://www.cnblogs.com/sword-successful/archive/2023/02/11/17112750.html
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x

举报 回复 使用道具