主頁 > .NET開發 > C# Abp框架入門系列文章(一)

C# Abp框架入門系列文章(一)

2022-01-03 06:02:37 .NET開發

隨著技術的進步,各式各樣的框架層出不窮,輪子越來越多,那么有沒有哪些優秀的開發框架供我們使用呢?如果我們能夠將各方面優秀的框架集合起來,應用到專案開發中,我們的作業是不是能事半功倍呢?而且各個框架的使用方向不同,很多配置也不同,如果能夠將繁雜的基礎作業集成起來,由統一的框架來完成,那么我們就可以專注于業務邏輯,提高作業效率,現在Abp就是這么一個框架,使用流行技術開發現代web應用程式的最佳實踐,本文作為Abp框架的入門文章,僅供學習分享使用,如有不足之處,還請指正,

什么是Abp?

ABP是“ASP.NET Boilerplate Project (ASP.NET樣板專案)”的簡稱,
ASP.NET Boilerplate是一個用最佳實踐和流行技術開發現代WEB應用程式的新起點,它旨在成為一個通用的WEB應用程式框架和專案模板,ABP是基于最新的ASP.NET CORE,ASP.NET MVC和Web API技術的應用程式框架,并使用流行的框架和庫,它提供了便于使用的授權,依賴注入,驗證,例外處理,本地化,日志記錄,快取等常用功能,

 

 

Abp架構

ABP實作了多層架構(領域層,應用層,基礎設施層和表示層),以及領域驅動設計(物體,存盤庫,領域服務,應用程式服務,DTO等),還實作和提供了良好的基礎設施來實作最佳實踐,如依賴注入,

 

 了解了Abp框架的基礎知識之后,讓我們一步一步的搭建Abp框架,并實作一個簡單的小例子,

安裝CLI

輸入cmd打開命令列視窗,然后輸入以下命令,安裝Abp.Cli,如下所示:

1 dotnet tool install -g Volo.Abp.Cli

安裝程序,如下圖所示:

 

創建第一個Abp專案

在命令列,切換到程式所在目錄【最好是空目錄】,然后通過命令進行創建,如下所示:

1 abp new Acme.BookStore

安裝程序,如下圖所示:

關于Abp的Cli相關命令,可參考官方檔案 ,

專案創建成功后,如下所示:

 通過Visual Studio打開解決方案,如下所示:

 

還原資料庫

在Abp解決方案中,通過運行【Acme.BookStore.DbMigrator】進行初始化資料庫,該專案是控制臺程式,采用Entity Framework的Code First方式遷移資料庫,

打開專案【Acme.BookStore.DbMigrator】中 appsettings.json檔案,修改資料庫連接字串,為本機連接字串,如下所示:

將專案設定為啟動專案,然后F5(或Ctrl + F5)運行即可,當出現以下頁面時,表示資料庫遷移成功,如下所示:

 

資料庫還原成功后,打開SQL Server資料庫,會多出一個資料庫【BookStore】,如下所示:

注意:最新版本的Abp版本為5.0.0,支持的Entity Framework Core版本為6.0,目前已不再支持SQL Server 2008 R2,所以需要升級資料庫版本到2012,

運行Abp程式

打開專案【Acme.BookStore.Web】中的appsettings.json檔案,修改資料庫連接字串,如下所示:

 

將專案【Acme.BookStore.Web】設定為啟動專案,然后按F5(或Ctrl+F5)運行專案,Visual Studio會自動打開首頁【https://localhost:44327/】,如下所示:

 

 在首頁上,點擊登錄【默認用戶名 admin,密碼 1q2w3E* 】,如下所示:

 

 登錄成功后,如下所示:

 以上就是Abp最新默認框架示例,接下來讓我們一起開發一個圖書管理的小功能,

Abp入門示例

1. 創建Book物體類

啟動模板中的領域層分為兩個專案:

  • Acme.BookStore.Domain包含你的物體, 領域服務和其他核心域物件.
  • Acme.BookStore.Domain.Shared包含可與客戶共享的常量,列舉或其他域相關物件.

在解決方案的領域層(Acme.BookStore.Domain專案)中定義物體,如下所示:

