2015-04-06 51 views
2

每当用户尝试更改帐单地址的街道地址时,都会发生异常。 Validation Error“一个或多个实体的验证失败”更改默认帐单地址'街道地址时出错

这是堆栈跟踪:

[DbEntityValidationException: Validation failed for one or more entities. See 'EntityValidationErrors' property for more details.] 
    System.Data.Entity.Internal.InternalContext.SaveChanges() +169 
    System.Data.Entity.Internal.LazyInternalContext.SaveChanges() +27 
    VirtoCommerce.Foundation.Data.EFRepositoryBase.SaveChangesInternal() +41 

[DbEntityValidationException: Entity Validation Failed - errors follow: 
VirtoCommerce.Foundation.Customers.Model.Address failed validation 
- Name : Only 128 characters allowed. 
] 
    VirtoCommerce.Foundation.Data.EFRepositoryBase.SaveChangesInternal() +548 
    VirtoCommerce.Foundation.Data.BasicUnitOfWork.SaveChanges() +407 
    VirtoCommerce.Foundation.Data.BasicUnitOfWork.Commit() +10 
    VirtoCommerce.Client.UserClient.SaveCustomerChanges(String memberId) +84 
    VirtoCommerce.Web.Controllers.AccountController.AddressEdit(AddressEditModel model) +1210 
    lambda_method(Closure , ControllerBase , Object[]) +104 
    System.Web.Mvc.ActionMethodDispatcher.Execute(ControllerBase controller, Object[] parameters) +14 
    System.Web.Mvc.ReflectedActionDescriptor.Execute(ControllerContext controllerContext, IDictionary`2 parameters) +156 
    System.Web.Mvc.ControllerActionInvoker.InvokeActionMethod(ControllerContext controllerContext, ActionDescriptor actionDescriptor, IDictionary`2 parameters) +27 
    System.Web.Mvc.Async.AsyncControllerActionInvoker.<BeginInvokeSynchronousActionMethod>b__39(IAsyncResult asyncResult, ActionInvocation innerInvokeState) +22 
    System.Web.Mvc.Async.WrappedAsyncResult`2.CallEndDelegate(IAsyncResult asyncResult) +29 
    System.Web.Mvc.Async.WrappedAsyncResultBase`1.End() +49 
    System.Web.Mvc.Async.AsyncControllerActionInvoker.EndInvokeActionMethod(IAsyncResult asyncResult) +32 
    System.Web.Mvc.Async.AsyncInvocationWithFilters.<InvokeActionMethodFilterAsynchronouslyRecursive>b__3d() +50 
    System.Web.Mvc.Async.<>c__DisplayClass46.<InvokeActionMethodFilterAsynchronouslyRecursive>b__3f() +225 
    System.Web.Mvc.Async.<>c__DisplayClass46.<InvokeActionMethodFilterAsynchronouslyRecursive>b__3f() +225 
    System.Web.Mvc.Async.<>c__DisplayClass46.<InvokeActionMethodFilterAsynchronouslyRecursive>b__3f() +225 
    System.Web.Mvc.Async.<>c__DisplayClass33.<BeginInvokeActionMethodWithFilters>b__32(IAsyncResult asyncResult) +10 
    System.Web.Mvc.Async.WrappedAsyncResult`1.CallEndDelegate(IAsyncResult asyncResult) +10 
    System.Web.Mvc.Async.WrappedAsyncResultBase`1.End() +49 
    System.Web.Mvc.Async.AsyncControllerActionInvoker.EndInvokeActionMethodWithFilters(IAsyncResult asyncResult) +34 
    System.Web.Mvc.Async.<>c__DisplayClass2b.<BeginInvokeAction>b__1c() +26 
    System.Web.Mvc.Async.<>c__DisplayClass21.<BeginInvokeAction>b__1e(IAsyncResult asyncResult) +100 
    System.Web.Mvc.Async.WrappedAsyncResult`1.CallEndDelegate(IAsyncResult asyncResult) +10 
    System.Web.Mvc.Async.WrappedAsyncResultBase`1.End() +49 
    System.Web.Mvc.Async.AsyncControllerActionInvoker.EndInvokeAction(IAsyncResult asyncResult) +27 
    System.Web.Mvc.Controller.<BeginExecuteCore>b__1d(IAsyncResult asyncResult, ExecuteCoreState innerState) +13 
    System.Web.Mvc.Async.WrappedAsyncVoid`1.CallEndDelegate(IAsyncResult asyncResult) +36 
    System.Web.Mvc.Async.WrappedAsyncResultBase`1.End() +54 
    System.Web.Mvc.Controller.EndExecuteCore(IAsyncResult asyncResult) +39 
    System.Web.Mvc.Controller.<BeginExecute>b__15(IAsyncResult asyncResult, Controller controller) +12 
    System.Web.Mvc.Async.WrappedAsyncVoid`1.CallEndDelegate(IAsyncResult asyncResult) +28 
    System.Web.Mvc.Async.WrappedAsyncResultBase`1.End() +54 
    System.Web.Mvc.Controller.EndExecute(IAsyncResult asyncResult) +29 
    System.Web.Mvc.Controller.System.Web.Mvc.Async.IAsyncController.EndExecute(IAsyncResult asyncResult) +10 
    System.Web.Mvc.MvcHandler.<BeginProcessRequest>b__5(IAsyncResult asyncResult, ProcessRequestState innerState) +21 
    System.Web.Mvc.Async.WrappedAsyncVoid`1.CallEndDelegate(IAsyncResult asyncResult) +36 
    System.Web.Mvc.Async.WrappedAsyncResultBase`1.End() +54 
    System.Web.Mvc.MvcHandler.EndProcessRequest(IAsyncResult asyncResult) +31 
    System.Web.Mvc.MvcHandler.System.Web.IHttpAsyncHandler.EndProcessRequest(IAsyncResult result) +9 
    System.Web.CallHandlerExecutionStep.System.Web.HttpApplication.IExecutionStep.Execute() +9651188 
    System.Web.HttpApplication.ExecuteStep(IExecutionStep step, Boolean& completedSynchronously) +155 

,如果你能在一个干净的构建复制这种错误,考虑到我没有改变任何与地址,或者在什么将帮助任何想法任何想法? 谢谢。

[更新]在更改送货地址的街道地址时也会发生这种情况。

回答

1

我找到了这个问题的答案。 当更改发货地址和帐单地址上的地址字段时,由于字符太多,字段将“爆炸”,因此名称字段将“炸毁”。这会发生,因为它会保持每次地址变更时加入BillingDefaultShippingDefault到字符串的结尾。

Name Column

为了解决这个问题,我已经改变了行354:

if (!model.Address.Name.Contains(UserHelper.DefaultBilling)) 
    model.Address.Name += UserHelper.DefaultBilling; 

和线路368:

if (!model.Address.Name.Contains(UserHelper.DefaultShipping)) 
    model.Address.Name += UserHelper.DefaultShipping; 

这解决了问题,希望它会如果你遇到它,也会帮助你。