主頁 >
.NET開發 > 基于 abp vNext 和 .NET Core 開發博客專案 - Blazor 實戰系列(六)
基于 abp vNext 和 .NET Core 開發博客專案 - Blazor 實戰系列(六)
2020-09-12 02:36:08 .NET開發
系列文章
基于 abp vNext 和 .NET Core 開發博客專案 - 使用 abp cli 搭建專案
基于 abp vNext 和 .NET Core 開發博客專案 - 給專案瘦身,讓它跑起來
基于 abp vNext 和 .NET Core 開發博客專案 - 完善與美化,Swagger登場
基于 abp vNext 和 .NET Core 開發博客專案 - 資料訪問和代碼優先
基于 abp vNext 和 .NET Core 開發博客專案 - 自定義倉儲之增刪改查
基于 abp vNext 和 .NET Core 開發博客專案 - 統一規范API,包裝回傳模型
基于 abp vNext 和 .NET Core 開發博客專案 - 再說Swagger,分組、描述、小綠鎖
基于 abp vNext 和 .NET Core 開發博客專案 - 接入GitHub,用JWT保護你的API
基于 abp vNext 和 .NET Core 開發博客專案 - 例外處理和日志記錄
基于 abp vNext 和 .NET Core 開發博客專案 - 使用Redis快取資料
基于 abp vNext 和 .NET Core 開發博客專案 - 集成Hangfire實作定時任務處理
基于 abp vNext 和 .NET Core 開發博客專案 - 用AutoMapper搞定物件映射
基于 abp vNext 和 .NET Core 開發博客專案 - 定時任務最佳實戰(一)
基于 abp vNext 和 .NET Core 開發博客專案 - 定時任務最佳實戰(二)
基于 abp vNext 和 .NET Core 開發博客專案 - 定時任務最佳實戰(三)
基于 abp vNext 和 .NET Core 開發博客專案 - 博客介面實戰篇(一)
基于 abp vNext 和 .NET Core 開發博客專案 - 博客介面實戰篇(二)
基于 abp vNext 和 .NET Core 開發博客專案 - 博客介面實戰篇(三)
基于 abp vNext 和 .NET Core 開發博客專案 - 博客介面實戰篇(四)
基于 abp vNext 和 .NET Core 開發博客專案 - 博客介面實戰篇(五)
基于 abp vNext 和 .NET Core 開發博客專案 - Blazor 實戰系列(一)
基于 abp vNext 和 .NET Core 開發博客專案 - Blazor 實戰系列(二)
基于 abp vNext 和 .NET Core 開發博客專案 - Blazor 實戰系列(三)
基于 abp vNext 和 .NET Core 開發博客專案 - Blazor 實戰系列(四)
基于 abp vNext 和 .NET Core 開發博客專案 - Blazor 實戰系列(五)
基于 abp vNext 和 .NET Core 開發博客專案 - Blazor 實戰系列(六)
基于 abp vNext 和 .NET Core 開發博客專案 - Blazor 實戰系列(七)
基于 abp vNext 和 .NET Core 開發博客專案 - Blazor 實戰系列(八)
基于 abp vNext 和 .NET Core 開發博客專案 - Blazor 實戰系列(九)
基于 abp vNext 和 .NET Core 開發博客專案 - 終結篇之發布專案
上一篇完成了博客文章詳情頁面的資料展示和基于JWT方式的簡單身份驗證,本篇繼續推進,完成后臺分類管理的所有增刪改查等功能,
分類管理
在 Admin 檔案夾下新建Razor組件,Categories.razor,設定路由,@page "/admin/categories",將具體的展示內容放在組件AdminLayout中,
@page "/admin/categories"
<AdminLayout>
<Loading />
</AdminLayout>
在這里我會將所有分類展示出來,新增、更新、洗掉都會放在一個頁面上去完成,
先將串列查出來,添加API的回傳引數,private ServiceResult<IEnumerable<QueryCategoryForAdminDto>> categories;,然后再初始化中去獲取資料,
//QueryCategoryForAdminDto.cs
namespace Meowv.Blog.BlazorApp.Response.Blog
{
public class QueryCategoryForAdminDto : QueryCategoryDto
{
/// <summary>
/// 主鍵
/// </summary>
public int Id { get; set; }
}
}
/// <summary>
/// API回傳的分類串列資料
/// </summary>
private ServiceResult<IEnumerable<QueryCategoryForAdminDto>> categories;
/// <summary>
/// 初始化
/// </summary>
/// <returns></returns>
protected override async Task OnInitializedAsync()
{
var token = await Common.GetStorageAsync("token");
Http.DefaultRequestHeaders.Add("Authorization", $"Bearer {token}");
categories = await FetchData();
}
/// <summary>
/// 獲取資料
/// </summary>
/// <returns></returns>
private async Task<ServiceResult<IEnumerable<QueryCategoryForAdminDto>>> FetchData()
{
return await Http.GetFromJsonAsync<ServiceResult<IEnumerable<QueryCategoryForAdminDto>>>("/blog/admin/categories");
}
初始化的時候,需要將我們存在localStorage中的token讀取出來,因為我們后臺的API都需要添加 Authorization Header 請求頭才能成功回傳資料,
在Blazor添加請求頭也是比較方便的,直接Http.DefaultRequestHeaders.Add(...)即可,要注意的是 token值前面需要加 Bearer ,跟了一個空格不可以省略,
獲取資料單獨提成了一個方法FetchData(),因為會頻繁用到,現在在頁面上將資料系結進行展示,
@if (categories == null)
{
<Loading />
}
else
{
<div class="post-wrap categories">
<h2 class="post-title">- Categories -</h2>
@if (categories.Success && categories.Result.Any())
{
<div class="categories-card">
@foreach (var item in categories.Result)
{
<div class="card-item">
<div class="categories">
<NavLink title="?洗掉" @onclick="@(async () => await DeleteAsync(item.Id))">?</NavLink>
<NavLink title="??編輯" @onclick="@(() => ShowBox(item))">??</NavLink>
<NavLink target="_blank" href=https://www.cnblogs.com/meowv/p/"@($"/category/{item.DisplayName}")">
@item.CategoryName
(@item.Count)
}
ShowBox())">??~~~ 新增分類 ~~~??
}
else
{
}
}
同樣的當categories還沒成功獲取到資料的時候,我們直接在展示 <Loading />組件,然后就是回圈串列資料在foreach中進行系結資料,
在每條資料最前面,加了洗掉和編輯兩個按鈕,洗掉的時候呼叫DeleteAsync方法,將當前分類的Id傳給他即可,新增和編輯的時候呼叫ShowBox方法,他接受一個引數,當前回圈到的分類物件item,即QueryCategoryForAdminDto,
同時這里考慮到復用性,我寫了一個彈窗組件,Box.Razor,放在Shared檔案夾下面,可以先看一下標題為彈窗組件的內容再回來繼續往下看,
洗掉分類
接下來看看洗掉方法,
/// <summary>
/// 洗掉分類
/// </summary>
/// <param name="id"></param>
/// <returns></returns>
private async Task DeleteAsync(int id)
{
// 彈窗確認
bool confirmed = await Common.InvokeAsync<bool>("confirm", "\n????真的要干掉這個該死的分類嗎????");
if (confirmed)
{
var response = await Http.DeleteAsync($"/blog/category?id={id}");
var result = await response.Content.ReadFromJsonAsync<ServiceResult>();
if (result.Success)
{
categories = await FetchData();
}
}
}
洗掉之前搞個原生的confirm進行提示,避免手殘誤刪,因為API那邊使用的是HttpDelete,所有我們呼叫API時候要用Http.DeleteAsync,回傳的是HttpResponseMessage物件,需要我們手動處理接識訓傳資料,將其轉換為ServiceResult物件,如果判斷洗掉成功后重新呼叫FetchData()重繪分類資料,
新增/更新分類
新增和更新資料選擇使用彈窗的方式來進行(彈窗組件在下方),首先是需要一個引數判斷彈窗是否打開,因為是將新增和更新放在一起,所以如何判斷是新增還是更新呢?這里使用Id來進行判斷,當編輯的時候肯定會有Id引數,新增的時候是沒有引數傳遞的,
當我們打開彈窗后里面需要展示兩個input框,用來供輸入要保存的資料,同樣是添加兩個變數,
添加所需的這幾個引數,
/// <summary>
/// 默認隱藏Box
/// </summary>
private bool Open { get; set; } = false;
/// <summary>
/// 新增或者更新時候的分類欄位值
/// </summary>
private string categoryName, displayName;
/// <summary>
/// 更新分類的Id值
/// </summary>
private int id;
現在可以將Box組件添加到頁面上,
<div class="post-wrap categories">
...
</div>
<Box OnClickCallback="@SubmitAsync" Open="@Open">
<div class="box-item">
<b>DisplayName:</b><input type="text" @bind="@displayName" @bind:event="oninput" />
</div>
<div class="box-item">
<b>CategoryName:</b><input type="text" @bind="@categoryName" @bind:event="oninput" />
</div>
</Box>
確定按鈕回呼事件執行SubmitAsync()方法,打開狀態引數為上面添加的Open,按鈕文字ButtonText為默認值不填,
添加了兩個input,將兩個分類欄位分別系結上去,使用@bind和@bind:event,前者等價于設定其value值,后者等價于一個change事件當值改變后會重新賦給系結的欄位引數,
現在可以來看看點擊了新增或者編輯按鈕的方法ShowBox(...),接收一個引數QueryCategoryForAdminDto讓其默認值為null,
/// <summary>
/// 顯示box,系結欄位
/// </summary>
/// <param name="dto"></param>
private void ShowBox(QueryCategoryForAdminDto dto = null)
{
Open = true;
id = 0;
// 新增
if (dto == null)
{
displayName = null;
categoryName = null;
}
else // 更新
{
id = dto.Id;
displayName = dto.DisplayName;
categoryName = dto.CategoryName;
}
}
執行ShowBox()方法,將彈窗打開,設定Open = true;和初始化id的值id = 0;,
通過引數是否null進行判斷是新增還是更新,這樣打開彈窗就搞定了,剩下的就交給彈窗來處理了,
因為新增和更新API需要還對應的輸入引數EditCategoryInput,去添加它不要忘了,
那么現在就只差按鈕回呼事件SubmitAsync()了,主要是給輸入引數進行賦值呼叫API,執行新增或者更新即可,
/// <summary>
/// 確認按鈕點擊事件
/// </summary>
/// <returns></returns>
private async Task SubmitAsync()
{
var input = new EditCategoryInput()
{
DisplayName = displayName.Trim(),
CategoryName = categoryName.Trim()
};
if (string.IsNullOrEmpty(input.DisplayName) || string.IsNullOrEmpty(input.CategoryName))
{
return;
}
var responseMessage = new HttpResponseMessage();
if (id > 0)
responseMessage = await Http.PutAsJsonAsync($"/blog/category?id={id}", input);
else
responseMessage = await Http.PostAsJsonAsync("/blog/category", input);
var result = await responseMessage.Content.ReadFromJsonAsync<ServiceResult>();
if (result.Success)
{
categories = await FetchData();
Open = false;
}
}
當引數為空時,直接return什么都不執行,通過當前Id判斷是新增還是更新操作,呼叫不同的方法PutAsJsonAsync和PostAsJsonAsync去請求API,同樣回傳到是HttpResponseMessage物件,最后如果操作成功,重新請求一個資料,重繪分類串列,將彈窗關閉掉,
分類管理頁面的全部代碼如下:
點擊查看代碼
@page "/admin/categories"
<AdminLayout>
@if (categories == null)
{
<Loading />
}
else
{
<div class="post-wrap categories">
<h2 class="post-title">- Categories -</h2>
@if (categories.Success && categories.Result.Any())
{
<div class="categories-card">
@foreach (var item in categories.Result)
{
<div class="card-item">
<div class="categories">
<NavLink title="?洗掉" @onclick="@(async () => await DeleteAsync(item.Id))">?</NavLink>
<NavLink title="??編輯" @onclick="@(() => ShowBox(item))">??</NavLink>
<NavLink target="_blank" href=https://www.cnblogs.com/meowv/p/"@($"/category/{item.DisplayName}")">
@item.CategoryName
(@item.Count)
}
ShowBox())">??~~~ 新增分類 ~~~??
}
else
{
}
DisplayName:
CategoryName:
}
@code {
///
/// 默認隱藏Box
///
private bool Open { get; set; } = false;
///
/// 新增或者更新時候的分類欄位值
///
private string categoryName, displayName;
///
/// 更新分類的Id值
///
private int id;
///
/// API回傳的分類串列資料
///
private ServiceResult> categories;
///
/// 初始化
///
///
protected override async Task OnInitializedAsync()
{
var token = await Common.GetStorageAsync("token");
Http.DefaultRequestHeaders.Add("Authorization", $"Bearer {token}");
categories = await FetchData();
}
///
/// 獲取資料
///
///
private async Task>> FetchData()
{
return await Http.GetFromJsonAsync>>("/blog/admin/categories");
}
///
/// 洗掉分類
///
///
///
private async Task DeleteAsync(int id)
{
Open = false;
// 彈窗確認
bool confirmed = await Common.InvokeAsync("confirm", "\n????真的要干掉這個該死的分類嗎????");
if (confirmed)
{
var response = await Http.DeleteAsync($"/blog/category?id={id}");
var result = await response.Content.ReadFromJsonAsync();
if (result.Success)
{
categories = await FetchData();
}
}
}
///
/// 顯示box,系結欄位
///
///
private void ShowBox(QueryCategoryForAdminDto dto = null)
{
Open = true;
id = 0;
// 新增
if (dto == null)
{
displayName = null;
categoryName = null;
}
else // 更新
{
id = dto.Id;
displayName = dto.DisplayName;
categoryName = dto.CategoryName;
}
}
///
/// 確認按鈕點擊事件
///
///
private async Task SubmitAsync()
{
var input = new EditCategoryInput()
{
DisplayName = displayName.Trim(),
CategoryName = categoryName.Trim()
};
if (string.IsNullOrEmpty(input.DisplayName) || string.IsNullOrEmpty(input.CategoryName))
{
return;
}
var responseMessage = new HttpResponseMessage();
if (id > 0)
responseMessage = await Http.PutAsJsonAsync($"/blog/category?id={id}", input);
else
responseMessage = await Http.PostAsJsonAsync("/blog/category", input);
var result = await responseMessage.Content.ReadFromJsonAsync();
if (result.Success)
{
categories = await FetchData();
Open = false;
}
}
}
彈窗組件
考慮到新增和更新資料的時候需要彈窗,這里就簡單演示一下寫一個小組件,
在 Shared 檔案夾下新建一個Box.razor,
在開始之前分析一下彈窗組件所需的元素,彈窗肯定有一個確認和取消按鈕,右上角需要有一個關閉按鈕,關閉按鈕和取消按鈕一個意思,他還需要一個打開或者關閉的狀態,判斷是否打開彈窗,還有就是彈窗內需要自定義展示內容,
確定按鈕的文字可以自定義,所以差不多就需要3個引數,組件內容RenderFragment ChildContent,是否打開彈窗bool Open默認隱藏,按鈕文字string ButtonText默認值給"確定",然后最重要的是確定按鈕需要一個回呼事件,EventCallback<MouseEventArgs> OnClickCallback 用于執行不同的事件,
/// <summary>
/// 組件內容
/// </summary>
[Parameter]
public RenderFragment ChildContent { get; set; }
/// <summary>
/// 是否隱藏
/// </summary>
[Parameter]
public bool Open { get; set; } = true;
/// <summary>
/// 按鈕文字
/// </summary>
[Parameter]
public string ButtonText { get; set; } = "確定";
/// <summary>
/// 確認按鈕點擊事件回呼
/// </summary>
[Parameter]
public EventCallback<MouseEventArgs> OnClickCallback { get; set; }
/// <summary>
/// 關閉Box
/// </summary>
private void Close() => Open = false;
右上角關閉和取消按鈕直接在內部進行處理,執行Close()方法,將引數Open值設定為false即可,
對應的html如下,
@if (Open)
{
<div class="shadow"></div>
<div class="box">
<div class="close" @onclick="Close">?</div>
<div class="box-content">
@ChildContent
<div class="box-item box-item-btn">
<button class="box-btn" @onclick="OnClickCallback">@ButtonText</button>
<button class="box-btn btn-primary" @onclick="Close">取消</button>
</div>
</div>
</div>
}
關于樣式
下面是彈窗組件所需的樣式代碼,大家需要的自取,也可以直接去GitHub實時獲取最新的樣式檔案,
.box {
width: 600px;
height: 300px;
border-radius: 5px;
background-color: #fff;
position: fixed;
top: 50%;
left: 50%;
margin-top: -150px;
margin-left: -300px;
z-index: 997;
}
.close {
position: absolute;
right: 3px;
top: 2px;
cursor: pointer;
}
.shadow {
width: 100%;
height: 100%;
position: fixed;
left: 0;
top: 0;
z-index: 996;
background-color: #000;
opacity: 0.3;
}
.box-content {
width: 90%;
margin: 20px auto;
}
.box-item {
margin-top: 10px;
height: 30px;
}
.box-item b {
width: 130px;
display: inline-block;
}
.box-item input[type=text] {
padding-left: 5px;
width: 300px;
height: 30px;
}
.box-item label {
width: 100px;
white-space: nowrap;
}
.box-item input[type=radio] {
width: auto;
height: auto;
visibility: initial;
display: initial;
margin-right: 2px;
}
.box-item button {
height: 30px;
width: 100px;
}
.box-item-btn {
position: absolute;
right: 20px;
bottom: 20px;
}
.box-btn {
display: inline-block;
height: 30px;
line-height: 30px;
padding: 0 18px;
background-color: #5A9600;
color: #fff;
white-space: nowrap;
text-align: center;
font-size: 14px;
border: none;
border-radius: 2px;
cursor: pointer;
}
button:focus {
outline: 0;
}
.box-btn:hover {
opacity: .8;
filter: alpha(opacity=80);
color: #fff;
}
.btn-primary {
border: 1px solid #C9C9C9;
background-color: #fff;
color: #555;
}
.btn-primary:hover {
border-color: #5A9600;
color: #333;
}
.post-box {
width: 98%;
margin: 27px auto 0;
}
.post-box-item {
width: 100%;
height: 30px;
margin-bottom: 5px;
}
.post-box-item input {
width: 49.5%;
height: 30px;
padding-left: 5px;
border: 1px solid #ddd;
}
.post-box-item input:nth-child(1) {
float: left;
margin-right: 1px;
}
.post-box-item input:nth-child(2) {
float: right;
margin-left: 1px;
}
.post-box .box-item b {
width: auto;
}
.post-box .box-item input[type=text] {
width: 90%;
}
好了,分類模塊的功能都完成了,標簽和友情鏈接的管理界面還會遠嗎?這兩個模塊的做法和分類是一樣的,有興趣的可以自己動手完成,今天到這吧,未完待續...
開源地址:https://github.com/Meowv/Blog/tree/blog_tutorial
轉載請註明出處,本文鏈接:https://www.uj5u.com/net/9655.html
標籤:.NET Core
上一篇:.Net Core微服務入門全紀錄(三)——Consul-服務注冊與發現(下)
下一篇:如何參與 .NET 的開發和設計
標籤雲
熱門瀏覽
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
友情鏈接