ASP.NET MVC (Fatura Kayıtları) - Controller

  • 659
  • (1)
  • (5)
  • 06 Şub 2018

InvoicesWeb uygulamasında şu anki noktaya kadar müşteri kayıtlarını işleyebileceğiniz CustomerController oluşturuldu. Faturalar için iki ayrı controller oluşturulabilir. Fatura genel bilgileri için InvoiceController, fatura satırları içinse InvoiceLineController oluşturulabilir.

Bu işlemler için gereken prosedürler InvoiceDB içerisinde tanımlanmış halde bulunuyor. CustomerModel veri türünün içinde bulunduğu Models dizini içerisine iki adet veri modeli daha oluşturun.

InvoiceModel ve InvoiceLineModel sınıfları fatura ve fatura satırlarını temsil eden veri modelleri olarak kullanılacaktır.

DBHelper sınıfı içerisine iki metot daha ekleyin. Bu metotlar (GetInvoice ve ListInvoices) tek bir faturayı veritabanından çekmek ve veritabanındaki faturaları listelemek için kullanılacak.


// Tek bir fatura kaydını almak için
public async Task<InvoiceModel> GetInvoice(int id)
{
    InvoiceModel invoice = new InvoiceModel() { InvoiceId = id };
    var connection = await OpenConnection();
    var command = invoice.ToGetOneCommand(connection);
    var dataReader = await command.ExecuteReaderAsync();
    while (await dataReader.ReadAsync())
    {
        invoice.GetFromDataReader(dataReader);
    }
    CloseConnection(connection);
    return invoice;
}

