如何在ajax中正确调用web服务
本文关键字:调用 web 服务 ajax | 更新日期: 2023-09-27 18:13:38
ok,这就是我要做的,我想从活动目录中获取所有用户并将其放在列表中,所以我会从ajax调用web服务,获取所有用户并将其放在列表字符串中,后来我想在文本框中使用jquery自动完成基于我之前得到的用户列表。
我是这样做的:
$(document).ready(function () {
// Load data then initialize plugin:
$.ajax({
url: '/SvcADUser.asmx/GetADUserList',
dataType: 'json'
}).done(function (source) {
var countriesArray = $.map(source, function (value) { return { value: value }; }),
countries = $.map(source, function (value) { return value; });
// Setup jQuery ajax mock:
$.mockjax({
url: '*',
responseTime: 200,
response: function (settings) {
var query = settings.data.query,
queryLowerCase = query.toLowerCase(),
suggestions = $.grep(countries, function (country) {
return country.toLowerCase().indexOf(queryLowerCase) !== -1;
}),
response = {
query: query,
suggestions: suggestions
};
this.responseText = JSON.stringify(response);
}
});
// Initialize autocomplete with local lookup:
$('#MainCT_dtvJobVac_PIC').autocomplete({
lookup: countriesArray,
onSelect: function (suggestion) {
$('#selection').html('You selected: ' + suggestion.value + ', ' + suggestion.data);
}
});
});
}());
}());
,但这扔给我一个错误,"NetworkError: 500 Internal Server Error - http://localhost:60525/SvcADUser.asmx/GetADUserList"
,如果我把url改为SvcADUser。Asmx,它不给一个错误,但没有给我结果。
我在这里做错了什么?顺便说一句,这是我的web服务代码:
[WebService(Namespace = "http://tempuri.org/")]
[WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
[System.ComponentModel.ToolboxItem(false)]
// To allow this Web Service to be called from script, using ASP.NET AJAX, uncomment the following line.
[System.Web.Script.Services.ScriptService]
public class SvcADUser : System.Web.Services.WebService
{
[ScriptMethod(ResponseFormat = ResponseFormat.Json)]
[WebMethod]
public List<string> GetADUserList(string keyword)
{
List<string> alluser = new List<string>();
using (var context = new PrincipalContext(ContextType.Domain, "weekendinc.com"))
{
using (var searcher = new PrincipalSearcher(new UserPrincipal(context)))
{
foreach (var result in searcher.FindAll())
{
DirectoryEntry de = result.GetUnderlyingObject() as DirectoryEntry;
alluser.Add((string)de.Properties["samAccountName"].Value);
}
}
}
var filtereduser = alluser.Where(usr => usr.ToLower().StartsWith(keyword.ToLower()));
return filtereduser.ToList();
}
}
try this
jQuery.ajax({
type: 'POST',
contentType: 'application/json;',
data: '{keyword:"test"}',
dataType: 'json',
async: true,
url: 'SvcADUser.asmx/GetADUserList',
success: function (result) {
alert(result.d);
}
});