收 藏 投 稿 繁 体 RSS 
站长吧-中国站长学习与交流的网站
首 页 运 营 学 院 建 站 论 坛
Web master8.net  
 网站运营  
  欢迎在本站发布信息,在线投递稿件请点这里。编辑QQ:4908220,欢迎联系交流。
业界动态 创业故事 推广研究 策划盈利 电子商务 企业平台
  站长工具
SEO查询 Whois查询 Pr查询 域名查询 IP查询 网页编辑器
 建站服务  
  如有建站意向,请尽快联系我们,以便安排时间... 建站服务 QQ4908220 QQ:4908220
作品展示 服务范围 服务流程 服务报价 联系方式 付款方式
文章正文  » 您的当前位置: 首页 >> 学院 >> 程序开发 >> ASP.Net
网站间共享数据的WebService
  来源:互联网 | 时间:2005-10-01 | 浏览:   相关评论 | 报告错误 | 发布文章
【字号: | | 】 【背景色 杏仁黄 秋叶褐 胭脂红 芥末绿 天蓝 雪青 灰 银河白(默认色)

在站点a的数据库服务器的数据库中有一个数据表NoteBoard包含字段ID(编号),Title(标题),NoterName(留言人名字),NoteTime(留言时间) 
怎样可以让站点b获得这个数据表的记录呢。 


在a定义访问a站数据库的webservice文件MyViewDBService.asmx 
<%@WebService Language="C#" Class="ViewDBService"%> 
using System; 
using System.Data; 
using System.Data.OleDb; 
using System.Web.Services; 
public class ViewDBService : WebService 

[WebMethod] 
public DataSet ViewDB() 

string connStr="Provider=Microsoft.Jet.OLEDB.4.0;Data Source=E:\\WmjDB.mdb"; 
OleDbConnection conn=new OleDbConnection(connStr); 
string sqls="select ID,Title,NoterName,NoteTime from NoteBoard order by id"; 
OleDbDataAdapter adapter=new OleDbDataAdapter(); 
adapter.SelectCommand=new OleDbCommand(sqls,conn); 
DataSet dataSet=new DataSet(); 
adapter.Fill(dataSet,"NoteBoard"); 
conn.Close(); 
return dataSet; 


/////////////////////////////////////////////////////////////////////////////// 
假设这个webservice在http://www.a.com/MyViewDBService.asmx 
则作为客护端在站点b可以使用 
wsdl /l:cs /n:DBService /out:ViewDBServiceClient.cs http://www.w.com/MyViewDBService.asmx 
生成客户端文件 ViewDBServiceClient.cs 
用 csc /t:library /out:ViewDBServiceClient.dll ViewDBServiceClient.cs 编译dll 
编写客户端网页文件index.aspx 
<%@page language="C#" Codebehind="index.aspx.cs" AutoEventWireup="false" Inherits="Wmj.ViewDB"%> 
<html> 
<head> 
<title>我的留言板</title> 
</head> 
<body> 
<form runat="server"> 
<center> 
<asp:DataGrid id="dataGrid1" ItemStyle-BackColor="#AAAADD" AutoGenerateColumns="false" 
AlternatingItemStyle-BackColor="#CCCCFF" HeaderStyle-BackColor="#000000"  
HeaderStyle-HorizontalAlign="Center" 
HeaderStyle-ForeColor="#FFFFFF" PagerStyle-Mode="NumericPages" 
AllowPaging="true" PageSize="4" Font-Size="10pt" runat="server"> 
<columns> 
<asp:BoundColumn HeaderText="序号" DataField="ID"/> 
<asp:BoundColumn HeaderText="标题" DataField="Title"/> 
<asp:BoundColumn HeaderText="留言人" DataField="NoterName"/> 
<asp:BoundColumn HeaderText="留言时间" DataField="NoteTime" DataFormatString="{0:dd/MM/yyyy}"/> 
</columns> 
</asp:DataGrid> 
<asp:Label id="label1" runat="server"/> 
</center> 
</form> 
</body> 
</html> 

 

编写客户端文件的codebehind index.aspx.cs 
//////////////////////////////////////////////////////////////////// 
using System; 
using System.Web.UI; 
using System.Web.UI.WebControls; 
using System.Data; 
using System.Data.OleDb; 
using DBService; //引入客户端文件的名字空间 
namespace Wmj 

public class ViewDB : Page 

protected DataGrid dataGrid1; 
public ViewDB() 

this.Init+=new EventHandler(this.Page_Init); 

public void Page_Init(object sender,EventArgs e) 

this.Load+=new EventHandler(this.Page_Load); 
this.dataGrid1.PageIndexChanged+=new  

 

DataGridPageChangedEventHandler(this.DataGrid1_PageIndexChanged); 

 

public void Page_Load(object sender,EventArgs e) 

ViewDBService viewDBService=new ViewDBService(); 
//使用webservice 
dataGrid1.DataSource=viewDBService.ViewDB().Tables["NoteBoard"].DefaultView; 
if(!Page.IsPostBack) 

dataGrid1.CurrentPageIndex=0; 
dataGrid1.DataBind(); 


public void DataGrid1_PageIndexChanged(object sender,DataGridPageChangedEventArgs e) 

dataGrid1.CurrentPageIndex=e.NewPageIndex; 
dataGrid1.DataBind(); 


}

master8
  • 上一篇:将人民币的数字表示转化成大写表示
  • 下一篇:万维网创始人博客处女秀

  • 我要投稿  打印本文  推荐本文  加入收藏  返回顶部  关闭窗口
    搜模板(www.somoban.com) 原创网站模板交易平台
    阿里妈妈再掀疯狂采购风,网站广告位严重告急,急召天下站长
    基于PHP+MySQL的整站、模块、插件开发等或者按需求实现相应功能;
基于各PHP主流建站系统CMS,BBS,BLOG等的模板定制,完全手写代码;
整站数据迁移或备份恢复;网页代码优化、重构;整站常规SEO优化;网站技术支持;
点击了解详情...
    站长论坛
    • 验证码: