XHR2 和[FromBody]使用说明

[FromBody]必须是application/json 否则会报415 不支持的类型

 

           

//Forms
function  FormsPost(data) { //Default Type x-www-form-urlencoding =>Form
    $.ajax({
        url: "/api/AgentAccount/PostForm",
        type: "post",                         
        datatype: "json",
        data: data,
        success: function (data) {
            alert('success');
        }
    }).fail(
    function (xhr, textstatus, err) {
        alert('error: ' + err);
    });
}

//[FromBody] Model
function ModelPost(data) {
    $.ajax({
        url: "/api/AgentAccount/UserRegister",
        type: "post",                        
        contentType: 'application/json; charset=utf-8', 
        datatype: "json",
        data: JSON.stringify(data),//jSON.stringfy for Model transmit [FromBody] will be used;
        success: function (data) {
            alert('success');
        }
    }).fail(
    function (xhr,textstatus, err) {
        alert('error: ' + err);
    });
}                
          
//[FromBody] String
function StringPost(data) {
    data = { "": "sds" };
    $.post('/api/AgentAccount/PostString', data);
    $.ajax({
        url: "/api/AgentAccount/PostString",
        type: "post",
        contentType: 'application/json; charset=utf-8',
        datatype: "json",
        data: data,
        success: function (data) {
            alert('success');
        }
    }).fail(
    function (xhr, textstatus, err) {
        alert('error: ' + err);
    });
}

//[FromBody] Image
function XhrUploadImage() {

}

//[FromeBody] xhr.Model
function XhrPostModel(data) {
    xhr = new XMLHttpRequest();                    
    xhr.open("POST", "/api/AgentAccount/UserRegister", true);   
    xhr.setRequestHeader('Content-Type', 'application/json');
    xhr.send(JSON.stringify(data));
    xhr.onreadystatechange = function (event) {
        if (4 == xhr.readyState) {
            if ((xhr.status >= 200 && xhr.status < 300) || xhr.status == 304) {
                alert(xhr.responseText);
            } else {
                alert('error:' + xhr.status);
            }
        }
    };
}

 对应controller action

        [HttpPost("PostForm")]
        public JsonResult PostForm(string FullName)
        {
            var data = new
            {
                username = "PostString"
            };
            return Json(data);
        }

        [HttpPost("UserRegister")]
        public JsonResult UserRegister([FromBody]AspNetUsers value)
        {
            var data = new {
                username="sf"
            };
            return Json(data);
        }

        // POST api/values
        [HttpPost("PostString")]
        public JsonResult PostString([FromBody] string value)
        {
            var data = new
            {
                username = "sf"
            };
            return Json(data);
        }

  

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值