Bugeto.Payments.ZarinPal
1.0.0
dotnet add package Bugeto.Payments.ZarinPal --version 1.0.0
NuGet\Install-Package Bugeto.Payments.ZarinPal -Version 1.0.0
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="Bugeto.Payments.ZarinPal" Version="1.0.0" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Bugeto.Payments.ZarinPal" Version="1.0.0" />
<PackageReference Include="Bugeto.Payments.ZarinPal" />
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add Bugeto.Payments.ZarinPal --version 1.0.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: Bugeto.Payments.ZarinPal, 1.0.0"
#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.
#:package Bugeto.Payments.ZarinPal@1.0.0
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=Bugeto.Payments.ZarinPal&version=1.0.0
#tool nuget:?package=Bugeto.Payments.ZarinPal&version=1.0.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
Bugeto.Payments.ZarinPal
کتابخانهای برای برقراری ارتباط تمیز و قابل تست با درگاه پرداخت زرینپال، همراه با نمونهی آماده در قالب برنامهی ASP.NET Core MVC.
امکانات
- ثبت درخواست پرداخت با پشتیبانی از متادیتا و جزئیات سبد خرید
- تولید آدرس هدایت کاربر به صفحهی پرداخت بر اساس محیط (Production یا Sandbox)
- وریفای تراکنش پس از بازگشت کاربر و دریافت اطلاعات کامل کارت و کد پیگیری
- استعلام وضعیت تراکنش از متد inquiry و بازیابی تراکنشهای تاییدنشده
- ثبت راحت سرویسها در DI با استفاده از متدهای اکستنشن
- تستهای واحد برای اطمینان از نگاشت صحیح پاسخهای زرین پال
- نمونهی MVC جهت اجرای سناریوی کامل پرداخت در محیط سندباکس
نحوه استفاده
ثبت سرویسها و پیکربندی
using Bugeto.Payments.ZarinPal.Abstractions;
using Bugeto.Payments.ZarinPal.Configuration;
using Bugeto.Payments.ZarinPal.Extensions;
using Bugeto.Payments.ZarinPal.Contracts.Requests;
var builder = WebApplication.CreateBuilder(args);
builder.Services.AddZarinPalGateway(options =>
{
options.MerchantId = "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx";
options.Environment = ZarinPalEnvironment.Sandbox;
});
var app = builder.Build();
app.MapPost("/payments/start", async (IZarinPalGateway gateway) =>
{
var request = new PaymentRequest
{
Amount = 50000,
Description = "تمدید اشتراک کاربر",
CallbackUrl = new Uri("https://example.com/payments/verify")
};
var response = await gateway.RequestPaymentAsync(request);
return response.IsSuccess ? Results.Redirect(response.Data!.PaymentUri!.ToString()) : Results.BadRequest(response.Errors);
});
ارسال درخواست حداقلی
var minimalRequest = new PaymentRequest
{
Amount = 10000,
Description = "خرید اعتبار",
CallbackUrl = new Uri("https://example.com/payments/verify")
};
var minimalResponse = await gateway.RequestPaymentAsync(minimalRequest);
ارسال درخواست کامل همراه همه پارامترها
var fullRequest = new PaymentRequest
{
Amount = 250000,
Description = "سبد خرید فروشگاه",
CallbackUrl = new Uri("https://example.com/payments/verify"),
Currency = "IRT",
Metadata = new PaymentMetadata
{
Mobile = "09120000000",
Email = "buyer@example.com",
OrderId = Guid.NewGuid().ToString("N")
},
Cart = new PaymentCartData
{
Items = new[]
{
new PaymentCartItem
{
Name = "دوره آموزش پیشرفته",
Amount = "150000",
Count = "1",
TotalAmount = "150000"
},
new PaymentCartItem
{
Name = "پکیج فایلهای دانلودی",
Amount = "50000",
Count = "2",
TotalAmount = "100000"
}
},
AddedCosts = new PaymentCartAddedCosts
{
Tax = "5000",
Payment = "2000",
Transport = "8000"
},
Deductions = new PaymentCartDeductions
{
Discount = "7000"
}
}
};
var fullResponse = await gateway.RequestPaymentAsync(fullRequest);
وریفای و استعلام وضعیت
if (minimalResponse.IsSuccess && minimalResponse.Data?.Authority is { } authority)
{
var verifyResult = await gateway.VerifyPaymentAsync(new PaymentVerificationRequest
{
Authority = authority,
Amount = minimalRequest.Amount
});
var inquiryResult = await gateway.InquiryPaymentAsync(new PaymentInquiryRequest
{
Authority = authority
});
}
var unverified = await gateway.GetUnverifiedPaymentsAsync();
اجرای نمونه MVC
cd Bugeto.Payments.ZarinPal.Sample.Mvc
ASPNETCORE_URLS=http://0.0.0.0:5000 dotnet run
مقادیر MerchantId در فایل appsettings.json به صورت پیشفرض برای محیط سندباکس تنظیم شده است. پس از اجرای برنامه، با مراجعه به آدرس /Payments میتوانید یک پرداخت آزمایشی انجام دهید و صفحهی «تراکنشهای تایید نشده» نیز برای مشاهده خروجی متد unVerified در دسترس است.
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net9.0 is compatible. 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. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
net9.0
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 9.0.0)
- Microsoft.Extensions.Http (>= 9.0.0)
- Microsoft.Extensions.Options (>= 9.0.0)
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 |
|---|---|---|
| 1.0.0 | 353 | 10/23/2025 |