图片 10

Web Service-创建

  • Web
    Service-介绍
  • Web Service-创建
  • Web
    Service-使用
  • Web
    Service-支持的数据类型
  • Web
    Service-安全
  • Web
    Service-介绍
  • Web
    Service-创建
  • Web Service-使用
  • Web
    Service-支持的数据类型
  • Web
    Service-安全

是webservice.就概念上来说,可能比较复杂,不过我们可以有个宏观的了解:webservice就是个对外的接口,里面有函数可供外部客户调用(注意:里面同样有客户不可调用的函数)。假若我们是服务端,我们写好了个webservice,然后把它给了客户(同时我们给了他们调用规则),客户就可以在从服务端获取信息时处于一个相对透明的状态。即使客户不了解(也不需要)其过程,他们只获取数据。



webservice传递的数据只能是序列化的数据,典型的就是xml数据。

这一节介绍的内容只是 Web Service 的一部分,还不算是一个完整的应用。

(在现在的版本中,通过在解决方案上右键,选择 Add
Web Reference,输入 Web Service 地址,即可直接使用该 Web Service。请参见
Add Web Reference 与 Add Service Reference
的使用区别。)

下面以一个简单例子为例:

在 Visual Web
Developer
中,新建一个 Web Service,其默认内容可能如下:

前面创建了一个简单的 Web Service,但如何使用它呢?

(一)新建——-项目–-Visual C#—web—ASP.NET Web
服务应用程序
,命名为TestWebService

