Asp.Net WebApi Get请求整理(一)

Asp.Net WebApi+JQuery Ajax的Get请求整理

一、总结

1.Asp.Net WebApi默认不支持Get请求,需要在Action方法上指定[HttpGet], 除非Action方法以‘Get’开头。

2.默认路由中,没有指定action,如果想路由到action不要手动指定
3.WebApi返回值的json对象,使用$.get 接收返回值,不需要手动反序列化处理
4.WebApi的Get请求中,Action可以接收多个参数

二、代码验证说明

1.默认不支持Get请求,需要在Action上指定请求类型[HttpGet]

[HttpGet]
public string ShowName(string name)
{
    return $"您传入的名字:‘{name}’";
}

异常内容:

2.默认路由中没有action参数处理

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

可以手动添加处理

config.Routes.MapHttpRoute(
    name: "DefaultApi2",
    routeTemplate: "api/{controller}/{action}",
    defaults: new { action = "Index" }
);

3.WebApi的返回值都是json数据类型,JQuery中的Ajax会自动识别为json对象,不需要手动反序列化

[HttpGet]
public object ShowName3(string name, int age)
{
    return new { name = name, age = age, success = true };
}

相应结果:

返回字典类型:

复制代码
[HttpGet]
public Dictionary<string, string> GetList1(bool IsShow)
{
    Dictionary<string, string> dict = new Dictionary<string, string>();
    if (IsShow)
    {
        dict.Add("name1", "张三");
        dict.Add("name2", "李四");
    }
    return dict;
}
复制代码

JavaScript代码:

复制代码
$.get('/api/user/getlist1', {
    isshow: true
}, function (data) {
    console.info(data);
    alert(data);
});
$.get('/api/user/showname2', {
    name: '张三丰',
    age:19
}, function (data) {
    console.info(data);
    alert(data);
});
复制代码

Asp.Net WebApi+AngularJS $http的Get请求整理

1.WebApi,相应结果为json对象,不需要手动发序列化处理

复制代码
//WebApi,相应结果为json对象,不需要手动发序列化处理
$http.get('/api/user/showname3', {
    params: {
        name: '张三',
        age: '15'
    }
}).then(function (result) {  //正确请求成功时处理
    console.info(result);
    alert(result.data.name);
}).catch(function (result) { //捕捉错误处理
    console.info(result);
    alert(result.data.Message);
});
复制代码

复制代码
$http.get('/api/user/getlist1', {
    params: {
        isshow: true
    }
}).then(function (result) {
    console.info(result);
    console.info(result.data);
}).catch(function (err) {
    console.info(err);
    alert(err.data.Message);
});
复制代码

 

更多:

Asp.Net WebAPI Get提交、Post提交处理

Asp.Net WebApi Action命名中已‘Get’开头问题

Angular 1.6提示$http.get(...).success is not a function

posted @   天马3798  阅读(8128)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
历史上的今天:
2015-02-03 分享到QQ空间、新浪微博、腾讯微博的代码!(收藏)
点击右上角即可分享
微信分享提示