NetCore入门篇(七):NetCore项目使用Controller之二

 

一、简介


1、说明Post,Get定义的区别。

2、说明如何路由定义。

 

二、Get、Post定义


1、api不定义访问方式时,同时支持get 和 post。如果定义某种方式,则仅支持某种方式。具体看代码及运行效果。

这里有个知识点,什么时候使用get,什么时候使用post,个人习惯能get则get,不能get则post,至于put,delete,从来不用。

api代码:

public class OneController : Controller
{
    [HttpGet]
    public string GetString(string id)
    {
        return "get:" + id;
    }
    [HttpPost]
    public string PostString(string id)
    {
        return "post:" + id;
    }
    public string NullString(string id)
    {
        return "null:" + id;
    }
}

html测试代码:

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8" />
    <title>示例代码</title>
    <script src="http://libs.baidu.com/jquery/2.0.0/jquery.min.js"></script>
    <script>
        $(function () {
            $.get("one/getstring", { id: "001" }, function (result) { console.log(result) });
            $.post("one/getstring", { id: "001" }, function (result) { console.log(result) });

            $.get("one/poststring", { id: "001" }, function (result) { console.log(result) });
            $.post("one/poststring", { id: "001" }, function (result) { console.log(result) });

            $.get("one/nullstring", { id: "001" }, function (result) { console.log(result) });
            $.post("one/nullstring", { id: "001" }, function (result) { console.log(result) });
        });
    </script>
</head><body></body>
</html>

结果

定义了httpget,则post返回404,定义了httppost则get返回404,不定义则都能访问。

 

 三、整个Controller定义路由


 1、直接上代码,一看就懂。仔细观察访问路径。

 

整个Controller定义路由:api代码

[Route("api/one")]
public class OneController : Controller
{
    [Route("GetString")]
    public string GetString(string id)
    {
        return "get:" + id;
    }
}

整个Controller定义路由:html代码

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8" />
    <title>示例代码</title>
    <script src="http://libs.baidu.com/jquery/2.0.0/jquery.min.js"></script>
    <script>
        $(function () {
            $.get("api/one/getstring", { id: "001" }, function (result) { console.log(result) });
            $.post("api/one/getstring", { id: "001" }, function (result) { console.log(result) });
        });
    </script>
</head><body></body>
</html>

整个Controller定义路由:效果

 

 

 

 

四、单个方法定义路由。


 1、直接上代码,一看就懂。仔细观察访问路径。

 

api代码:

public class OneController : Controller
{
    [Route("api2/one/getstring")]
    public string GetString(string id)
    {
        return "get:" + id;
    }
}

html代码,路径差别:

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8" />
    <title>示例代码</title>
    <script src="http://libs.baidu.com/jquery/2.0.0/jquery.min.js"></script>
    <script>
        $(function () {
            $.get("api2/one/getstring", { id: "001" }, function (result) { console.log(result) });
            $.post("api2/one/getstring", { id: "001" }, function (result) { console.log(result) });
        });
    </script>
</head><body></body>
</html>

运行效果

 

 

 

 

 

五、既定义路由又定义访问方式


1、直接上代码,一看就懂。仔细观察访问路径。

 

api代码:

public class OneController : Controller
{
    [HttpGet("api3/one/getstring")]
    public string GetString(string id)
    {
        return "get:" + id;
    }
}

html 代码:

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8" />
    <title>示例代码</title>
    <script src="http://libs.baidu.com/jquery/2.0.0/jquery.min.js"></script>
    <script>
        $(function () {
            $.get("api3/one/getstring", { id: "001" }, function (result) { console.log(result) });
            $.post("api3/one/getstring", { id: "001" }, function (result) { console.log(result) });
        });
    </script>
</head><body></body>
</html>

运行效果

 

 

 

 

六、结论


1、通过以上对比,可以知道,路由的定义有几种方式,并且可以自由组合。

2、另一种是在Startup中定义,见下图。

3、在生产过程中,以上方法几乎不会用到,一般都是用Startup默认路由,因为我们只要一个可以访问的唯一地址而已。

 

 

 

<返回NetCore入门系列目录

前往下一篇:NetCore入门篇(八):NetCore项目使用Controller之三>

posted @ 2021-02-23 17:05  深海地平线  阅读(1171)  评论(0编辑  收藏  举报