<%@ WebService Language=”C#” Class=”WebService” %>
using System;
using System.Web;
using System.Web.Services;
using System.Web.Services.Protocols;
[WebService(Namespace = “]
[WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
public class WebService  : System.Web.Services.WebService
{
    [WebMethod]
    public string HelloWorld()
    {
        return “Hello World”;
    }
}

首先创建一个 Web Service,代码如下:

此时的目录结构如图所示:

核心内容如下:

<%@ WebService Language=”C#” Class=”WebService” %>

  • <%@ WebService Language=”C#” Class=”WebService” %> Web
    Service 声明。
  • System 和 System.Web.Services 必不可少的名称空间。
  • 类继承于 WebService。
  • [WebMethod] 表示这是一个 Web Service 方法,可以从 service
    中被访问。如果语言是 VB,则使用 <WebMethod>。

using System;
using System.Web;
using System.Web.Services;
using System.Web.Services.Protocols;

图片 1

在浏览器中访问如下:

[WebService(Namespace = “]
[WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
public class WebService  : System.Web.Services.WebService
{
    [WebMethod]
    public string HelloWorld(string userName)
    {
        return “Hello World” + userName;
    }
}

我们修改Service1.asmx的名字为:MyService.asmx

图片 2

我们在访问 Web Service 网页时,添加上参数
WSDL,比如下例地址:

同时修改文件中的class名

从这里可以看到 Web Service 提供的方法。

public classMyService: System.Web.Services.WebService

图片 3

可以得到一个 XML 文件:

{

调用其中的某一个方法

图片 4

[WebMethod]

图片 5

我们现在要把这个 XML 文件生成 .cs 文件

public string HelloWorld()

以 XML 格式返回方法返回的结果

使用 WSDL 文件,该文件是 .NET Framework SDK 的一部分,通常位于类似于

{

WebMethod 也可以有参数,比如:

C:Program FilesMicrosoft Visual Studio 8SDKv2.0Bin

return “Hello World”;

    [WebMethod]
    public string HelloWorld(string userName)
    {
        return “Hello World” + userName;
    }

的地方。在命令提示符中使用类似如下的命令生成 .cs 文件:

}

在浏览器中访问如下:

C:Program FilesMicrosoft Visual Studio 8SDKv2.0Bin>wsdl
/language:C#
/namespace:cftea /out:D:WebService.cs

}

图片 6

language 指定语言,namespace 指定名称空间,out 指定输出位置。

同时修改文件MyService.asmx(右击–查看标记;如果在vs环境下双击打开的是.cs文件)

图片 7

然后将这个 .cs
文件交给另一个服务器端的程序员,另一个服务器端的程序员就可以根据这个 .cs
文件来创建对本 Web Service 的调用,将 .cs 文件放在 App_Code 下。

<%@ WebService Language=”C#” CodeBehind=”MyService.asmx.cs”
Class=”TestWebService.Service1″ %>改为

  • Web
    Service-介绍
  • Web Service-创建
  • Web
    Service-使用
  • Web
    Service-支持的数据类型
  • Web
    Service-安全

using System;
using System.Data;
using System.Configuration;
using System.Collections;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using cftea;
public partial class Default2 : System.Web.UI.Page
{
    protected void Page_Load(object sender, EventArgs e)
    {
        WebService ws = new WebService();
        lbl.Text =
ws.HelloWorld(“千一网络”);
    }
}

<%@ WebService Language=”C#” CodeBehind=”MyService.asmx.cs”
Class=”TestWebService.MyService” %>


预览,我们就可以看到经过 Web Service 处理后返回的结果了。

(二)重新生成项目,右击MyService.asmx,选择“在浏览器中查看”,即可检查本项目是否有语法错误

说明:我们也可以将 .cs 文件编译成 dll,再将
dll 放在 bin 目录下。请参见 将 CS 编译成 DLL,并利用 Namespace
使用之。

(三)在MyService.asmx添加指定方法

  • Web
    Service-介绍
  • Web
    Service-创建
  • Web Service-使用
  • Web
    Service-支持的数据类型
  • Web
    Service-安全

using System;


using System.Data;

using System.Web;

using System.Collections;

using System.Web.Services;

using System.Web.Services.Protocols;

using System.ComponentModel;

namespace TestWebService

{

///

/// Service1 的摘要说明

///

[WebService(Namespace =
“http://tempuri.org/”)]

[WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]

[ToolboxItem(false)]

public classMyService: System.Web.Services.WebService

{

[WebMethod]//必须要有的,为了说明,其下是一个方法,每一个方法前面都需要有。

public string getName()

{

return “Hope”;

}

[WebMethod]

public string getAge()

{

return “25”;

}

[WebMethod]

public string HelloWorld()

{

return “Hello World”;

}

}

}

重新生成项目,右击MyService.asmx,选择“在浏览器中查看”,若在URL地址上没有MyService.asmx,则补全URL地址,如:

效果如下:

图片 8

(四)发布在外网上(后续还没有做)

这里我是在本机上测试的,所以没有必要发布。如果要发布到外网上,我们可以通过:

把bin文件下的文件以及与bin(包括.dll和.pdb文件)同级目录的asmx文件上传到外网即可。

(五)使用web service接口。

新建一个普通的windows应用程序,右击,添加web引用(在下一篇日志中,有介绍VS2010中如何添加web引用)—-

如图:

图片 9

改一下web引用名为:HopeWebService如图:

图片 10

此时,我们可以使用webservice中的方法了。通过HopeWebService我们可以访问其中的两个方法。

(六)使用方法:

HopeWebService.MyService obj = new HopeWebService.MyService();

MessageBox.Show(“name is:” +obj.getName()+”;age is:” +obj.getAge());

摘自:http://blog.sina.com.cn/s/blog_49f485700100gfrl.html

********************************************************************************************************************************************************

在Visual Studio
2010中已经找不到直接创建WebService的模板方式了,但下面的方法可实现:

在 Visual Studio 2010 的新建 Web 应用程序或者 Web
网站窗口中,如果你选择 .NET 4.0,会发现缺少了 ASP.NET Web Services
模板。你可能会怀疑 VS 2010 是不是不支持 ASP.NET Web Services
了?答案是否定的!你可以通过下面两种方式建立 ASP.NET Web Services
项目或网站:

1.如果直接选择 .NET 4.0,可以选择 ASP.NET Empty Web Site/Application
模板,建立空的 Web 网站或项目,在添加新项窗口中,你依然会发现 Web
Service 这个项模板。

2.可以先选择 .NET 2.0/3.0/3.5,就可以选择 ASP.NET Web Services
模板建立了,之后如果需要 .NET 4.0
的新特性,可以在项目属性窗口或网站属性页窗口的 Build 选项卡中选择 .NET
4.0。

从 Visual Studio 2010 对 .NET 4.0 故意隐藏 ASP.NET Web Services
模板来看,显然已不建议使用 ASP.NET Web Services 建立新的服务,WCF
服务应该是新项目的首选。

发表评论

电子邮件地址不会被公开。 必填项已用*标注