我正在为使用Picking Process的公司开发一个Webapp。
这个过程非常简单,我有一份包含一些信息的销售订单,并且我创建了包含一些信息的拣配清单(例如:项目数,总重量和销售订单ID)。
我总是遇到这个错误
内部服务器错误
...当我尝试使用PUT方法时,创建一个Picking List并将其添加到Web Api端的数据库中。
当我删除[HttpPost]
时,错误更改为:
找不到方法
或
不允许的方法
这是我的代码:
客户端
public async Task<bool> AddTarefa(ListasPicking listaPickingAdd)
{
String listaparaAdicionar = listaPickingAdd.idLista + ";" + listaPickingAdd.IDordemVenda + ";" + listaPickingAdd.peso + ";" + listaPickingAdd.itens;
HttpResponseMessage response = await cliente.PutAsJsonAsync("api/ListasPicking/", listaparaAdicionar);
return response.IsSuccessStatusCode;
}
Web Api Side - 控制器
//PUT: api/ListasPicking
[ResponseType(typeof (ListasPicking))]
[HttpPut]
public IHttpActionResult PutLista ([FromBody] String lista)
{
if(!ModelState.IsValid)
{
return BadRequest(ModelState);
}
String[] result = lista.Split(';');
ListasPicking novaLista = new ListasPicking();
novaLista.idLista=result[0];
novaLista.IDordemVenda = result[1];
string lista_peso_converttoDouble = result[2];
novaLista.peso = Convert.ToDouble(lista_peso_converttoDouble);
string lista_items_converttoInt = result[3];
novaLista.itens = Convert.ToInt32(lista_items_converttoInt);
primContext.ListasPickingGet.Add(novaLista);
primContext.SaveChanges();
return StatusCode(HttpStatusCode.Created);
}
我尝试了一些与此类问题相关的解决方案,以及相同的错误。
的Web.config
<?xml version="1.0" encoding="utf-8"?>
<!--
For more information on how to configure your ASP.NET application, please visit
https://go.microsoft.com/fwlink/?LinkId=301879
-->
<configuration>
<configSections>
<sectionGroup name="applicationSettings" type="System.Configuration.ApplicationSettingsGroup, System, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
<section name="PrimaveraRest.Properties.Settings" type="System.Configuration.ClientSettingsSection, System, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission="false" />
</sectionGroup>
<!-- For more information on Entity Framework configuration, visit http://go.microsoft.com/fwlink/?LinkID=237468 -->
<section name="entityFramework" type="System.Data.Entity.Internal.ConfigFile.EntityFrameworkSection, EntityFramework, Version=6.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission="false" />
</configSections>
<appSettings>
<add key="webpages:Version" value="3.0.0.0" />
<add key="webpages:Enabled" value="false" />
<add key="ClientValidationEnabled" value="true" />
<add key="UnobtrusiveJavaScriptEnabled" value="true" />
</appSettings>
<system.web>
<compilation debug="true" targetFramework="4.5.2" />
<httpRuntime targetFramework="4.5.2" />
<httpModules>
<add name="ApplicationInsightsWebTracking" type="Microsoft.ApplicationInsights.Web.ApplicationInsightsHttpModule, Microsoft.AI.Web" />
</httpModules>
</system.web>
<system.webServer>
<handlers>
<remove name="ExtensionlessUrlHandler-Integrated-4.0" />
<remove name="OPTIONSVerbHandler" />
<remove name="TRACEVerbHandler" />
<!-- <remove name="WebDAV"/> -->
<add name="ExtensionlessUrlHandler-Integrated-4.0" path="*." verb="*" type="System.Web.Handlers.TransferRequestHandler" preCondition="integratedMode,runtimeVersionv4.0" />
</handlers>
<validation validateIntegratedModeConfiguration="false" />
<modules>
<!-- <remove name="WebDAVModule"/> -->
<remove name="ApplicationInsightsWebTracking" />
<add name="ApplicationInsightsWebTracking" type="Microsoft.ApplicationInsights.Web.ApplicationInsightsHttpModule, Microsoft.AI.Web" preCondition="managedHandler" />
</modules>
</system.webServer>
<runtime>
<assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
<dependentAssembly>
<assemblyIdentity name="Newtonsoft.Json" culture="neutral" publicKeyToken="30ad4fe6b2a6aeed" />
<bindingRedirect oldVersion="0.0.0.0-6.0.0.0" newVersion="6.0.0.0" />
</dependentAssembly>
<dependentAssembly>
<assemblyIdentity name="System.Web.Optimization" publicKeyToken="31bf3856ad364e35" />
<bindingRedirect oldVersion="1.0.0.0-1.1.0.0" newVersion="1.1.0.0" />
</dependentAssembly>
<dependentAssembly>
<assemblyIdentity name="WebGrease" publicKeyToken="31bf3856ad364e35" />
<bindingRedirect oldVersion="0.0.0.0-1.5.2.14234" newVersion="1.5.2.14234" />
</dependentAssembly>
<dependentAssembly>
<assemblyIdentity name="System.Web.Helpers" publicKeyToken="31bf3856ad364e35" />
<bindingRedirect oldVersion="1.0.0.0-3.0.0.0" newVersion="3.0.0.0" />
</dependentAssembly>
<dependentAssembly>
<assemblyIdentity name="System.Web.WebPages" publicKeyToken="31bf3856ad364e35" />
<bindingRedirect oldVersion="1.0.0.0-3.0.0.0" newVersion="3.0.0.0" />
</dependentAssembly>
<dependentAssembly>
<assemblyIdentity name="System.Web.Mvc" publicKeyToken="31bf3856ad364e35" />
<bindingRedirect oldVersion="1.0.0.0-5.2.3.0" newVersion="5.2.3.0" />
</dependentAssembly>
</assemblyBinding>
</runtime>
<system.codedom>
<compilers>
<compiler language="c#;cs;csharp" extension=".cs" type="Microsoft.CodeDom.Providers.DotNetCompilerPlatform.CSharpCodeProvider, Microsoft.CodeDom.Providers.DotNetCompilerPlatform, Version=1.0.3.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35" warningLevel="4" compilerOptions="/langversion:6 /nowarn:1659;1699;1701" />
<compiler language="vb;vbs;visualbasic;vbscript" extension=".vb" type="Microsoft.CodeDom.Providers.DotNetCompilerPlatform.VBCodeProvider, Microsoft.CodeDom.Providers.DotNetCompilerPlatform, Version=1.0.3.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35" warningLevel="4" compilerOptions="/langversion:14 /nowarn:41008 /define:_MYTYPE=\"Web\" /optionInfer+" />
</compilers>
</system.codedom>
<applicationSettings>
<PrimaveraRest.Properties.Settings>
<setting name="Company" serializeAs="String">
<value>DEMO</value>
</setting>
<setting name="User" serializeAs="String">
<value>adminfixe</value>
</setting>
<setting name="Password" serializeAs="String">
<value>123456</value>
</setting>
</PrimaveraRest.Properties.Settings>
</applicationSettings>
<entityFramework>
<defaultConnectionFactory type="System.Data.Entity.Infrastructure.LocalDbConnectionFactory, EntityFramework">
<parameters>
<parameter value="mssqllocaldb" />
</parameters>
</defaultConnectionFactory>
<providers>
<provider invariantName="System.Data.SqlClient" type="System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer" />
</providers>
</entityFramework>
</configuration>
更新
当我重建我的解决方案时,我会得到一些这样的行:
Files \ Microsoft Visual 工作室\ 2017年\社区\的MSBuild \ 15.0 \斌\ Microsoft.Common.CurrentVersion.targets(1964,5): 警告MSB3270:处理器之间存在不匹配 正在构建的项目架构“MSIL”和处理器 参考“Interop.ICrmDS800”,“x86”的体系结构。这个 不匹配可能导致运行时故障。请考虑改变 通过的目标处理器架构的项目 配置管理器,以便对齐处理器体系结构 您的项目和引用之间,或依赖于 具有与目标匹配的处理器体系结构的引用 项目的处理器架构
可能是问题吗? Interop.dll是我在项目中包含的文件,用于使用外部程序获取有关销售订单的信息。
解
“ListaPicking”模型中缺少[Key]注释,我正在使用默认值传递DateTime变量...我只是更改为例如DateTime.Today,现在它正在工作:)
答案 0 :(得分:2)
你调用PutAsJsonAsync
但是当你需要一个表示json的字符串时,你会传递一个非json字符串作为你的数据参数。
来自文档:
将PUT请求作为异步操作发送到指定的Uri,并将给定值序列化为JSON。
要使其工作,请致电PutAsync
。
答案 1 :(得分:1)
您可以发送整个模型
public async Task<bool> AddTarefa(ListasPicking listaPickingAdd) {
var response = await cliente.PutAsJsonAsync("api/ListasPicking/", listaPickingAdd);
return response.IsSuccessStatusCode;
}
以同样的方式接受它,而不是解构和重构它。
[ResponseType(typeof (ListasPicking))]
[HttpPut]
public IHttpActionResult PutLista ([FromBody] ListasPicking novaLista) {
if(!ModelState.IsValid) {
return BadRequest(ModelState);
}
primContext.ListasPickingGet.Add(novaLista);
primContext.SaveChanges();
return StatusCode(HttpStatusCode.Created);
}