C#开发WebService笔记

一、基本概念
       Web Service也叫XML Web Service WebService是一种可以接收从Internet或者Intranet上的其它系统中传递过来的请求,轻量级的独立的通讯技术。是:通过SOAP在Web上提供的软件服务,使用WSDL文件进行说明,并通过UDDI进行注册。
 
XML:(Extensible Markup Language)扩展型可标记语言。面向短期的临时数据处理、面向万维网络,是Soap的基础。

Soap:(Simple Object Access Protocol)简单对象存取协议。是XML Web Service 的通信协议。当用户通过UDDI找到你的WSDL描述文档后,他通过可以SOAP调用你建立的Web服务中的一个或多个操作。SOAP是XML文档形式的调用方法的规范,它可以支持不同的底层接口,像HTTP(S)或者SMTP。

WSDL:(Web Services Description Language) WSDL 文件是一个 XML 文档,用于说明一组 SOAP 消息以及如何交换这些消息。大多数情况下由软件自动生成和使用。

UDDI (Universal Description, Discovery, and Integration) 是一个主要针对Web服务供应商和使用者的新项目。在用户能够调用Web服务之前,必须确定这个服务内包含哪些商务方法,找到被调用的接口定义,还要在服务端来编制软件,UDDI是一种根据描述文档来引导系统查找相应服务的机制。UDDI利用SOAP消息机制(标准的XML/HTTP)来发布,编辑,浏览以及查找注册信息。它采用XML格式来封装各种不同类型的数据,并且发送到注册中心或者由注册中心来返回需要的数据。

 Web Service与web应用程序的区别在于,web service不提供页面显示,其它基本是一样。

下面做一个web service ,实现往表wms_xx_cl 中增加一条记录的功能。

二、开发工具选择

 .net平台内建了对Web Service的支持,包括Web Service的构建和使用。与其它开发平台不同,使用.net平台,你不需要其他的工具或者SDK就可以完成Web Service的开发了。.net Framework本身就全面支持Web Service,包括服务器端的请求处理器和对客户端发送和接受SOAP消息的支持。所以,使用vs研发webservice是最简单的,本文使用VS.Net 2010。

三、建立数据库

使用sqlserver2000建立一个数据库,建立一个表wms_xx_wl。


简单点,定义三个字段,自增的键值,编号和名称。

四、web service 程序

4.1 打开vs2010,新建一个webservice工程。


选择,Asp.Net Web 服务应用程序,确定,vs2010自动生成了web service 的程序框架。

4.2 新建一个类dbutil ,操作数据库,代码如下:
using System;
using System.Data;
using System.Configuration;
using System.Linq;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.HtmlControls;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Xml.Linq;
using System.Data.SqlClient;
using System.Text.RegularExpressions;
using System.Collections;
using System.Collections.Generic;
namespace WlWebService
{
    public class DbUtil : IDisposable
    {
        public static SqlConnection sqlCon;  //用于连接数据库        
        private String ConnectionString = @"Server=server;Database=db;Uid=sa;Pwd=password;";
        
        public DbUtil()
        {
            if (sqlCon == null)
            {
                sqlCon = new SqlConnection();
                sqlCon.ConnectionString = ConnectionString;
                sqlCon.Open();
            }
        }
       
        public void Dispose()
        {
            if (sqlCon != null)
            {
                sqlCon.Close();
                sqlCon = null;
            }
        } 
        /// <summary>
        /// 增加一条物料信息
        /// </summary>
        /// <param name="bh">物料编号</param>
        /// <param name="mc">物料名称</param> 
        public bool insertwlinfo(string bh,  string mc)
        {
            try
            {
                string sql = "insert into wms_xx_wl (bh,mc) values ('" + bh + "','" + mc + "')"; 
                SqlCommand cmd = new SqlCommand(sql, sqlCon);
                cmd.ExecuteNonQuery();
                cmd.Dispose();
                return true;
            }
            catch (Exception)
            {
                return false;
            }
        }
 
    }
}

4.3 修改Service1.asmx.cs代码如下:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Services;
namespace WlWebService
{
    /// <summary>
    /// Service1 的摘要说明
    /// </summary>
    [WebService(Namespace = "http://tempuri.org/")]
    [WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
    [System.ComponentModel.ToolboxItem(false)]
    // 若要允许使用 ASP.NET AJAX 从脚本中调用此 Web 服务,请取消对下行的注释。
    // [System.Web.Script.Services.ScriptService]
    public class Service1 : System.Web.Services.WebService
    {
        DbUtil dbutil = new DbUtil();
        [WebMethod]
        public string HelloWorld()
        {
            return "Hello World";
        }
        [WebMethod(Description = "增加一条物料信息")]
        public bool insertwlinfo(string bh, string mc)
        {
            return dbutil.insertwlinfo(bh, mc);
        }
    }
}

4.4 运行,看看效果:


4.5 点击insertwlinfo:

进行测试,输入信息,如下图:

点击调用。

数据增加成功,可见C#开发webservice十分方便,webservice开发好了,还需要服务器发布和其它程序调用等等问题,下文再描述。

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值