在Acme.BookStore.Domain專案中,右鍵創建檔案夾Books,然后新增Book類,如下所示:

 1 namespace Acme.BookStore.Books
 2 {
 3     public class Book : AuditedAggregateRoot<Guid>
 4     {
 5         public string Name { get; set; }
 6 
 7         public BookType Type { get; set; }
 8 
 9         public DateTime PublishDate { get; set; }
10 
11         public float Price { get; set; }
12     }
13 }

其中Book繼承自AuditedAggregateRoot<Guid>,在Abp中,默認提供了兩個物體基類AggregateRootEntity,而AuditedAggregateRoot<Guid>是AggregateRoot的派生類,其中Guid是主鍵型別,

上述類中用到的BookType為創建的 列舉型別,在Acme.BookStore.Domain.Shared專案中,如下所示:

 1 namespace Acme.BookStore.Books
 2 {
 3     public enum BookType
 4     {
 5         Undefined,
 6         Adventure,
 7         Biography,
 8         Dystopia,
 9         Fantastic,
10         Horror,
11         Science,
12         ScienceFiction,
13         Poetry
14     }
15 }

Book和BookType,如下所示:

 

2. 將Book物體添加到DbContext中

 EF Core需要你將物體和 DbContext 建立關聯.最簡單的做法是在Acme.BookStore.EntityFrameworkCore專案的BookStoreDbContext類中添加DbSet屬性.如下所示:

 1 namespace Acme.BookStore.EntityFrameworkCore
 2 {
 3     [ReplaceDbContext(typeof(IIdentityDbContext))]
 4     [ReplaceDbContext(typeof(ITenantManagementDbContext))]
 5     [ConnectionStringName("Default")]
 6     public class BookStoreDbContext : 
 7         AbpDbContext<BookStoreDbContext>,
 8         IIdentityDbContext,
 9         ITenantManagementDbContext
10     {
11         /* Add DbSet properties for your Aggregate Roots / Entities here. */
12         
13         #region Entities from the modules
14         //其他自帶的已略去
15         /// <summary>
16         /// Book示例資料庫操作
17         /// </summary>
18         public DbSet<Book> Books { get; set; }
19 
20         #endregion
21         
22 
23 
24     }
25 }    

3. 將Book物體映射到資料庫表

在本示例中采用Code First方式自動生成資料庫,所以需要將物體和資料庫表進行映射,在 Acme.BookStore.EntityFrameworkCore 專案中打開 BookStoreDbContextModelCreatingExtensions.cs 檔案,添加 Book 物體的映射代碼. 最終類應為:

 1 namespace Acme.BookStore.EntityFrameworkCore
 2 {
 3     public static class BookStoreDbContextModelCreatingExtensions
 4     {
 5         public static void ConfigureBookStore(this ModelBuilder builder)
 6         {
 7             Check.NotNull(builder, nameof(builder));
 8 
 9             /* Configure your own tables/entities inside here */
10 
11             builder.Entity<Book>(b =>
12             {
13                 b.ToTable(BookStoreConsts.DbTablePrefix + "Books",
14                           BookStoreConsts.DbSchema);
15                 b.ConfigureByConvention(); //auto configure for the base class props
16                 b.Property(x => x.Name).IsRequired().HasMaxLength(128);
17             });
18         }
19     }
20 }
  • BookStoreConsts 含有用于表的架構和表前綴的常量值. 你不必使用它,但建議在單點控制表前綴.
  • ConfigureByConvention() 方法優雅的配置/映射繼承的屬性,應始終對你所有的物體使用它.

3. 添加資料遷移

啟動模板使用EF Core Code First Migrations創建和維護資料庫架構. 我們應該創建一個新的遷移并且應用到資料庫.

在 Acme.BookStore.EntityFrameworkCore 目錄打開命令列終端輸入以下命令:

1 dotnet ef migrations add Created_Book_Entity

具體示例如下所示:

 

 上述命令,會添加新的遷移類到專案中,如下所示:

 

4. 添加種子資料

