WebApi调用及发布

//Controller
 public class ProductsController : ApiController
    {
        Product[] products = new Product[]
      {
            new Product { Id = 1, Name = "Tomato Soup", Category = "Groceries", Price = 1 },
            new Product { Id = 2, Name = "Yo-yo", Category = "Toys", Price = 3.75M },
            new Product { Id = 3, Name = "Hammer", Category = "Hardware", Price = 16.99M }
      };

        public IEnumerable<Product> GetAllProducts()
        {
            return products;
        }

        public IHttpActionResult GetProduct(int id)
        {
            var product = products.FirstOrDefault((p) => p.Id == id);
            if (product == null)
            {
                return NotFound();
            }
            return Ok(product);
        }
    }

 

//Models
  public class Product
    {
       public int Id { get; set; }
        public string Name { get; set; }
        public string Category { get; set; }
        public decimal Price { get; set; }
    }

WebApiConfig.cs Web API 路由

默认方法:GetAllProducts(); "api/{controller}/{id}"  http://localhost/api/products

调用自定义方法:GetAllProducts(); "api/{controller}/{action}/{id}"  http://localhost/api/products/GetAllProducts

把此API部署IIS上

C#后台代码调用例子:

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" Async="true"  %>

因后台调用是异步需要加 Async="true" 

public string Get(){

string url = "http://IIS端口/api/products/GetAllProducts";

HttpClient client = new HttpClient();

//返回数据格式XML或JSON
client.DefaultRequestHeaders.Accept.Add(new MediaTypeWithQualityHeaderValue("text/xml"));
//client.DefaultRequestHeaders.Accept.Add(new MediaTypeWithQualityHeaderValue("text/json");

HttpResponseMessage response = client.GetAsync(url).Result;
Task<string> xx = response.Content.ReadAsStringAsync();

string xx1 = response.Content.ReadAsStringAsync().Result;

}

 

返回数据XML:

<arrayofproduct xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.datacontract.org/2004/07/API2.Models">
<product>
<category>Groceries</category>
<id>1</id>
<name>Tomato Soup</name>
<price>1</price>
</product>
<product>
<category>Toys</category>
<id>2</id>
<name>Yo-yo</name>
<price>3.75</price>
</product>
<product>
<category>Hardware</category>
<id>3</id>
<name>Hammer</name>
<price>16.99</price>
</product>
</arrayofproduct>

返回JSON:

[{"Id":1,"Name":"Tomato Soup","Category":"Groceries","Price":1.0}
,{"Id":2,"Name":"Yo-yo","Category":"Toys","Price":3.75}
,{"Id":3,"Name":"Hammer","Category":"Hardware","Price":16.99}]

前台调用直接写ajax就可以完成。

如果是跨域调用时前台页需要加此标签(此代码可以解决跨域调用数据返回错误问题,ajax使用jsonp格式)

<meta http-equiv="Access-Control-Allow-Origin" content="*" />

 

 

posted @ 2016-10-28 14:57  哈佛  阅读(2852)  评论(0编辑  收藏  举报