欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

初始WebApi(1)

程序员文章站 2022-04-14 16:02:47
如果你要问我WebApi是干嘛,我只能说它是的给数据。哈哈哈哈哈,这几天也才刚刚了解了解关于WebApi的知识,今天就来谈谈吧。 1.创建WebApi项目 第一步:选择ASP.NET Web应用程序 第二步:选择WebApi,记得要取消勾选Https配置,点击创建 第三步:创建完成后形成的项目结构 ......

如果你要问我webapi是干嘛,我只能说它是的给数据。哈哈哈哈哈,这几天也才刚刚了解了解关于webapi的知识,今天就来谈谈吧。

1.创建webapi项目

第一步:选择asp.net web应用程序

初始WebApi(1)

第二步:选择webapi,记得要取消勾选https配置,点击创建

初始WebApi(1)

 第三步:创建完成后形成的项目结构

这里和asp.net mvc的目录结构看起来有点类似,其实还是有很大的不同的

在这里view视图其实不起什么作用。

初始WebApi(1)

下面来看看目录结构中有什么东西。

初始WebApi(1)

 可以看到自动创建了两个控制器分别是home和values(这里的student和user是我自己创建的)

进去看看。需要注意的是这里home和下面介绍的values是不同的控制器,哪里不同呢?等一下就知道啦

home控制器:

初始WebApi(1)

values控制器:

与home控制器最大的区别就在于继承的控制器前者是controller、后者是apicontroller

可以看到这里分别有几个方法:get(查询)、post(新增)、put(修改)、以及delete(删除)

[frombody]在这里的作用就是只接受从data中传递过来的参数,也就是其他传参方法比如querystring形式的方法无法获取。

为什么系统自动帮我们创建了这四个方法呢?

 1 using system;
 2 using system.collections.generic;
 3 using system.linq;
 4 using system.net;
 5 using system.net.http;
 6 using system.web.http;
 7 
 8 namespace demo.controllers
 9 {
10     //webapi控制器
11     public class valuescontroller : apicontroller
12     {
13         // get api/values
14         public ienumerable<string> get()
15         {
16             return new string[] { "value1", "value2" };
17         }
18 
19         // get api/values/5
20         public string get(int id)
21         {
22             return "value";
23         }
24 
25         // post api/values
26         public void post([frombody]string value)
27         {
28         }
29         //frombody指定数据来源必须是data中的数据而不是从querystring过来的
30         // put api/values/5
31         public void put(int id, [frombody]string value)
32         {
33         }
34 
35         // delete api/values/5
36         public void delete(int id)
37         {
38         }
39     }
40 }

这里的原有还有追溯到创建webapi项目的时候

那就是restful http服务模板

通过restful语义定义的四个方法,可以通过ajax请求进行调用并获得数据。

初始WebApi(1)

 下面我们去创建一个普通的html页面和一个student api控制器以及一个student类

student类:

 1 using system;
 2 using system.collections.generic;
 3 using system.linq;
 4 using system.web;
 5 
 6 namespace demo.models
 7 {
 8     public class student
 9     {
10         public int id { get; set; }
11         public string name { get; set; }
12     }
13 }

student控制器方法:

在注释中我也备注了restful使用规则和约束

 1 using demo.models;
 2 using system;
 3 using system.collections.generic;
 4 using system.linq;
 5 using system.net;
 6 using system.net.http;
 7 using system.web.http;
 8 
 9 namespace demo.controllers
10 {
11     //webapi控制器
12     public class studentcontroller : apicontroller
13     {
14         /// <summary>
15         /// restful格式的数据提供方式 方法名要带着get
16         /// restful风格节省了方法名的编写,但是不适合~login登录、上传 、修改头像、点赞等业务功能的实现
17         /// restful只适合对某一个表的增删改查
18         /// </summary>
19         /// <returns></returns>
20         public student get()
21         {
22             return new student() { id = 1, name = "黄朝" };
23         }
24         /// <summary>
25         ///get不能省略
26         /// </summary>
27         /// <param name="name"></param>
28         /// <returns></returns>
29         public string get(string name)
30         {
31             return "参数是:" + name;
32         }
33 
34         public string getaddress(string addname) {
35             return "地址参数是:" + addname;
36         }
37         /// <summary>
38         /// 在这里post是做新增操作
39         /// </summary>
40         /// <param name="stu">学生对象</param>
41         public void post(student stu)
42         { 
43             
44         }
45         /// <summary>
46         /// 修改操作
47         /// </summary>
48         /// <param name="id">修改的id</param>
49         /// <param name="stu">修改的对象</param>
50         public void put(int id,student stu)
51         { 
52             
53         }
54         /// <summary>
55         /// 删除
56         /// </summary>
57         /// <param name="id">根据id的删除</param>
58         public void delete(int id)
59         { 
60             
61 
62         }
63     }
64 }

html页:

根据type不同的参数,调用后台api的数据。可以作为对象参数传递也可以根据id作为参数传递

<!doctype html>
<html>
<head>
    <meta charset="utf-8" />
    <title></title>
    <script src="scripts/jquery-3.3.1.js"></script>
    <script>
        $.ajax({
            url: "/api/student",
            type: "get"
        }).done(function (data) { console.log(data) })

        //$.ajax({
        //    url: "/api/student",
        //    type: "post",
        //    data: {
        //        id: 1,
        //        name:"abc"
        //    }
        //}).done(function () {
        //    console.info("成功");
        //}).fail(function () {
        //    console.info("失败");
        //})

        ///api/student/1 1为id
        //$.ajax({
        //    url: "/api/student/1",
        //    type: "put",
        //    data: {
        //        id: 12,
        //        name:"lisi"
        //    }
        //}).done(function () {
        //    console.info("成功")
        //}).fail(function () {
        //    console.info("失败")
        //})

        //$.ajax({
        //    url:"/api/student/1"
        //    type: "delete"
        //}).done(function () {rl: "/api/student/1",
        //    console.info("成功")
        //}).fail(function () {
        //    console.info("失败")
        //})
</script>
</head>
<body>
        
</body>
</html>

以上就是我对初次了解webapi的一个学习总结,如果以上内容存在不足或错误代码,请指出,谢谢。