web api示例

上篇博客讲解rest服务开发时,曾经提到过asp.net mvc中的rest api,由于篇幅原因,没有在上篇博客中进行讲解,这里专门拿出来进行讨论。还是一样引用上次的案例,用asp.net mvc提供的web api来进行IP地址归宿地查询接口的开发。

由于我机器装的是win8企业版操作系统,VS版本是2012,因此我们选择使用VS自带的MVC4模版中的Web API来创建一个项目。

\

\

点击确定后,VS会自动为我们创建一个完整的可运行的ASP.NET Web API的项目。

从项目的目录结构可以看出,ASP.NET Web API与ASP.NET MVC项目的结构几乎一致。我们删除为我们默认创建并打开的ValuesController文件(示例性文件,可以参考)。

既然要打造一个IP地址查询服务接口,为了跟上文的服务形式一致,我们还是使用GET请求方式的服务,不过我们这次使用MVC中的Web API来实现。

首先在Models文件夹中建立一个Address模型类。

?
1
2
3
4
5
6
7
8
9
namespace MvcWebApi.Models
{
     public class Address
     {
         public string IPAddress { get; set; }
         public string Province { get; set; }
         public string City { get; set; } 
     }
}
接着我们在Controllers文件夹下建立一个IPAddressController控制器,需要注意的是,这个IPAddressController一定要继承自ApiController类,这样服务才能暴露出来。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
namespace MvcWebApi.Controllers
{
     public class IPAddressController : ApiController
     {
         private static IList addresses = new List
         {
             new Address(){ IPAddress= "1.91.38.31" , Province= "北京市" , City= "北京市" },  
             new Address(){ IPAddress = "210.75.225.254" , Province = "上海市" , City = "上海市"  },
         };
 
         public IEnumerable GetIPAddresses()
         {
             return addresses;
         }
 
         public Address GetIPAddressByIP(string IP)
         {
             return addresses.FirstOrDefault(x => x.IPAddress == IP);
         }
 
     }
}</address></address></address>
只要做上面两步就可以运行这个项目了,我们按Ctrl+F5运行整个项目,出现了如下的页面。

\

我们点击右上角的API链接。

\

可以看到我们定义的Web API的接口的使用方法以及说明。

既然是服务,能够被其它程序调用就需要一个持续保障它运行的环境,我们可以将这个写好的Web API的项目发布到IIS当中。

我们可以使用VS自带的发布功能进行发布,并映射到IIS应用程序目录当中。

\

\

我们点击IIS右侧的浏览,看看服务有没有能够正常运行。

\

我们按照文档的提示,我们在地址栏输入http://192.168.0.2/webapi/api/ipaddress。

\

可以看到,我们收到了Web API定义的服务提供的数据。同样的我们试一下另外一个接口方法。

\

OK,这样就好了。

但是如果我们需要返回JSON格式怎么办呢?有个简便的方法,在Global.asax.cs文件中,添加一个方法即可。

\

关于这段代码的原因,可以参考:http://blog.miniasp.com/post/2012/10/12/ASPNET-Web-API-Force-return-JSON-format-instead-of-XML-for-Google-Chrome-Firefox-Safari.aspx,这里不重复。

我们运行这个项目后,重复发布。

当我们再次在浏览器中运行时,就可以看到默认返回的是JSON格式了(IE默认就是JSON)。

ASP.NET Web API就开发好了,至于在C#程序中怎么调用,可以参考我上篇博客中的代码。如果要在页面中调用,可以通过JQuery等JS库请求URL即可。

参考资料:

http://www.asp.net/web-api/overview/getting-started-with-aspnet-web-api/tutorial-your-first-web-api

http://blog.miniasp.com/post/2012/10/12/ASPNET-Web-API-Force-return-JSON-format-instead-of-XML-for-Google-Chrome-Firefox-Safari.aspx

下面是一个简单的示例,演示如何使用 SQL 查询数据,并将结果作为 JSON 返回给 Web API。 首先,创建一个 ASP.NET Core Web API 项目。在项目中添加一个名为“DataAccess”的文件夹。在该文件夹中创建一个名为“SqlDataAccess.cs”的类,该类将负责连接数据库并执行查询。 ```csharp using System.Collections.Generic; using System.Data; using System.Data.SqlClient; using System.Linq; using Dapper; namespace WebApi.DataAccess { public class SqlDataAccess { private readonly string _connectionString; public SqlDataAccess(string connectionString) { _connectionString = connectionString; } public List<T> LoadData<T, U>(string sql, U parameters) { using IDbConnection connection = new SqlConnection(_connectionString); List<T> rows = connection.Query<T>(sql, parameters).ToList(); return rows; } } } ``` 该类使用 Dapper ORM 库来执行查询。 `LoadData` 方法接收两个类型参数:`T` 表示返回的数据类型,`U` 表示查询参数的类型。 接下来,在“Controllers”文件夹中创建一个名为“DataController.cs”的控制器类。在该类中,我们将使用 `SqlDataAccess` 类从数据库中检索数据并将其作为 JSON 返回给客户端。以下是示例控制器类的代码: ```csharp using Microsoft.AspNetCore.Mvc; using WebApi.DataAccess; namespace WebApi.Controllers { [ApiController] [Route("[controller]")] public class DataController : ControllerBase { private readonly SqlDataAccess _dataAccess; public DataController(SqlDataAccess dataAccess) { _dataAccess = dataAccess; } [HttpGet] public IActionResult Get() { // 这里是数据库查询,查询的结果将返回一个包含多个对象的列表 var results = _dataAccess.LoadData<SomeType>("SELECT * FROM SomeTable", null); // 将结果作为 JSON 返回给客户端 return Ok(results); } } } ``` 在上面的代码中,我们使用 `SqlDataAccess` 类从数据库中检索数据。我们将查询结果作为包含多个对象的列表返回。然后,我们将列表作为 JSON 返回给客户端。 最后,我们需要将 `SqlDataAccess` 类注入到控制器中。在“Startup.cs”文件中的“ConfigureServices”方法中添加以下代码: ```csharp services.AddTransient<SqlDataAccess>(_ => new SqlDataAccess(Configuration.GetConnectionString("DefaultConnection"))); ``` 现在,我们已经完成了一个简单的 Web API,它允许客户端使用 SQL 查询数据并将结果作为 JSON 返回。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值