asp.net mvc 的webApi (一)自己手動創建


http://www.cnblogs.com/youring2/archive/2013/03/08/2949455.html

昨天看了兩篇文章:

ASP.NET Web API(一):使用初探,GET和POST數據Parry

HttpClient + ASP.NET Web API, WCF之外的另一個選擇dudu

通過這兩篇文章讓我了解了WEB API的簡單用法。

Parry是在MVC中使用WebAPI:在Visual Studio 2012中新建MVC4項目,在App_Start目錄下有一個WebApiConfig.cs文件,這個文件中就是相應的Web API的路由配置了。

我也根據這兩篇文章寫了一個簡單的測試程序。

先創建了一個UserModel

public class UserModel
{
public string UserID { get; set; }
public string UserName { get; set; }
}

然后添加Web API Controller

public class UserController : ApiController
{
public UserModel getAdmin()
{
return new UserModel() { UserID = "000", UserName = "Admin" };
}
}

注冊路由(這里應該需要改動,和路由的機制一樣,才能夠在webapi中使用多個方法)自好沒有理解到位己的觀點可能

public static void Register(HttpConfiguration config)
{
config.Routes.MapHttpRoute(
name:
"DefaultApi",
routeTemplate:
"api/{controller}/{id}",
defaults:
new { id = RouteParameter.Optional }
);
}

在Global中注冊

protected void Application_Start(object sender, EventArgs e)
{
WebApiConfig.Register(GlobalConfiguration.Configuration);
}

這個時候用地址欄訪問地址:api/user/getadmin

image

這個時侯默認返回的是XML數據模型。

使用AJAX請求這個api,指定數據格式為json

$.ajax({
type:
'GET',
url:
'api/user/getadmin',
dataType:
'json',
success:
function (data, textStatus) {
alert(data.UserID +
" | " + data.UserName);
},
error:
function (xmlHttpRequest, textStatus, errorThrown) {
}
});

alert出來的結果是:

image

這樣看來,真的是dudu所說的,可以根據請求的數據類型返回指定的數據格式。

 

POST數據

修改一下controller,添加一個add方法

public bool add(UserModel user)
{
return user != null;
}

只為了測試,所以這里只判斷一下傳入的實體是否為空,如果不為空則返回true

我在頁面上添加了一個button,代碼如下:

<input type="button" name="btnOK" id="btnOK" value="發送POST請求" />

添加JS代碼

$('#btnOK').bind('click', function () {
//創建ajax請求,將數據發送到后台處理
var postData = {
UserID:
'001',
UserName:
'QeeFee'
};
$.ajax({
type:
'POST',
url:
'api/user/add',
data: postData,
dataType:
'json',
success:
function (data, textStatus) {
alert(data);
},
error:
function (xmlHttpRequest, textStatus, errorThrown) {
}
});
});

再次運行頁面

image

我們附加進程進行調試,在發送ajax請求的時候,服務器段接收到的數據如圖:

image

如果認為此文對您有幫助,別忘了支持一下哦!


注意!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系我们删除。



 
粤ICP备14056181号  © 2014-2020 ITdaan.com