如果不需要通過代碼添加種子資料,可以跳過,建議遵循步驟操作,以熟悉Abp框架,在 Acme.BookStore.Domain 專案下創建派生 IDataSeedContributor 的類,并且拷貝以下代碼:

 1 namespace Acme.BookStore.Books
 2 {
 3     public class BookStoreDataSeederContributor
 4         : IDataSeedContributor, ITransientDependency
 5     {
 6         private readonly IRepository<Book, Guid> _bookRepository;
 7 
 8         public BookStoreDataSeederContributor(IRepository<Book, Guid> bookRepository)
 9         {
10             _bookRepository = bookRepository;
11         }
12 
13         public async Task SeedAsync(DataSeedContext context)
14         {
15             if (await _bookRepository.GetCountAsync() <= 0)
16             {
17                 await _bookRepository.InsertAsync(
18                     new Book
19                     {
20                         Name = "1984",
21                         Type = BookType.Dystopia,
22                         PublishDate = new DateTime(1949, 6, 8),
23                         Price = 19.84f
24                     },
25                     autoSave: true
26                 );
27 
28                 await _bookRepository.InsertAsync(
29                     new Book
30                     {
31                         Name = "The Hitchhiker's Guide to the Galaxy",
32                         Type = BookType.ScienceFiction,
33                         PublishDate = new DateTime(1995, 9, 27),
34                         Price = 42.0f
35                     },
36                     autoSave: true
37                 );
38             }
39         }
40     }
41 }
  • 如果資料庫中當前沒有圖書,則此代碼使用 IRepository<Book, Guid>(默認為repository)將兩本書插入資料庫.

5. 更新資料庫

運行 Acme.BookStore.DbMigrator 應用程式來更新資料庫,將Acme.BookStore.DbMigrator設定為啟動程式,然后運行即可,如下所示:

 

 執行成功后,打開資料庫管理工具,即可看到新生成的資料表,如下所示:

 

 以上則表示資料庫創建成功,

6. 創建應用程式

應用程式層由兩個分離的專案組成:

  • Acme.BookStore.Application.Contracts 包含你的DTO和應用服務介面.
  • Acme.BookStore.Application 包含你的應用服務實作.

在本部分中,創建一個應用程式服務,使用ABP Framework的 CrudAppService 基類來獲取,創建,更新和洗掉書籍.

6. 1 創建BookDto類

在Abp中,需要創建Book物體的Dto類,在Acme.BookStore.Application.Contracts專案中,添加BootDto類,如下所示:

 1 namespace Acme.BookStore
 2 {
 3     public class BookDto : AuditedEntityDto<Guid>
 4     {
 5         public string Name { get; set; }
 6 
 7         public BookType Type { get; set; }
 8 
 9         public DateTime PublishDate { get; set; }
10 
11         public float Price { get; set; }
12     }
13 }
  • DTO類被用來在 表示層 和 應用層 傳遞資料.
  • 為了在頁面上展示書籍資訊,BookDto被用來將書籍資料傳遞到表示層.
  • BookDto繼承自 AuditedEntityDto<Guid>.跟上面定義的 Book 物體一樣具有一些審計屬性.

在將書籍回傳到表示層時,需要將Book物體轉換為BookDto物件. AutoMapper庫可以在定義了正確的映射時自動執行此轉換. 啟動模板配置了AutoMapper,因此你只需在Acme.BookStore.Application專案的BookStoreApplicationAutoMapperProfile類中定義映射:

 1 namespace Acme.BookStore
 2 {
 3     public class BookStoreApplicationAutoMapperProfile : Profile
 4     {
 5         public BookStoreApplicationAutoMapperProfile()
 6         {
 7             /* You can configure your AutoMapper mapping configuration here.
 8              * Alternatively, you can split your mapping configurations
 9              * into multiple profile classes for a better organization. */
10             CreateMap<Book, BookDto>();
11         }
12     }
13 }

6.2 CreateUpdateBookDto

Acme.BookStore.Application.Contracts專案中創建一個名為 CreateUpdateBookDto 的DTO類:

 1 namespace Acme.BookStore.Books
 2 {
 3     public class CreateUpdateBookDto
 4     {
 5         [Required]
 6         [StringLength(128)]
 7         public string Name { get; set; }
 8 
 9         [Required]
10         public BookType Type { get; set; } = BookType.Undefined;
11 
12         [Required]
13         [DataType(DataType.Date)]
14         public DateTime PublishDate { get; set; } = DateTime.Now;
15 
16         [Required]
17         public float Price { get; set; }
18     }
19 }
  • 這個DTO類被用于在創建或更新書籍的時候從用戶界面獲取圖書資訊.
  • 它定義了資料注釋屬性(如[Required])來定義屬性的驗證. DTO由ABP框架自動驗證.

