eitaa logo
پروژه ASP.Net Core MVC (وب و سی شارپ)
120 دنبال‌کننده
168 عکس
38 ویدیو
376 فایل
❁﷽❁ آموزش 📖 برنامه نویسی ASP.Net Core MVC (وب و سی شارپ) Admin: @alialirezapanahi برنامه نویسی برنامه نویسی سی شارپ eitaa.com/sisharpapp برنامه نویسی وب eitaa.com/aspdatnet ویراستی virasty.com/alialirezapanahi آپارات aparat.com/alialirezapanahi
مشاهده در ایتا
دانلود
پروژه ASP.Net Core MVC (وب و سی شارپ)
افزودن به سبد خرید قسمت اول
بیایید کد را تحلیل کنیم و توضیحات هر بخش را مرور کنیم. این کد در namespace Test_Store.Domain.Entities.Carts قرار دارد و شامل دو کلاس Cart و CartItem است که سبد خرید و آیتم‌های سبد خرید را در یک فروشگاه اینترنتی مدیریت می‌کنند. کلاس Cart این کلاس نمایانگر یک سبد خرید است. csharp public class Cart : BaseEntity { public virtual User User { get; set; } public long? UserId { get; set; } public Guid BrowserId { get; set; } public bool Finished { get; set; } public ICollection<CartItem> CartItems { get; set; } } User (کاربر): این ویژگی به کاربر مرتبط با سبد خرید اشاره دارد. این رابطه به صورت مجازی (virtual) تعریف شده است، که به Entity Framework اجازه می‌دهد تا رابطه را به صورت lazy load مدیریت کند. UserId: شناسه کاربر مرتبط با سبد خرید. این مقدار می‌تواند null باشد، به این معنا که ممکن است سبد خرید بدون کاربر (مثلاً برای مهمان‌ها) ایجاد شود. BrowserId (شناسه مرورگر): یک GUID که به مرورگر کاربر اختصاص داده شده است. این ویژگی می‌تواند برای پیگیری سبد خرید کاربر حتی بدون ورود به سیستم استفاده شود. Finished (پایان یافته): یک مقدار بولی که نشان می‌دهد آیا سبد خرید کامل شده است (مثلاً خرید انجام شده است) یا خیر. CartItems (آیتم‌های سبد خرید): یک مجموعه از آیتم‌های سبد خرید که در این سبد خرید وجود دارند. این رابطه به صورت یک به چند تعریف شده است، یعنی یک سبد خرید می‌تواند چندین آیتم سبد خرید داشته باشد. کلاس CartItem این کلاس نمایانگر یک آیتم در سبد خرید است. csharp public class CartItem : BaseEntity { public virtual Product Product { get; set; } public long ProductId { get; set; } public int Count { get; set; } public int Price { get; set; } public virtual Cart Cart { get; set; } public long CartId { get; set; } } Product (محصول): این ویژگی به محصول مرتبط با آیتم سبد خرید اشاره دارد. این رابطه نیز به صورت مجازی (virtual) تعریف شده است تا Entity Framework بتواند به صورت lazy load این رابطه را مدیریت کند. ProductId: شناسه محصول مرتبط با آیتم سبد خرید. Count (تعداد): تعداد محصول در این آیتم سبد خرید. این مقدار نشان می‌دهد که چند واحد از محصول در سبد خرید قرار دارد. Price (قیمت): قیمت محصول در زمان اضافه شدن به سبد خرید. Cart (سبد خرید): این ویژگی به سبد خرید مرتبط با این آیتم اشاره دارد. این رابطه به صورت مجازی (virtual) تعریف شده است. CartId: شناسه سبد خرید مرتبط با این آیتم. نتیجه‌گیری این کلاس‌ها به همراه ویژگی‌هایشان، ساختار داده‌ای سبد خرید و آیتم‌های مرتبط با آن را در یک فروشگاه اینترنتی تعریف می‌کنند. با استفاده از این کلاس‌ها می‌توان سبد خرید کاربران را مدیریت کرد، آیتم‌ها را به سبد خرید اضافه کرد، تعداد آیتم‌ها را تغییر داد و سبد خرید را نهایی کرد.
پروژه ASP.Net Core MVC (وب و سی شارپ)
افزودن به سبد خرید قسمت اول
این کد مربوط به یک کلاس به نام CookiesManeger است که در namespace EndPoint.Site.Utilities قرار دارد. این کلاس شامل متدهایی برای مدیریت کوکی‌ها در ASP.NET Core است. بیایید هر متد را به صورت جداگانه توضیح دهیم. کلاس CookiesManeger متد Add این متد برای افزودن یک کوکی جدید به پاسخ HTTP استفاده می‌شود. csharp public void Add(HttpContext context, string token, string value) { context.Response.Cookies.Append(token, value, getCookieOptions(context)); } پارامترها: HttpContext context: زمینه درخواست HTTP. string token: نام کوکی. string value: مقدار کوکی. عملکرد: کوکی‌ای با نام token و مقدار value به پاسخ HTTP اضافه می‌کند. تنظیمات کوکی از متد getCookieOptions گرفته می‌شود. متد Contains این متد بررسی می‌کند که آیا کوکی با نام مشخصی در درخواست HTTP وجود دارد یا خیر. csharp public bool Contains(HttpContext context, string token) { return context.Request.Cookies.ContainsKey(token); } پارامترها: HttpContext context: زمینه درخواست HTTP. string token: نام کوکی. عملکرد: بررسی می‌کند که آیا کوکی با نام token در درخواست HTTP وجود دارد یا خیر و نتیجه را به صورت بولی برمی‌گرداند. متد GetValue این متد مقدار کوکی با نام مشخص را از درخواست HTTP برمی‌گرداند. csharp public string GetValue(HttpContext context, string token) { string cookieValue; if (!context.Request.Cookies.TryGetValue(token, out cookieValue)) { return null; } return cookieValue; } پارامترها: HttpContext context: زمینه درخواست HTTP. string token: نام کوکی. عملکرد: تلاش می‌کند مقدار کوکی با نام token را از درخواست HTTP دریافت کند. اگر کوکی موجود باشد، مقدار آن را برمی‌گرداند؛ در غیر این صورت، null برمی‌گرداند. متد Remove این متد کوکی با نام مشخص را از درخواست HTTP حذف می‌کند. csharp public void Remove(HttpContext context, string token) { if (context.Request.Cookies.ContainsKey(token)) { context.Response.Cookies.Delete(token); } } پارامترها: HttpContext context: زمینه درخواست HTTP. string token: نام کوکی. عملکرد: بررسی می‌کند که آیا کوکی با نام token در درخواست HTTP وجود دارد یا خیر. اگر کوکی موجود باشد، آن را حذف می‌کند. متد GetBrowserId این متد شناسه مرورگر (BrowserId) را دریافت می‌کند. اگر شناسه مرورگر وجود نداشته باشد، یک شناسه جدید ایجاد کرده و آن را به کوکی اضافه می‌کند. csharp public Guid GetBrowserId(HttpContext context) { string browserId = GetValue(context, "BowserId"); if (browserId == null) { string value = Guid.NewGuid().ToString(); Add(context, "BowserId", value); browserId = value; } Guid guidBowser; Guid.TryParse(browserId, out guidBowser); return guidBowser; } پارامترها: HttpContext context: زمینه درخواست HTTP. عملکرد: تلاش می‌کند مقدار کوکی BowserId را دریافت کند. اگر کوکی موجود نباشد، یک شناسه جدید ایجاد کرده و آن را به کوکی اضافه می‌کند. سپس شناسه مرورگر را به صورت Guid برمی‌گرداند. متد getCookieOptions این متد تنظیمات کوکی را برای افزودن به پاسخ HTTP ایجاد می‌کند. csharp private CookieOptions getCookieOptions(HttpContext context) { return new CookieOptions { HttpOnly = true, Path = context.Request.PathBase.HasValue ? context.Request.PathBase.ToString() : "/", Secure = context.Request.IsHttps, Expires = DateTime.Now.AddDays(100), }; } پارامترها: HttpContext context: زمینه درخواست HTTP. عملکرد: یک شیء CookieOptions جدید ایجاد می‌کند با تنظیمات زیر: HttpOnly: فقط از طریق HTTP قابل دسترسی باشد، نه از طریق جاوااسکریپت. Path: مسیر کوکی. Secure: کوکی فقط در درخواست‌های HTTPS ارسال شود. Expires: تاریخ انقضای کوکی (100 روز از تاریخ فعلی). نتیجه‌گیری این کلاس ابزاری را فراهم می‌کند برای مدیریت کوکی‌ها در ASP.NET Core، از جمله افزودن، حذف، بررسی وجود، و دریافت مقدار کوکی‌ها. این ابزار به شما امکان می‌دهد که به راحتی کوکی‌ها را در برنامه وب خود مدیریت کنید.
پروژه ASP.Net Core MVC (وب و سی شارپ)
افزودن به سبد خرید قسمت اول
بیایید این کد را تحلیل کنیم و توضیحات مربوط به هر بخش از کنترلر CartController را مرور کنیم. این کنترلر به عنوان یک رابط برای مدیریت سبد خرید در برنامه ASP.NET Core عمل می‌کند و شامل عملیاتی مانند افزودن محصول به سبد خرید، حذف محصول، افزایش و کاهش تعداد محصول و مشاهده سبد خرید کاربر است. فضای نام‌ها و وابستگی‌ها csharp using EndPoint.Site.Utilities; using Microsoft.AspNetCore.Mvc; using Test_Store.Application.Services.Carts; EndPoint.Site.Utilities: برای استفاده از کلاس CookiesManeger. Microsoft.AspNetCore.Mvc: برای استفاده از کنترلرها و متدهای مربوط به MVC. Test_Store.Application.Services.Carts: برای استفاده از سرویس‌های مربوط به سبد خرید. تعریف کلاس CartController csharp namespace EndPoint.Site.Controllers { public class CartController : Controller { private readonly ICartService _cartService; private readonly CookiesManeger cookiesManeger; public CartController(ICartService cartService) { _cartService = cartService; cookiesManeger = new CookiesManeger(); } متغیرهای خصوصی: _cartService: یک سرویس برای مدیریت عملیات‌های سبد خرید. cookiesManeger: یک شیء از کلاس CookiesManeger برای مدیریت کوکی‌ها. سازنده: سازنده کلاس، ICartService را به عنوان وابستگی دریافت کرده و آن را به _cartService اختصاص می‌دهد. همچنین یک نمونه از CookiesManeger ایجاد می‌کند. متد Index csharp public IActionResult Index() { var resultGetLst = _cartService.GetMyCart(cookiesManeger.GetBrowserId(HttpContext)); return View(resultGetLst.Data); } عملکرد: شناسه مرورگر (BrowserId) کاربر را از کوکی‌ها دریافت می‌کند. با استفاده از سرویس _cartService، سبد خرید کاربر را دریافت می‌کند. داده‌های سبد خرید را به ویو ارسال می‌کند. متد AddToCart csharp public IActionResult AddToCart(long ProductId) { var resultAdd = _cartService.AddToCart(ProductId, cookiesManeger.GetBrowserId(HttpContext)); return RedirectToAction("Index"); } عملکرد: شناسه مرورگر (BrowserId) کاربر را از کوکی‌ها دریافت می‌کند. محصول مورد نظر را به سبد خرید کاربر اضافه می‌کند. کاربر را به صفحه Index ریدایرکت می‌کند. متد Add csharp public IActionResult Add(long CartItemId) { _cartService.Add(CartItemId); return RedirectToAction("Index"); } عملکرد: تعداد آیتم مشخص در سبد خرید را افزایش می‌دهد. کاربر را به صفحه Index ریدایرکت می‌کند. متد LowOff csharp public IActionResult LowOff(long CartItemId) { _cartService.LowOff(CartItemId); return RedirectToAction("Index"); } عملکرد: تعداد آیتم مشخص در سبد خرید را کاهش می‌دهد. کاربر را به صفحه Index ریدایرکت می‌کند. متد Remove csharp public IActionResult Remove(long ProductId) { _cartService.RemoveFromCart(ProductId, cookiesManeger.GetBrowserId(HttpContext)); return RedirectToAction("Index"); } عملکرد: شناسه مرورگر (BrowserId) کاربر را از کوکی‌ها دریافت می‌کند. محصول مشخص را از سبد خرید کاربر حذف می‌کند. کاربر را به صفحه Index ریدایرکت می‌کند. نتیجه‌گیری این کنترلر به عنوان واسطی برای مدیریت عملیات‌های مختلف مرتبط با سبد خرید در برنامه ASP.NET Core عمل می‌کند. از سرویس‌های سبد خرید (ICartService) و مدیریت کوکی‌ها (CookiesManeger) برای انجام عملیات‌ها و پیگیری سبد خرید کاربر استفاده می‌کند.
پروژه ASP.Net Core MVC (وب و سی شارپ)
افزودن به سبد خرید قسمت اول
بیایید کد مربوط به نمایش سبد خرید در ویو را بررسی و توضیح دهیم. این کد یک ویو Razor است که از مدل CartDto برای نمایش سبد خرید کاربر استفاده می‌کند. تعریف مدل و تنظیمات csharp @using Test_Store.Application.Services.Carts; @model CartDto @{ ViewData["Title"] = "Index"; Layout = "~/Views/Shared/_Layout.cshtml"; int sumTota = 0; } @using Test_Store.Application.Services.Carts: استفاده از فضای نام برای دسترسی به مدل‌ها و سرویس‌های مربوط به سبد خرید. @model CartDto: تعریف مدل ویو که از نوع CartDto است. ViewData["Title"]: تنظیم عنوان صفحه. Layout: تعیین لایوت (چیدمان) صفحه. int sumTota: تعریف یک متغیر محلی برای مجموع کل قیمت‌ها. نمایش سبد خرید html <section class="cart-home"> <div class="post-item-cart d-block order-2"> <div class="content-page"> <div class="cart-form"> <form action="#" class="c-form"> <table class="table-cart cart table table-borderless"> <thead> <tr> <th scope="col" class="product-cart-name">نام محصول</th> <th scope="col" class="product-cart-quantity">تعداد مورد نیاز</th> <th scope="col" class="product-cart-price">قیمت</th> <th scope="col" class="product-cart-Total">مجموع</th> </tr> </thead> <tbody> @foreach (var item in Model.CartItems) { <tr> <th scope="row" class="product-cart-name"> <div class="product-thumbnail-img"> <a href="#"> <img src="~/@item.Images"> </a> <div class="product-remove"> <a href="~/cart/remove?ProductId=@item.Id" class="remove"> <i class="mdi mdi-close"></i> </a> </div> </div> <div class="product-title"> <a href="#"> @item.Product </a> </div> </th> <td class="product-cart-quantity"> <div class="required-number before"> <div class="quantity"> <input type="number" min="1" max="100" step="1" value="@item.Count" id="count-@item.Id"> <div class="quantity-nav"> <div class="quantity-button quantity-up" onclick="AddCount('@item.Id')">+</div> <div class="quantity-button quantity-down" onclick="lowCount('@item.Id')">-</div> </div> </div> </div> </td> <td class="product-cart-price"> <span class="amount"> @item.Price.ToString("n0") <span>تومان</span> </span> </td> <td class="product-cart-Total"> <span class="amount"> @{
پروژه ASP.Net Core MVC (وب و سی شارپ)
افزودن به سبد خرید قسمت اول
int total = item.Price * item.Count; } @total.ToString("n0") <span>تومان</span> </span> </td> </tr> } </tbody> </table> </form> </div> جدول سبد خرید: شامل ستون‌هایی برای نام محصول، تعداد مورد نیاز، قیمت و مجموع است. @foreach: حلقه‌ای برای تکرار آیتم‌های موجود در سبد خرید و نمایش آن‌ها. مجموع قیمت هر آیتم: محاسبه مجموع قیمت هر آیتم با ضرب قیمت واحد در تعداد و نمایش آن. نمایش جمع کل سبد خرید و گزینه‌های حمل و نقل html <div class="cart-collaterals"> <div class="totals d-block"> <h3 class="Total-cart-total">مجموع کل سبد خرید</h3> <div class="checkout-summary"> <ul class="checkout-summary-summary"> <li class="cart-subtotal"> <span class="amount">قیمت کل</span> <span> @sumTota.ToString("n0") تومان</span> </li> <li class="shipping-totals"> <span class="amount">حمل و نقل</span> <div class="shipping-totals-item"> <div class="shipping-totals-outline"> <label for="#" class="outline-radio"> <input type="radio" name="payment_method" id="payment-option-online" checked="checked"> <span class="outline-radio-check"></span> </label> <label for="#" class="shipping-totals-title-row"> <div class="shipping-totals-title">حمل و نقل رایگان</div> </label> </div> <div class="shipping-totals-outline"> <label for="#" class="outline-radio"> <input type="radio" name="payment_method" id="payment-option-online"> <span class="outline-radio-check"></span> </label> <label for="#" class="shipping-totals-title-row"> <div class="shipping-totals-title">حمل و نقل معمولی: 20,000 تومان</div> </label> </div> <span class="shipping-destination">حمل و نقل به خراسان شمالی</span> </div> </li> <li class="order-total"> <span class="amount"> مجموع</span> <span> 6,032,000 تومان</span> </li> <li class="discount-code"> <div class=" align-items-center"> <div class="col-md-7 pr mt-5"> <div class="coupon"> <form action="#"> <input type="text" name="input-coupon" class="input-coupon-code" placeholder="كد تخفیف:"> <button class="btn btn-coupon" type="submit">اعمال</button> </form> </div> </div>
پروژه ASP.Net Core MVC (وب و سی شارپ)
افزودن به سبد خرید قسمت اول
<div class="col-md-2 pl mt-5"> <div class="proceed-to-checkout"> <a href="#" class="checkout-button d-block">تسویه حساب</a> </div> </div> </div> </li> </ul> </div> </div> </div> </div> </div> </section> مجموع کل سبد خرید: شامل بخش‌هایی برای نمایش قیمت کل، هزینه حمل و نقل و مجموع نهایی. گزینه‌های حمل و نقل: شامل گزینه‌های حمل و نقل رایگان و حمل و نقل معمولی است. کد تخفیف: یک فرم برای وارد کردن کد تخفیف و اعمال آن. دکمه تسویه حساب: دکمه‌ای برای انتقال به صفحه تسویه حساب. اسکریپت‌ها csharp @section Scripts { <script> function AddCount(CartItemId) { window.location.replace('/cart/add?CartItemId=' + CartItemId); } function lowCount(CartItemId) { window.location.replace('/cart/LowOff?CartItemId=' + CartItemId); } </script> } افزایش تعداد آیتم: فراخوانی متد AddCount با استفاده از شناسه آیتم. کاهش تعداد آیتم: فراخوانی متد lowCount با استفاده از شناسه آیتم. نتیجه‌گیری این ویو Razor یک صفحه کامل برای نمایش و مدیریت سبد خرید کاربر است. شامل نمایش آیتم‌های موجود در سبد خرید، محاسبه مجموع قیمت‌ها، نمایش گزینه‌های حمل و نقل، اعمال کد تخفیف و امکان تسویه حساب است.
Cookie management.zip
حجم: 2.5M
پروژه کوچک مدیریت کوکی که فقط در همین پروژه کوکی ساخته میشود و حذف کرد
برای دیدن کوکی روی صفحه مرورگر کلیک راست کرده و بازرسی Inspect را بزنید و در بخش application و زیر منوی cookies ، کوکی ها را مشاهده میکنید که هر سایتی کوکی جداگانه ای دارد
Test_Store 16.zip
حجم: 57M
افزودن به سبد قسمت دوم من را ببخشید نتوانستم از صفحه تست زرین پال ارتباط برقرار کنم بعدا من بیشتر برسی کنم که مشکل کجاست و اینکه من تا بعد عید نمیتوانم آموزش بگذارم شاید در عید اگر وقت کردم آموزش میگذارم تا بعد عید از صبر شکیبایی متشکرم من کد ها را توضیح نمیدهم چون نتوانستم ارتباط با صفحه تست زرین پال برقرار کنم، خودتان کدها را برسی کنید و اگر مشکل را حل کردید در ایتا به من پیام دهید چند تا جدول هم اضافه شده که مایگریشن جدید و آپدیت دیتابیس لینک سایت و نمونه کدها: https://www.zarinpal.com/lab/category/samplecode/ اگر لینک باز نشد، لینک را کپی و در مرورگر پیس کن تا لینک باز شود
zarinpalasp.netcorerest.zip
حجم: 9.6M
سلام پروژه تصحح شده زرین پال هست که به صفحه تست بانک زرین وصل می شود نکته مهم : برنامه فقط یک بار اجرا می شود و نمیتونید به صفحه قبل برگردید و دوباره تست کنید. شما پس از انصراف یا پرداخت موفق به صفحه پرداخت برگشته‌اید و به دلیل مسائل امنیتی، سشن (session) پرداخت قبلی به پایان رسیده و دیگر نمی‌توان از آن استفاده کرد. این یک مکانیزم امنیتی استاندارد است تا از پرداخت‌های تکراری یا مشکلات مرتبط با سشن‌های نامعتبر جلوگیری شود.
پروژه ASP.Net Core MVC (وب و سی شارپ)
سلام پروژه تصحح شده زرین پال هست که به صفحه تست بانک زرین وصل می شود نکته مهم : برنامه فقط یک بار ا
بیایید این کد را قدم به قدم توضیح دهیم. شرح کد: این کد یک کلاس به نام RequestParameters در فضای نام zarinpalasp.netcorerest.Models ایجاد می‌کند. این کلاس برای نگهداری پارامترهای مربوط به درخواست پرداخت از زرین‌پال استفاده می‌شود. جزئیات کد: فضای نام و استفاده‌ها: csharp using System; using System.Collections.Generic; using System.Linq; using System.Threading.Tasks; این خطوط از کد، فضاهای نام مورد نیاز برای عملکرد برنامه را وارد می‌کنند. تعریف کلاس: csharp namespace zarinpalasp.netcorerest.Models { public class RequestParameters { کلاس RequestParameters در فضای نام zarinpalasp.netcorerest.Models تعریف شده است. خصوصیات کلاس: csharp public string merchant_id { get; set; } public string amount { get; set; } public string description { get; set; } public string callback_url { get; set; } public string[]? metadata { get; set; } این خصوصیات پارامترهای مختلف مربوط به درخواست پرداخت را تعریف می‌کنند: merchant_id: شناسه تاجر. amount: مقدار پرداخت. description: توضیح درباره پرداخت. callback_url: URL بازگشتی برای تأیید یا لغو پرداخت. metadata: اطلاعات اضافه‌ای که می‌تواند شامل موبایل و ایمیل باشد. سازنده کلاس: csharp public RequestParameters(string merchant_id, string amount, string description, string callback_url, string? mobile, string? email) { this.merchant_id = merchant_id; this.amount = amount; this.description = description; this.callback_url = callback_url; this.metadata = new string[2]; if (mobile != null) { this.metadata[0] = mobile; } if (email != null) { this.metadata[1] = email; } } سازنده کلاس RequestParameters پارامترهای ورودی را می‌پذیرد و آن‌ها را به خصوصیات کلاس اختصاص می‌دهد. همچنین، آرایه metadata را مقداردهی اولیه می‌کند و در صورت وجود مقادیر موبایل و ایمیل، آن‌ها را به آرایه metadata اضافه می‌کند. تبدیل ضمنی: csharp public static implicit operator RestSharp.RequestParameters(RequestParameters v) { throw new NotImplementedException(); } این خط از کد یک تبدیل ضمنی (implicit) از RequestParameters به RestSharp.RequestParameters تعریف می‌کند. اما چون پیاده‌سازی نشده، یک استثنای NotImplementedException پرتاب می‌کند. نتیجه‌گیری کلاس RequestParameters برای نگهداری پارامترهای مربوط به درخواست پرداخت از زرین‌پال استفاده می‌شود. این کلاس شامل پارامترهای مهمی مانند merchant_id, amount, description, callback_url, و metadata (که می‌تواند موبایل و ایمیل باشد) است.