从C#中的void方法返回错误消息

问题描述 投票:0回答:1

我目前正在尝试让我的方法在条件无效的情况下返回错误消息。但我不确定如何以无效方法进行此操作。

我有一个看起来像这样的方法

        [HttpPost]
        [ValidateAntiForgeryToken]
        [Audit]
        public void AddUnits(int so_id, int site_id, int[] addItem_id, int[] addItem_qty, int[] addItem_disc)
        {
            // Loop however many times is necessary to iterate through the largest array
            for (int i = 0; i < Math.Max(Math.Max(addItem_id.Length, addComp_id.Length), addPart_id.Length); i++)
            {
                foreach (SODetails sod in db.SalesOrders.Find(so_id).SalesDetails)
                {
                    if (i < addItem_id.Length && addItem_qty[i] != 0 && sod.ItemID == addItem_id[i] && addItem_id[i] != 365 && addItem_id[i] != 410) 
                    {

                        sod.item_qty += addItem_qty[i];
                        sod.item_discount = addItem_disc[i];
                        addItem_id[i] = 0;
                        addItem_qty[i] = 0;
                        addItem_disc[i] = 0;
                    }              
                }
                db.SaveChanges();

                if(i < addItem_qty.Length && addItem_qty[i] != 0)
                {
                    SODetails sODetails = new SODetails
                    {
                        SalesOrderID = so_id,
                        SiteID = site_id
                    };

                    // Only add a unit to the SODetails object if it's not null and has an id and quanitity specified
                    if(i < addItem_id.Length && addItem_id[i] != 0 && addItem_qty[i] != 0)
                    {
                        sODetails.ItemID = addItem_id[i];
                        sODetails.item_qty = addItem_qty[i];
                        sODetails.item_discount = addItem_disc[i];
                    }

                    if (sODetails.SiteID == 0)
                        sODetails.SiteID = null;


                    SalesOrder SO = db.SalesOrders.Find(sODetails.SalesOrderID);
                    SODetails salesOrderDetails = db.SODetails.Add(sODetails);
                    salesOrderDetails.SalesOrder = SO;

                    Item SO_Item = db.Items.Find(sODetails.ItemID);
                    Component SO_Component = db.Components.Find(sODetails.ComponentID);
                    Part SO_Part = db.Parts.Find(sODetails.PartID);

                    if (SO_Item != null)
                    {
                        if (SO.OrderType == SOType.OffSiteInventory && sODetails.InventorySite == "Main Inventory" && SO_Item.On_Hand < salesOrderDetails.item_qty)
                        {

                            ModelState.AddModelError(string.Empty, "Not enough stock in inventory");
                                //TempData["SalesOrderMessage"] = SO_Item.SalesOrderMessage;

                        }

                        sODetails.item_qty = sODetails.item_qty == null ? 0 : sODetails.item_qty;
                        int qtyOrdered = sODetails.item_qty == null ? 0 : (int)sODetails.item_qty;
                        salesOrderDetails.dynamicItem_qty = qtyOrdered;

                        if (SO_Item.SalesOrderMessage != null)
                            TempData["SalesOrderMessage"] = SO_Item.SalesOrderMessage;
                    }

                    db.SODetails.Add(sODetails);

                }
            }

            db.SaveChanges();
        }

这是我进行验证检查的代码部分

 if (SO.OrderType == SOType.OffSiteInventory && sODetails.InventorySite == "Main Inventory" && SO_Item.On_Hand < salesOrderDetails.item_qty)
                        {

                            ModelState.AddModelError(string.Empty, "Not enough stock in inventory");
                                //TempData["SalesOrderMessage"] = SO_Item.SalesOrderMessage;

                        }

如果条件有效,我希望它返回显示错误消息的屏幕。但是由于方法为Void,所以我不知道如何使它执行此操作,或者不知道是否有可能。

c# asp.net-mvc linq error-handling
1个回答
0
投票

您可以创建一个特定的异常类,然后将其放入void函数中。然后,您可以在调用函数中处理此异常。

© www.soinside.com 2019 - 2024. All rights reserved.