就像上面的BookDto一樣,創建一個從CreateUpdateBookDto物件到Book物體的映射,最終映射配置類如下:

 1 namespace Acme.BookStore
 2 {
 3     public class BookStoreApplicationAutoMapperProfile : Profile
 4     {
 5         public BookStoreApplicationAutoMapperProfile()
 6         {
 7             /* You can configure your AutoMapper mapping configuration here.
 8              * Alternatively, you can split your mapping configurations
 9              * into multiple profile classes for a better organization. */
10             CreateMap<Book, BookDto>();
11             CreateMap<CreateUpdateBookDto, Book>();
12         }
13     }
14 }

7. 創建應用程式服務 

7.1 創建IBookAppService

下一步是為應用程式定義介面,在Acme.BookStore.Application.Contracts專案中定義一個名為IBookAppService的介面:

  • 框架定義應用程式服務的介面不是必需的. 但是,它被建議作為最佳實踐.
  • ICrudAppService定義了常見的CRUD方法:GetAsync,GetListAsync,CreateAsync,UpdateAsyncDeleteAsync. 你可以從空的IApplicationService介面繼承并手動定義自己的方法(將在下一部分中完成).
  • ICrudAppService有一些變體, 你可以在每個方法中使用單獨的DTO,也可以分別單獨指定(例如使用不同的DTO進行創建和更新).

7.2 創建 BookAppService

Acme.BookStore.Application專案中創建名為 BookAppService 的 IBookAppService 實作:

 1 namespace Acme.BookStore.Books
 2 {
 3     public class BookAppService :
 4         CrudAppService<
 5             Book, //The Book entity
 6             BookDto, //Used to show books
 7             Guid, //Primary key of the book entity
 8             PagedAndSortedResultRequestDto, //Used for paging/sorting
 9             CreateUpdateBookDto>, //Used to create/update a book
10         IBookAppService //implement the IBookAppService
11     {
12         public BookAppService(IRepository<Book, Guid> repository)
13             : base(repository)
14         {
15 
16         }
17     }
18 }
  • BookAppService繼承了CrudAppService<...>.它實作了 ICrudAppService 定義的CRUD方法.
  • BookAppService注入IRepository <Book,Guid>,這是Book物體的默認倉儲. ABP自動為每個聚合根(或物體)創建默認倉儲. 請參閱倉儲檔案
  • BookAppService使用IObjectMapperBook物件轉換為BookDto物件, 將CreateUpdateBookDto物件轉換為Book物件. 啟動模板使用AutoMapper庫作為物件映射提供程式. 我們之前定義了映射, 因此它將按預期作業.

8. 自動生成API Controllers

你通常創建Controller以將應用程式服務公開為HTTP API端點. 因此允許瀏覽器或第三方客戶端通過AJAX呼叫它們.

ABP可以自動按照慣例將你的應用程式服務配置為MVC API控制器.

9. Swagger UI

啟動模板配置為使用Swashbuckle.AspNetCore運行swagger UI. 運行應用程式并在瀏覽器中輸入https://localhost:XXXX/swagger/(用你自己的埠替換XXXX)作為URL.

你會看到一些內置的介面和Book的介面,它們都是REST風格的:

10. 創建頁面

在Acme.BookStore.Web專案的Pages檔案夾下,創建Books目錄,然后新增Razer Pages,如下所示:

 

 添加成功后,如下所示:

 

 Index.cshtml頁面代碼如下所示:

1 @page
2 @using Acme.BookStore.Web.Pages.Books
3 @model IndexModel
4 
5 <h2>Books</h2>

11. 將Book頁面添加到主選單

