码迷,mamicode.com
首页 > Windows程序 > 详细

在webapi中为Action使用dynamic参数实现Post方式调用

时间:2019-07-03 12:13:42      阅读:152      评论:0      收藏:0      [点我收藏+]

标签:log   for   fun   var   span   tar   处理   div   start   

原文:在webapi中为Action使用dynamic参数实现Post方式调用

1.在webapi中使用controller/action/id的路径配置,打开文件[App_Start] -[WebApiConfig]

 

  config.Routes.MapHttpRoute(
                name: "DefaultApi",
                routeTemplate: "api/{controller}/{action}/{id}",
                defaults: new { id = RouteParameter.Optional }
            );

 

2.直接使用[HttpPost]过滤器,为action添加实现方法:

[HttpPost]
// POST api/<controller>
public string AdminLogin(string userName,string passWord)
{
  return "";
}

  产生的问题:前端将“type”改为“Post”方式,无论如何都获取不到该方法。

 

3.解决方案一:

 ①添加中转的对象类,用于存储参数。

    public class AdminLogin
    {
        public string UserName { get; set; }

        public string PassWord { get; set; }
    }

②修改action参数配置。

      [HttpPost]
        // POST api/<controller>
        public string AdminLogin([FromBody]AdminLogin adminLogin)
        {
           return adminLogin.UserName;
        }    

③前端调用方法:

      $.ajax({

            type: "POST", url: AdminApi.AdminLogin,
       data: {UserName:"xxx",PassWord:"XXX"},
       success: function (data) {
           //处理方法

            }
        });

  

  

4.解决方案二:

①修改action参数为dynamic及方法调用:

      [HttpPost]
        // POST api/<controller>
        public string AdminLogin([FromBody]dynamic adminLogin)
        {
            string userName = adminLogin.UserName;
            string passWord = adminLogin.PassWord;
            return  userName;
        }

②修改前端调用方式:

        var obj = { UserName: username, PassWord: password };

        //调用api验证方法
        $.ajax({

            type: "POST", url: AdminApi.AdminLogin,
       data: JSON.stringify(obj), contentType: "application/json", 
       success: function (data) {
             //内部实现方法

            }
        });

  

  

 

 

在webapi中为Action使用dynamic参数实现Post方式调用

标签:log   for   fun   var   span   tar   处理   div   start   

原文地址:https://www.cnblogs.com/lonelyxmas/p/11125462.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!