// Faturaları Listelemek için kullanılan sorgu
public async Task<IEnumerable<InvoiceModel>> ListInvoices()
{
    var connection = await OpenConnection();
    var command = new SqlCommand(@"
        select colInvoiceID, colInvoiceNumber, colTitle, i.colCustomerID, c.colName as colCustomerName, 
            i.colAddress, i.colInvoiceStatusID, s.colInvoiceStatus, i.colInvoiceTypeID, it.colInvoiceType, 
            i.colPaymentTypeID, p.colPaymentType, colPaymentDate,
            colCreateDateTime, i.colUserID, u.colFullName as colUserName
        from tblInvoices i
            left join tblInvoiceTypes it on i.colInvoiceTypeID = it.colInvoiceTypeID
            left join tblInvoiceStatuses s on i.colInvoiceStatusID = s.colInvoiceStatusID
            left join tblPaymentTypes p on i.colPaymentTypeID = p.colPaymentTypeID
            left join tblCustomers c on i.colCustomerID = c.colCustomerID
            left join tblUsers u on u.colUserID = i.colUserID", connection);
    var dataReader = await command.ExecuteReaderAsync();
    List<InvoiceModel> invoices = new List<InvoiceModel>();
    while (await dataReader.ReadAsync())
    {
        InvoiceModel invoice = new InvoiceModel();
        invoice.GetFromDataReader(dataReader);
        invoices.Add(invoice);
    }
    CloseConnection(connection);
    return invoices;
}

InvoiceModel sınıfı tıpkı CustomerModel sınıfı gibi IProcedure arabirimini kullanan bir sınıf olmalıdır.


public class InvoiceModel: IProcedure
{
    public int InvoiceId { get; set; }
    [Display(Name = "Fatura No")]
    public string InvoiceNumber { get; set; }
    [Display(Name = "Başlık")]
    public string Title { get; set; }
    [Display(Name = "Müşteri")]
    public int CustomerId { get; set; }
    [Display(Name = "Müşteri")]
    public string CustomerName { get; set; }
    [Display(Name = "Adres")]
    public string Address { get; set; }
    [Display(Name = "Fatura Durumu")]
    public int InvoiceStatusId { get; set; }
    [Display(Name = "Fatura Durumu")]
    public string InvoiceStatus { get; set; }
    [Display(Name = "Fatura Türü")]
    public int InvoiceTypeId { get; set; }
    [Display(Name = "Fatura Türü")]
    public string InvoiceType { get; set; }
    [Display(Name = "Ödeme Türü")]
    public int PaymentTypeId { get; set; }
    [Display(Name = "Ödeme Türü")]
    public string PaymentType { get; set; }
    [Display(Name = "Ödeme Tarihi")]
    public DateTime PaymentDate { get; set; }
    [Display(Name = "Oluşturulma")]
    public DateTime CreateDateTime { get; set; }
    [Display(Name = "Kullanıcı")]
    public int UserId { get; set; }
    [Display(Name = "Kullanıcı")]
    public string User { get; set; }
    public List<InvoiceLineModel> Lines { get; set; }

    public void GetFromDataReader(SqlDataReader dataReader)
    {
        InvoiceId = Convert.ToInt32(dataReader["colInvoiceID"]);
        InvoiceNumber = dataReader["colInvoiceNumber"].ToString();
        Title = dataReader["colTitle"].ToString();
        CustomerId = Convert.ToInt32(dataReader["colCustomerID"]);
        Address = dataReader["colAddress"].ToString();
        InvoiceTypeId = Convert.ToInt32(dataReader["colInvoiceTypeID"]);
        InvoiceStatusId = Convert.ToInt32(dataReader["colInvoiceStatusID"]);
        PaymentTypeId = Convert.ToInt32(dataReader["colPaymentTypeID"]);
        InvoiceType = dataReader["colInvoiceType"].ToString();
        InvoiceStatus = dataReader["colInvoiceStatus"].ToString();
        PaymentType = dataReader["colPaymentType"].ToString();
        PaymentDate = Convert.ToDateTime(dataReader["colPaymentDate"]);
        CreateDateTime = Convert.ToDateTime(dataReader["colCreateDateTime"]);
        UserId = Convert.ToInt32(dataReader["colUserID"]);
        User = dataReader["colUserName"].ToString();
    }
    
    public SqlCommand ToCreateCommand(SqlConnection connection)
    {
        SqlCommand command = new SqlCommand("dbo.procCreateInvoice", connection)
        { CommandType = System.Data.CommandType.StoredProcedure };
        command.Parameters.AddRange(new SqlParameter[] { PrmInvoiceNumber, PrmTitle, PrmCustomerId,
            PrmAddress, PrmInvoiceStatusId, PrmInvoiceTypeId, PrmPaymentTypeId, PrmUserId, PrmPaymentDate });
        return command;
    }

    public SqlCommand ToUpdateCommand(SqlConnection connection)
    {
        SqlCommand command = new SqlCommand("dbo.procUpdateInvoice", connection)
        { CommandType = System.Data.CommandType.StoredProcedure };
        command.Parameters.AddRange(new SqlParameter[] { PrmInvoiceId, PrmInvoiceNumber, PrmTitle, PrmCustomerId,
            PrmAddress, PrmInvoiceStatusId, PrmInvoiceTypeId, PrmPaymentTypeId, PrmPaymentDate });
        return command;
    }

    public SqlCommand ToDeleteCommand(SqlConnection connection)
    {
        SqlCommand command = new SqlCommand("dbo.procDeleteInvoice", connection)
        { CommandType = System.Data.CommandType.StoredProcedure };
        command.Parameters.AddRange(new SqlParameter[] { PrmInvoiceId });
        return command;
    }

    public SqlCommand ToGetOneCommand(SqlConnection connection)
    {
        SqlCommand command = new SqlCommand(@"
            select colInvoiceID, colInvoiceNumber, colTitle, i.colCustomerID, c.colName as colCustomerName, 
                i.colAddress, i.colInvoiceStatusID, s.colInvoiceStatus, i.colInvoiceTypeID, it.colInvoiceType, 
                i.colPaymentTypeID, p.colPaymentType, colPaymentDate,
                colCreateDateTime, i.colUserID, u.colFullName as colUserName
            from tblInvoices i
                left join tblInvoiceTypes it on i.colInvoiceTypeID = it.colInvoiceTypeID
                left join tblInvoiceStatuses s on i.colInvoiceStatusID = s.colInvoiceStatusID
                left join tblPaymentTypes p on i.colPaymentTypeID = p.colPaymentTypeID
                left join tblCustomers c on i.colCustomerID = c.colCustomerID
                left join tblUsers u on u.colUserID = i.colUserID
            where colInvoiceID = @_invoiceId
            select colInvoiceLineID, colDescription, colUnit, colPrice, colVatRatio 
            from tblInvoiceLines 
            where colInvoiceID = @_invoiceId", connection);
        command.Parameters.Add(PrmInvoiceId);
        return command;
    }

    private SqlParameter PrmInvoiceId { get { return new SqlParameter("@_invoiceID", System.Data.SqlDbType.Int) { Value = InvoiceId }; } }
    private SqlParameter PrmInvoiceNumber { get { return new SqlParameter("@_invoiceNumber", System.Data.SqlDbType.VarChar, 16) { Value = InvoiceNumber ?? "" }; } }
    private SqlParameter PrmCustomerId { get { return new SqlParameter("@_customerID", System.Data.SqlDbType.Int) { Value = CustomerId }; } }
    private SqlParameter PrmAddress { get { return new SqlParameter("@_address", System.Data.SqlDbType.NVarChar, 256) { Value = Address ?? "" }; } }
    private SqlParameter PrmTitle { get { return new SqlParameter("@_title", System.Data.SqlDbType.NVarChar, 64) { Value = Title ?? (object)DBNull.Value }; } }
    private SqlParameter PrmInvoiceTypeId { get { return new SqlParameter("@_invoiceTypeID", System.Data.SqlDbType.Int) { Value = InvoiceTypeId }; } }
    private SqlParameter PrmInvoiceStatusId { get { return new SqlParameter("@_invoiceStatusID", System.Data.SqlDbType.Int) { Value = InvoiceStatusId }; } }
    private SqlParameter PrmPaymentTypeId { get { return new SqlParameter("@_paymentTypeID", System.Data.SqlDbType.Int) { Value = PaymentTypeId }; } }
    private SqlParameter PrmPaymentDate { get { return new SqlParameter("@_paymentDate", System.Data.SqlDbType.Date) { Value = PaymentDate }; } }
    private SqlParameter PrmUserId { get { return new SqlParameter("@_userID", System.Data.SqlDbType.Int) { Value = UserId }; } }
}

Bu sınıfın yanı sıra oluşturma ve düzenleme sayfalarına çekilecek sabit veriler (Fatura Türü, Fatura Durumu, Ödeme Türü) için de aynı dosyada sınıflar oluşturun.


public class InvoiceTypeModel
{
    public int Id { get; set; }
    public string Value { get; set; }

    public void GetFromDataReader(SqlDataReader dataReader)
    {
        Id = Convert.ToInt32(dataReader["colInvoiceTypeID"]);
        Value = dataReader["colInvoiceType"].ToString();
    }
}

public class InvoiceStatusModel
{
    public int Id { get; set; }
    public string Value { get; set; }

    public void GetFromDataReader(SqlDataReader dataReader)
    {
        Id = Convert.ToInt32(dataReader["colInvoiceStatusID"]);
        Value = dataReader["colInvoiceStatus"].ToString();
    }
}

public class PaymentTypeModel
{
    public int Id { get; set; }
    public string Value { get; set; }

    public void GetFromDataReader(SqlDataReader dataReader)
    {
        Id = Convert.ToInt32(dataReader["colPaymentTypeID"]);
        Value = dataReader["colPaymentType"].ToString();
    }
}

public class InvoiceCustomerModel
{
    public int Id { get; set; }
    public string Value { get; set; }

    public void GetFromDataReader(SqlDataReader dataReader)
    {
        Id = Convert.ToInt32(dataReader["colCustomerID"]);
        Value = dataReader["colName"].ToString();
    }
}

public class InvoiceValuesModel
{
    public List<InvoiceTypeModel> InvoiceTypes { get; set; }
    public List<InvoiceStatusModel> InvoiceStatuses { get; set; }
    public List<PaymentTypeModel> PaymentTypes { get; set; }
    public List<InvoiceCustomerModel> InvoiceCustomers { get; set; }

    public InvoiceValuesModel() { InvoiceTypes = new List<InvoiceTypeModel>(); InvoiceStatuses = new List<InvoiceStatusModel>(); PaymentTypes = new List<PaymentTypeModel>(); }
}

Veritabanından nasıl veri çekileceği CustomerModel sınıfı ile aynı mantıkta işlemektedir. Ardından faturalar için oluşturulacak controller içerisinde aynı metotlar kullanılacaktır.


public class InvoiceController : Controller
{
    public async Task<ActionResult> List()
    {
        DBHelper db = new DBHelper();
        ViewBag.Invoices = await db.ListInvoices();
        return View();
    }

    public async Task<ActionResult> Create()
    {
        DBHelper db = new DBHelper();
        ViewBag.InvoiceValues = await db.GetInvoiceValues();
        return View();
    }

    [HttpPost]
    [ValidateAntiForgeryToken]
    public async Task<ActionResult> Create(InvoiceModel invoice)
    {
        DBHelper db = new DBHelper();
        ViewBag.InvoiceValues = await db.GetInvoiceValues();
        invoice.UserId = 1;
        // geçici olarak her oluşturulan fatura 1 id kullanıcı sayılsın
        var result = await db.CreateProcedure(invoice);
        if (result.Success) ModelState.Clear();
        ViewBag.Result = result;
        return View();
    }
    
    public async Task<ActionResult> Edit(int id)
    {
        DBHelper db = new DBHelper();
        var invoice = await db.GetInvoice(id);
        ViewBag.Invoice = invoice;
        ViewBag.InvoiceValues = await db.GetInvoiceValues();
        return View(invoice);
    }

    [HttpPost]
    [ValidateAntiForgeryToken]
    public async Task<ActionResult> Edit(InvoiceModel invoice)
    {
        DBHelper db = new DBHelper();
        ViewBag.InvoiceValues = await db.GetInvoiceValues();
        var result = await db.UpdateProcedure(invoice);
        ViewBag.Result = result;
        return View();
    }

    public async Task<ActionResult> Delete(int id)
    {
        DBHelper db = new DBHelper();
        var invoice = await db.GetInvoice(id);
        if (invoice == null) return RedirectToAction("List", "Invoice");
        return View(invoice);
    }

    [HttpPost, ActionName("Delete")]
    public async Task<ActionResult> DeleteConfirm(int id)
    {
        DBHelper db = new DBHelper();
        InvoiceModel customer = new InvoiceModel() { InvoiceId = id };
        var result = await db.DeleteProcedure(customer);
        return RedirectToAction("List", "Invoice");
    }
}

Fatura oluşturmak için Create.cshtml dosyasını CustomerController içerisinde yaptığınız aynı işlemleri yaparak oluşturup doldurun. Create metoduna sağ tıklayıp Add View işlemi ile kolayca View oluşturabilirsiniz.


@model InvoicesWeb.Models.InvoiceModel

@{
    ViewBag.Title = "Fatura Oluştur";
    InvoicesWeb.Models.InvoiceValuesModel invoiceValues = ViewBag.InvoiceValues;
    List<SelectListItem> listInvoiceTypes = new List<SelectListItem>();
    foreach (var type in invoiceValues.InvoiceTypes)
    {
        listInvoiceTypes.Add(new SelectListItem() { Text = type.Value, Value = type.Id.ToString() });
    }
    List<SelectListItem> listInvoiceStatuses = new List<SelectListItem>();
    foreach (var type in invoiceValues.InvoiceStatuses)
    {
        listInvoiceStatuses.Add(new SelectListItem() { Text = type.Value, Value = type.Id.ToString() });
    }
    List<SelectListItem> listPaymentTypes = new List<SelectListItem>();
    foreach (var type in invoiceValues.PaymentTypes)
    {
        listPaymentTypes.Add(new SelectListItem() { Text = type.Value, Value = type.Id.ToString() });
    }
    List<SelectListItem> listInvoiceCustomers = new List<SelectListItem>();
    foreach (var type in invoiceValues.InvoiceCustomers)
    {
        listInvoiceCustomers.Add(new SelectListItem() { Text = type.Value, Value = type.Id.ToString() });
    }
    InvoicesWeb.Helpers.DBResult result = ViewBag.Result;
}

<h2>Fatura Oluştur</h2>

@using (Html.BeginForm()) 
{
    @Html.AntiForgeryToken()
    <div class="form-horizontal">
        <hr />
        @Html.ValidationSummary(true, "", new { @class = "text-danger" })
        <div class="form-group">
            @Html.LabelFor(model => model.InvoiceNumber, htmlAttributes: new { @class = "control-label col-md-2" })
            <div class="col-md-10">
                @Html.EditorFor(model => model.InvoiceNumber, new { htmlAttributes = new { @class = "form-control" } })
                @Html.ValidationMessageFor(model => model.InvoiceNumber, "", new { @class = "text-danger" })
            </div>
        </div>
        <div class="form-group">
            @Html.LabelFor(model => model.Title, htmlAttributes: new { @class = "control-label col-md-2" })
            <div class="col-md-10">
                @Html.EditorFor(model => model.Title, new { htmlAttributes = new { @class = "form-control" } })
                @Html.ValidationMessageFor(model => model.Title, "", new { @class = "text-danger" })
            </div>
        </div>
        <div class="form-group">
            @Html.LabelFor(model => model.CustomerId, htmlAttributes: new { @class = "control-label col-md-2" })
            <div class="col-md-10">
                @Html.DropDownListFor(model => model.CustomerId, listInvoiceCustomers, new { @class = "form-control" })
                @Html.ValidationMessageFor(model => model.CustomerId, "", new { @class = "text-danger" })
            </div>
        </div>
        <div class="form-group">
            @Html.LabelFor(model => model.Address, htmlAttributes: new { @class = "control-label col-md-2" })
            <div class="col-md-10">
                @Html.EditorFor(model => model.Address, new { htmlAttributes = new { @class = "form-control" } })
                @Html.ValidationMessageFor(model => model.Address, "", new { @class = "text-danger" })
            </div>
        </div>
        <div class="form-group">
            @Html.LabelFor(model => model.InvoiceTypeId, htmlAttributes: new { @class = "control-label col-md-2" })
            <div class="col-md-10">
                @Html.DropDownListFor(model => model.InvoiceTypeId, listInvoiceTypes, new { @class = "form-control" })
                @Html.ValidationMessageFor(model => model.InvoiceTypeId, "", new { @class = "text-danger" })
            </div>
        </div>
        <div class="form-group">
            @Html.LabelFor(model => model.InvoiceStatusId, htmlAttributes: new { @class = "control-label col-md-2" })
            <div class="col-md-10">
                @Html.DropDownListFor(model => model.InvoiceStatusId, listInvoiceStatuses, new { @class = "form-control" })
                @Html.ValidationMessageFor(model => model.InvoiceStatusId, "", new { @class = "text-danger" })
            </div>
        </div>
        <div class="form-group">
            @Html.LabelFor(model => model.PaymentTypeId, htmlAttributes: new { @class = "control-label col-md-2" })
            <div class="col-md-10">
                @Html.DropDownListFor(model => model.PaymentTypeId, listPaymentTypes, new { @class = "form-control" })
                @Html.ValidationMessageFor(model => model.PaymentTypeId, "", new { @class = "text-danger" })
            </div>
        </div>
        <div class="form-group">
            @Html.LabelFor(model => model.PaymentDate, htmlAttributes: new { @class = "control-label col-md-2" })
            <div class="col-md-10">
                @Html.EditorFor(model => model.PaymentDate, new { htmlAttributes = new { @class = "form-control" } })
                @Html.ValidationMessageFor(model => model.PaymentDate, "", new { @class = "text-danger" })
            </div>
        </div>
        <div class="form-group">
            <div class="col-md-offset-2 col-md-10">
                <input type="submit" value="Oluştur" class="btn btn-default" />
            </div>
        </div>
    </div>
}

<div>
    @Html.ActionLink("Listeye dön", "Index")
</div>

Fatura genel bilgilerini düzenlemek için kullanılan Edit.cshtml dosyası aşağıdaki gibi olacaktır.


@model InvoicesWeb.Models.InvoiceModel

@{
    ViewBag.Title = "Fatura Düzenle";
    InvoicesWeb.Models.InvoiceValuesModel invoiceValues = ViewBag.InvoiceValues;
    List<SelectListItem> listInvoiceTypes = new List<SelectListItem>();
    foreach (var type in invoiceValues.InvoiceTypes)
    {
        listInvoiceTypes.Add(new SelectListItem() { Text = type.Value, Value = type.Id.ToString() });
    }
    List<SelectListItem> listInvoiceStatuses = new List<SelectListItem>();
    foreach (var type in invoiceValues.InvoiceStatuses)
    {
        listInvoiceStatuses.Add(new SelectListItem() { Text = type.Value, Value = type.Id.ToString() });
    }
    List<SelectListItem> listPaymentTypes = new List<SelectListItem>();
    foreach (var type in invoiceValues.PaymentTypes)
    {
        listPaymentTypes.Add(new SelectListItem() { Text = type.Value, Value = type.Id.ToString() });
    }
    List<SelectListItem> listInvoiceCustomers = new List<SelectListItem>();
    foreach (var type in invoiceValues.InvoiceCustomers)
    {
        listInvoiceCustomers.Add(new SelectListItem() { Text = type.Value, Value = type.Id.ToString() });
    }
    InvoicesWeb.Helpers.DBResult result = ViewBag.Result;
}

<h2>Fatura Düzenle</h2>

@using (Html.BeginForm())
{
    @Html.AntiForgeryToken()

    <div class="form-horizontal">
        @Html.HiddenFor(model => model.InvoiceId)
        <hr />
        @Html.ValidationSummary(true, "", new { @class = "text-danger" })
        <div class="form-group">
            @Html.LabelFor(model => model.InvoiceNumber, htmlAttributes: new { @class = "control-label col-md-2" })
            <div class="col-md-10">
                @Html.EditorFor(model => model.InvoiceNumber, new { htmlAttributes = new { @class = "form-control" } })
                @Html.ValidationMessageFor(model => model.InvoiceNumber, "", new { @class = "text-danger" })
            </div>
        </div>
        <div class="form-group">
            @Html.LabelFor(model => model.Title, htmlAttributes: new { @class = "control-label col-md-2" })
            <div class="col-md-10">
                @Html.EditorFor(model => model.Title, new { htmlAttributes = new { @class = "form-control" } })
                @Html.ValidationMessageFor(model => model.Title, "", new { @class = "text-danger" })
            </div>
        </div>
        <div class="form-group">
            @Html.LabelFor(model => model.CustomerId, htmlAttributes: new { @class = "control-label col-md-2" })
            <div class="col-md-10">
                @Html.DropDownListFor(model => model.CustomerId, listInvoiceCustomers, new { @class = "form-control" })
                @Html.ValidationMessageFor(model => model.CustomerId, "", new { @class = "text-danger" })
            </div>
        </div>
        <div class="form-group">
            @Html.LabelFor(model => model.Address, htmlAttributes: new { @class = "control-label col-md-2" })
            <div class="col-md-10">
                @Html.EditorFor(model => model.Address, new { htmlAttributes = new { @class = "form-control" } })
                @Html.ValidationMessageFor(model => model.Address, "", new { @class = "text-danger" })
            </div>
        </div>
        <div class="form-group">
            @Html.LabelFor(model => model.InvoiceTypeId, htmlAttributes: new { @class = "control-label col-md-2" })
            <div class="col-md-10">
                @Html.DropDownListFor(model => model.InvoiceTypeId, listInvoiceTypes, new { @class = "form-control" })
                @Html.ValidationMessageFor(model => model.InvoiceTypeId, "", new { @class = "text-danger" })
            </div>
        </div>
        <div class="form-group">
            @Html.LabelFor(model => model.InvoiceStatusId, htmlAttributes: new { @class = "control-label col-md-2" })
            <div class="col-md-10">
                @Html.DropDownListFor(model => model.InvoiceStatusId, listInvoiceStatuses, new { @class = "form-control" })
                @Html.ValidationMessageFor(model => model.InvoiceStatusId, "", new { @class = "text-danger" })
            </div>
        </div>
        <div class="form-group">
            @Html.LabelFor(model => model.PaymentTypeId, htmlAttributes: new { @class = "control-label col-md-2" })
            <div class="col-md-10">
                @Html.DropDownListFor(model => model.PaymentTypeId, listPaymentTypes, new { @class = "form-control" })
                @Html.ValidationMessageFor(model => model.PaymentTypeId, "", new { @class = "text-danger" })
            </div>
        </div>
        <div class="form-group">
            @Html.LabelFor(model => model.PaymentDate, htmlAttributes: new { @class = "control-label col-md-2" })
            <div class="col-md-10">
                @Html.EditorFor(model => model.PaymentDate, new { htmlAttributes = new { @class = "form-control" } })
                @Html.ValidationMessageFor(model => model.PaymentDate, "", new { @class = "text-danger" })
            </div>
        </div>
        <div class="form-group">
            <div class="col-md-offset-2 col-md-10">
                <input type="submit" value="Düzenle" class="btn btn-default" />
            </div>
        </div>
    </div>
}

<div>
    <a href="@Url.Action("List", "Invoice")">Listeye Dön</a>
</div>

İlişkili İçerikler

Web uygulaması içinde veritabanından çağırılacak veya sunucuya gönderilecek veri modelleri oldukça önem teşkil etmektedir.

ASP.NET MVC ile fatura kayıtlarının tutulduğu, görüntülendiği, güncellendiği bir uygulama oluşturabilirsiniz.

Oturum açmak için sayfa düzenini belirlemek, gönderilen oturum bilgilerinin veritabanında prosedür ile doğrulanması ve yönlendirme işlemleri login sayfasının temel işleyişidir.

Paylaşın
Etiket Bulutu