打開 Menus 檔案夾中的 BookStoreMenuContributor 類,在 ConfigureMainMenuAsync 方法的底部添加如下代碼:

 1 namespace Acme.BookStore.Web.Menus
 2 {
 3     public class BookStoreMenuContributor : IMenuContributor
 4     {
 5         public async Task ConfigureMenuAsync(MenuConfigurationContext context)
 6         {
 7             if (context.Menu.Name == StandardMenus.Main)
 8             {
 9                 await ConfigureMainMenuAsync(context);
10             }
11         }
12 
13         private async Task ConfigureMainMenuAsync(MenuConfigurationContext context)
14         {
15             var administration = context.Menu.GetAdministration();
16             var l = context.GetLocalizer<BookStoreResource>();
17 
18             context.Menu.Items.Insert(
19                 0,
20                 new ApplicationMenuItem(
21                     BookStoreMenus.Home,
22                     l["Menu:Home"],
23                     "~/",
24                     icon: "fas fa-home",
25                     order: 0
26                 )
27             );
28             
29             if (MultiTenancyConsts.IsEnabled)
30             {
31                 administration.SetSubItemOrder(TenantManagementMenuNames.GroupName, 1);
32             }
33             else
34             {
35                 administration.TryRemoveMenuItem(TenantManagementMenuNames.GroupName);
36             }
37 
38             administration.SetSubItemOrder(IdentityMenuNames.GroupName, 2);
39             administration.SetSubItemOrder(SettingManagementMenuNames.GroupName, 3);
40             //添加book選單 
41             context.Menu.AddItem(
42                 new ApplicationMenuItem(
43                     "BooksStore",
44                     l["Menu:BookStore"],
45                     icon: "fa fa-book"
46                 ).AddItem(
47                     new ApplicationMenuItem(
48                         "BooksStore.Books",
49                         l["Menu:Books"],
50                         url: "/Books"
51                     )
52                 )
53             );
54         }
55     }
56 }

運行Acme.BookStore.Web專案,等錄以后,便可以查看選單,如下所示:

 

 點擊選單后,跳轉到默認的Book首頁,如下所示:

 

12. 修改Book首頁

將 Pages/Book/Index.cshtml 改成下面的樣子:

 1 @page
 2 @using Acme.BookStore.Localization
 3 @using Acme.BookStore.Web.Pages.Books
 4 @using Microsoft.Extensions.Localization
 5 @model IndexModel
 6 @inject IStringLocalizer<BookStoreResource> L
 7 @section scripts
 8 {
 9     <abp-script src="/Pages/Books/Index.js" />
10 }
11 <abp-card>
12     <abp-card-header>
13         <h2>@L["Books"]</h2>
14     </abp-card-header>
15     <abp-card-body>
16         <abp-table striped-rows="true" id="BooksTable"></abp-table>
17     </abp-card-body>
18 </abp-card>

其中參考的Index.js位于Pages/Books目錄下,如下所示:

 1 $(function () {
 2     var l = abp.localization.getResource('BookStore');
 3 
 4     var dataTable = $('#BooksTable').DataTable(
 5         abp.libs.datatables.normalizeConfiguration({
 6             serverSide: true,
 7             paging: true,
 8             order: [[1, "asc"]],
 9             searching: false,
10             scrollX: true,
11             ajax: abp.libs.datatables.createAjax(acme.bookStore.books.book.getList),
12             columnDefs: [
13                 {
14                     title: l('Name'),
15                     data: "name"
16                 },
17                 {
18                     title: l('Type'),
19                     data: "type",
20                     render: function (data) {
21                         return l('Enum:BookType:' + data);
22                     }
23                 },
24                 {
25                     title: l('PublishDate'),
26                     data: "publishDate",
27                     render: function (data) {
28                         return luxon
29                             .DateTime
30                             .fromISO(data, {
31                                 locale: abp.localization.currentCulture.name
32                             }).toLocaleString();
33                     }
34                 },
35                 {
36                     title: l('Price'),
37                     data: "price"
38                 },
39                 {
40                     title: l('CreationTime'), data: "creationTime",
41                     render: function (data) {
42                         return luxon
43                             .DateTime
44                             .fromISO(data, {
45                                 locale: abp.localization.currentCulture.name
46                             }).toLocaleString(luxon.DateTime.DATETIME_SHORT);
47                     }
48                 }
49             ]
50         })
51     );
52 });

