2014-11-04 60 views
0

在我的Web API项目,我有一个名为的ContactController控制器和它命名为同步方法,等待下面的字符串列表:帖子列表

[HttpPost] 
    [Route("api/Contact/Synchro")] 
    public IHttpActionResult Synchro([FromBody]List<string> listNumTel) 
    { 
     List<Profil> listContact = new List<Profil>(); 
     if (listNumTel.Count() > 0) 
     { 
      try 
      { 
       listContact = Librairie.Contacts.getContactSync(listNumTel); 
       return Ok(listContact); 
      } 
      catch(Exception e) { 
       return InternalServerError(e); 
      } 
     } 
     else 
     { 
      return BadRequest(); 
     } 
    } 

测试该方法中,我创建以下称为AJAX:

$("#btn_synchro").click(function() { 
    $.ajax({ 
     url: '../api/Contact/Synchro', 
     type: 'POST', 
     data: { 
      "listNumTel": [ 
       "+33640512999", 
       "+33640522997", 
       "+33640182998", 
       "+33640742996"] 
     }, 
     dataType: 'json', 
     success: function (data) { 
      alert('Synchro réussi: ' + data); 
     }, 
     error: function (request, error) { 
      alert("Erreur lors de la synchro"); 
     } 
    }) 
}); 

当我在调试模式下测试,呼叫工作正常,但该方法得到一个空列表。我检查了json是否有效,它是。有人看到什么可能是错的?提前致谢 !

+1

如果将它作为内容类型“application/x-www-form-urlencoded”发送,您是否可以检查浏览器的请求? – 2014-11-04 16:38:02

+0

请求的内容类型似乎是:application/json – 2014-11-04 20:42:08

+1

那么,请尝试将其设置为“application/x-www-form-urlencoded”,因为我认为您的后端不会理解它是传入的POST请求。 jQuery似乎应该默认将其设置为此,但尝试在'contentType'中明确设置它 – 2014-11-04 20:44:03

回答

2

感谢您的答案,但我刚刚发现了解决方案。这完全是关于JSON发送。要通过一个Ajax调用,例如发送字符串列表中,JSON应该看起来像变量listNumero

("#btn_synchro").click(function() { 
    var listNumero = 
     [ '+33640532999', 
      '+33640532997', 
      '+33640532998', 
      '+33640532996']; 

    $.ajax({ 
     url: '../api/Contact/Synchro', 
     type: 'POST', 
     data: JSON.stringify(listNumero), 
     contentType: "application/json", 
     dataType: 'json', 
     success: function (data) { 
      alert('Synchro réussi: ' + data); 
     }, 
     error: function (request, error) { 
      alert("Erreur lors de la synchro"); 
     } 
    }) 
}); 

您可以比较我的帖子下面,JSON是不同的。现在我的web api控制器可以从列表中获取值。