一起谈.NET技术,JavaScript 调用 ASP.NET WebService 的简单方法

简介:   客户端 JavaScript 调用 ASP.NET WebService 的方法除了采用 WebServer.htc 和构造 SOAPAction 的方法外,下面介绍一个采用 Ajax调用的简单方法,并且可以传递参数。

  客户端 JavaScript 调用 ASP.NET WebService 的方法除了采用 WebServer.htc 和构造 SOAPAction 的方法外,下面介绍一个采用 Ajax调用的简单方法,并且可以传递参数。其实,ASP.NET WebService 就是一个网站,所以,Request 对象是可用的,这样,传递参数就很容易了。下面是一个WebService1.asmx的代码:

  ASMX 代码:

 
  
<% @ WebService Language = " C# " CodeBehind = " WebService1.asmx.cs " Class = " WebService1 " %>
  C#代码:
 
    
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Services;
using System.Data;

/// <summary>
/// Summary description for WebService1
/// </summary>
[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 WebService1 : System.Web.Services.WebService
{
[WebMethod]
// 字符串返回测试
public string GetServerTime()
{
return " 当前服务器时间: " + DateTime.Now.ToString();
}

[WebMethod]
// long 类型返回测试
public long GetServerTimeTicks()
{
return DateTime.Now.Ticks;
}

[WebMethod]
// Datatable返回测试
public DataTable GetTestDataTable()
{
DataTable dt
= new DataTable( " TestTable " );
DataRow dr;
dt.Columns.Add(
new DataColumn( " id " , typeof (Int32)));
dt.Columns.Add(
new DataColumn( " text " , typeof ( string )));
for ( int i = 0 ; i < 6 ; i ++ )
{
dr
= dt.NewRow();
dr[
0 ] = i;
dr[
1 ] = " 列表项目 " + i.ToString();
dt.Rows.Add(dr);
}
return dt;
}

[WebMethod]
// List 类型测试
public List < User > GetTestUser()
{
// 传递参数传测试
string param = this .Context.Request.QueryString[ " param " ];
if (param == null ) param = this .Context.Request.Form[ " param1 " ];
List
< User > u_list = new List < User > ();
for ( int i = 0 ; i < 10 ; i ++ )
{
User u
= new User();
u.Name
= " LoginName " + i.ToString() + " param = " + param;
u.Title
= " 孟宪会 " + i.ToString();
u_list.Add(u);
}
return u_list;
}

// 定义一个对象 User
public class User
{
public String Name { get ; set ; }
public String Title { get ; set ; }
}
}
  HTML 代码:
 
    
<! DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd" >
< html xmlns ="http://www.w3.org/1999/xhtml" >
< head runat ="server" >
< title > JavaScript 调用 ASP.NET Web 服务测试 </ title >
< script type ="text/javascript" >
var xmlHttp = null ;
function createXMLHttpRequest() {
try {
if (window.XMLHttpRequest)
xmlHttp
= new XMLHttpRequest();
else if (window.ActiveXObject)
xmlHttp
= new ActiveXObject( " Microsoft.XMLHTTP " );
}
catch (ex) { }
}

function AsynRequest() {
createXMLHttpRequest();
if (xmlHttp == null ) {
alert(
" 不能创建 XmlHttpRequest 对象 " );
return ;
}
xmlHttp.open(
" GET " , " WebService1.asmx/GetTestUser?param=net_lover " , true );
xmlHttp.setRequestHeader(
" Connection " , " close " );
xmlHttp.onreadystatechange
= function () {
if (xmlHttp.readyState == 4 ) {
if (xmlHttp.status == 200 ) {
var userList = xmlHttp.responseXML.getElementsByTagName( " User " );
for (i = 0 ; i < userList.length; i ++ ) {
document.getElementById(
" get1 " ).innerHTML += userList[i].getElementsByTagName( " Name " )[ 0 ].firstChild.nodeValue + " " ;
document.getElementById(
" get1 " ).innerHTML += userList[i].getElementsByTagName( " Title " )[ 0 ].firstChild.nodeValue + " <br/> " ;
}
}
}
};
xmlHttp.send();
}

function AsynPostRequest() {
createXMLHttpRequest();
if (xmlHttp == null ) {
alert(
" 不能创建 XmlHttpRequest 对象 " );
return ;
}
var data = " param1=abc " ;
xmlHttp.open(
" POST " , " WebService1.asmx/GetTestUser?t= " + Date.parse( new Date()), true );
xmlHttp.setRequestHeader(
" Content-type " , " application/x-www-form-urlencoded " );
xmlHttp.setRequestHeader(
" Content-length " , data.length);
xmlHttp.setRequestHeader(
" Connection " , " close " );
xmlHttp.onreadystatechange
= function () {
if (xmlHttp.readyState == 4 ) {
if (xmlHttp.status == 200 ) {
var userList = xmlHttp.responseXML.getElementsByTagName( " User " );
for (i = 0 ; i < userList.length; i ++ ) {
document.getElementById(
" post1 " ).innerHTML += userList[i].getElementsByTagName( " Name " )[ 0 ].firstChild.nodeValue + " " ;
document.getElementById(
" post1 " ).innerHTML += userList[i].getElementsByTagName( " Title " )[ 0 ].firstChild.nodeValue + " <br/> " ;
}
}
}
};
xmlHttp.send(data);
}
</ script >
</ head >
< body >
< input type ="button" value ="GET 方法调用" onclick ="AsynRequest()" />
< input type ="button" value ="POST方法调用" onclick ="AsynPostRequest()" />
< div id ="get1" ></ div >
< div id ="post1" ></ div >
</ body >
</ html >
  需要注意的是:使用此方法需要在web.config里加入以下的配置:
 
     
< system.web >
< webServices >
< protocols >
< add name = "HttpPost" />
< add name = "HttpGet" />
</ protocols >
</ webServices >
</ system.web >
目录
相关文章
|
6月前
|
存储 开发框架 前端开发
asp.net与asp.net优缺点及示例
asp.net与asp.net优缺点及示例
|
1月前
|
开发框架 前端开发 .NET
进入ASP .net mvc的世界
进入ASP .net mvc的世界
29 0
|
1月前
|
XML 开发框架 .NET
C# .NET面试系列八:ADO.NET、XML、HTTP、AJAX、WebService
## 第二部分:ADO.NET、XML、HTTP、AJAX、WebService #### 1. .NET 和 C# 有什么区别? .NET(通用语言运行时): ```c# 定义:.NET 是一个软件开发框架,提供了一个通用的运行时环境,用于在不同的编程语言中执行代码。 作用:它为多语言支持提供了一个统一的平台,允许不同的语言共享类库和其他资源。.NET 包括 Common Language Runtime (CLR)、基础类库(BCL)和其他工具。 ``` C#(C Sharp): ```c# 定义: C# 是一种由微软设计的面向对象的编程语言,专门为.NET 平台开发而创建。 作
174 2
|
1月前
|
开发框架 中间件 .NET
C# .NET面试系列七:ASP.NET Core
## 第一部分:ASP.NET Core #### 1. 如何在 controller 中注入 service? 在.NET中,在ASP.NET Core应用程序中的Controller中注入服务通常使用<u>依赖注入(Dependency Injection)</u>来实现。以下是一些步骤,说明如何在Controller中注入服务: 1、创建服务 首先,确保你已经在应用程序中注册了服务。这通常在Startup.cs文件的ConfigureServices方法中完成。例如: ```c# services.AddScoped<IMyService, MyService>(); //
61 0
|
1月前
|
开发框架 前端开发 .NET
C# .NET面试系列六:ASP.NET MVC
<h2>ASP.NET MVC #### 1. MVC 中的 TempData\ViewBag\ViewData 区别? 在ASP.NET MVC中,TempData、ViewBag 和 ViewData 都是用于在控制器和视图之间传递数据的机制,但它们有一些区别。 <b>TempData:</b> 1、生命周期 ```c# TempData 的生命周期是短暂的,数据只在当前请求和下一次请求之间有效。一旦数据被读取,它就会被标记为已读,下一次请求时就会被清除。 ``` 2、用途 ```c# 主要用于在两个动作之间传递数据,例如在一个动作中设置 TempData,然后在重定向到另
95 5
|
6月前
|
Windows
​史上最详细的Windows10系统离线安装.NET Framework 3.5的方法(附离线安装包下载)
​史上最详细的Windows10系统离线安装.NET Framework 3.5的方法(附离线安装包下载)
565 0
|
3月前
|
开发框架 安全 搜索推荐
分享105个NET源码ASP源码,总有一款适合您
分享105个NET源码ASP源码,总有一款适合您
27 4
|
4月前
|
Java 应用服务中间件 Spring
WebService - CXF开发Server和Client(main方法测试)
WebService - CXF开发Server和Client(main方法测试)
40 0
|
7月前
|
开发框架 前端开发 .NET
.NET 8 Release Candidate 1 (RC1)现已发布,包括许多针对ASP.NET Core的重要改进!
.NET 8 Release Candidate 1 (RC1)现已发布,包括许多针对ASP.NET Core的重要改进!
175 0
.NET 8 Release Candidate 1 (RC1)现已发布,包括许多针对ASP.NET Core的重要改进!
|
8月前
|
存储 开发框架 .NET
ASP.NET学生管理系统(.NET毕业设计)
ASP.NET学生管理系统(.NET毕业设计)
100 0