然后運行專案,結果如下所示:

 

 以上就是Abp的簡單入門介紹,旨在拋轉引玉,一起學習,共同進步,

備注

 浣溪沙·一曲新詞酒一杯【作者】晏殊 【朝代】北宋

一曲新詞酒一杯,去年天氣舊亭臺,夕陽西下幾時回?

無可奈何花落去,似曾相識燕歸來,小園香徑獨徘徊,


作者:小六公子
出處:http://www.cnblogs.com/hsiang/
本文著作權歸作者和博客園共有,寫文不易,支持原創,歡迎轉載【點贊】,轉載請保留此段宣告,且在文章頁面明顯位置給出原文連接,謝謝,
關注個人公眾號,定時同步更新技術及職場文章

轉載請註明出處,本文鏈接:https://www.uj5u.com/net/401365.html

標籤:.NET技术

上一篇:使用.NET 6開發TodoList應用(15)——實作查詢搜索

下一篇:使用.NET 6開發TodoList應用(15)——實作查詢搜索

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • WebAPI簡介

    Web體系結構: 有三個核心:資源(resource),URL(統一資源識別符號)和表示 他們的關系是這樣的:一個資源由一個URL進行標識,HTTP客戶端使用URL定位資源,表示是從資源回傳資料,媒體型別是資源回傳的資料格式。 接下來我們說下HTTP. HTTP協議的系統是一種無狀態的方式,使用請求/ ......

    uj5u.com 2020-09-09 22:07:47 more
  • asp.net core 3.1 入口:Program.cs中的Main函式

    本文分析Program.cs 中Main()函式中代碼的運行順序分析asp.net core程式的啟動,重點不是剖析原始碼,而是理清程式開始時執行的順序。到呼叫了哪些實體,哪些法方。asp.net core 3.1 的程式入口在專案Program.cs檔案里,如下。ususing System; us ......

    uj5u.com 2020-09-09 22:07:49 more
  • asp.net網站作為websocket服務端的應用該如何寫

    最近被websocket的一個問題困擾了很久,有一個需求是在web網站中搭建websocket服務。客戶端通過網頁與服務器建立連接,然后服務器根據ip給客戶端網頁發送資訊。 其實,這個需求并不難,只是剛開始對websocket的內容不太了解。上網搜索了一下,有通過asp.net core 實作的、有 ......

    uj5u.com 2020-09-09 22:08:02 more
  • ASP.NET 開源匯入匯出庫Magicodes.IE Docker中使用

    Magicodes.IE在Docker中使用 更新歷史 2019.02.13 【Nuget】版本更新到2.0.2 【匯入】修復單列匯入的Bug,單元測驗“OneColumnImporter_Test”。問題見(https://github.com/dotnetcore/Magicodes.IE/is ......

    uj5u.com 2020-09-09 22:08:05 more
  • 在webform中使用ajax

    如果你用過Asp.net webform, 說明你也算是.NET 開發的老兵了。WEBform應該是2011 2013左右,當時還用visual studio 2005、 visual studio 2008。后來基本都用的是MVC。 如果是新開發的專案,估計沒人會用webform技術。但是有些舊版 ......

    uj5u.com 2020-09-09 22:08:50 more
  • iis添加asp.net網站,訪問提示:由于擴展配置問題而無法提供您請求的

    今天在iis服務器配置asp.net網站,遇到一個問題,記錄一下: 問題:由于擴展配置問題而無法提供您請求的頁面。如果該頁面是腳本,請添加處理程式。如果應下載檔案,請添加 MIME 映射。 WindowServer2012服務器,添加角色安裝完.netframework和iis之后,運行aspx頁面 ......

    uj5u.com 2020-09-09 22:10:00 more
  • WebAPI-處理架構

    帶著問題去思考,大家好! 問題1:HTTP請求和回傳相應的HTTP回應資訊之間發生了什么? 1:首先是最底層,托管層,位于WebAPI和底層HTTP堆疊之間 2:其次是 訊息處理程式管道層,這里比如日志和快取。OWIN的參考是將訊息處理程式管道的一些功能下移到堆疊下端的OWIN中間件了。 3:控制器處理 ......

    uj5u.com 2020-09-09 22:11:13 more
  • 微信門戶開發框架-使用指導說明書

    微信門戶應用管理系統,采用基于 MVC + Bootstrap + Ajax + Enterprise Library的技術路線,界面層采用Boostrap + Metronic組合的前端框架,資料訪問層支持Oracle、SQLServer、MySQL、PostgreSQL等資料庫。框架以MVC5,... ......

    uj5u.com 2020-09-09 22:15:18 more
  • WebAPI-HTTP編程模型

    帶著問題去思考,大家好!它是什么?它包含什么?它能干什么? 訊息 HTTP編程模型的核心就是訊息抽象,表示為:HttPRequestMessage,HttpResponseMessage.用于客戶端和服務端之間交換請求和回應訊息。 HttpMethod類包含了一組靜態屬性: private stat ......

    uj5u.com 2020-09-09 22:15:23 more
  • 部署WebApi隨筆

    一、跨域 NuGet參考Microsoft.AspNet.WebApi.Cors WebApiConfig.cs中配置: // Web API 配置和服務 config.EnableCors(new EnableCorsAttribute("*", "*", "*")); 二、清除默認回傳XML格式 ......

    uj5u.com 2020-09-09 22:15:48 more
最新发布
  • C#多執行緒學習(二) 如何操縱一個執行緒

    <a href="https://www.cnblogs.com/x-zhi/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/2943582/20220801082530.png" alt="" /></...

    uj5u.com 2023-04-19 09:17:20 more
  • C#多執行緒學習(二) 如何操縱一個執行緒

    C#多執行緒學習(二) 如何操縱一個執行緒 執行緒學習第一篇:C#多執行緒學習(一) 多執行緒的相關概念 下面我們就動手來創建一個執行緒,使用Thread類創建執行緒時,只需提供執行緒入口即可。(執行緒入口使程式知道該讓這個執行緒干什么事) 在C#中,執行緒入口是通過ThreadStart代理(delegate)來提供的 ......

    uj5u.com 2023-04-19 09:16:49 more
  • 記一次 .NET某醫療器械清洗系統 卡死分析

    <a href="https://www.cnblogs.com/huangxincheng/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/214741/20200614104537.png" alt="" /&g...

    uj5u.com 2023-04-18 08:39:04 more
  • 記一次 .NET某醫療器械清洗系統 卡死分析

    一:背景 1. 講故事 前段時間協助訓練營里的一位朋友分析了一個程式卡死的問題,回過頭來看這個案例比較經典,這篇稍微整理一下供后來者少踩坑吧。 二:WinDbg 分析 1. 為什么會卡死 因為是表單程式,理所當然就是看主執行緒此時正在做什么? 可以用 ~0s ; k 看一下便知。 0:000> k # ......

    uj5u.com 2023-04-18 08:33:10 more
  • SignalR, No Connection with that ID,IIS

    <a href="https://www.cnblogs.com/smartstar/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/u36196.jpg" alt="" /></a>...

    uj5u.com 2023-03-30 17:21:52 more
  • 一次對pool的誤用導致的.net頻繁gc的診斷分析

    <a href="https://www.cnblogs.com/dotnet-diagnostic/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/3115652/20230225090434.png" alt=""...

    uj5u.com 2023-03-28 10:15:33 more
  • 一次對pool的誤用導致的.net頻繁gc的診斷分析

    <a href="https://www.cnblogs.com/dotnet-diagnostic/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/3115652/20230225090434.png" alt=""...

    uj5u.com 2023-03-28 10:13:31 more
  • C#遍歷指定檔案夾中所有檔案的3種方法

    <a href="https://www.cnblogs.com/xbhp/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/957602/20230310105611.png" alt="" /></a&...

    uj5u.com 2023-03-27 14:46:55 more
  • C#/VB.NET:如何將PDF轉為PDF/A

    <a href="https://www.cnblogs.com/Carina-baby/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/2859233/20220427162558.png" alt="" />...

    uj5u.com 2023-03-27 14:46:35 more
  • 武裝你的WEBAPI-OData聚合查詢

    <a href="https://www.cnblogs.com/podolski/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/616093/20140323000327.png" alt="" /><...

    uj5u.com 2023-03-27 14:46:16 more