wangchao.org
添加收藏 | 博客
 
购物视频论坛IT业界自然风光美女图片王朝网络小游戏BT下载生活百科编程设计手机图片小说
 
笑话 | 水库 | 娱乐 | 体育 | 英语 | 宠物 | 美食 | 旅游 | 养生 | 手机 | 数码 | 汽车 | 珠宝 | 美容 | 装修 | 厨房 | 科普 | 动物 | 植物 | 影音 | 百科 | 知道 | 词典
  
 
 您好! 您现在位于: 王朝网络 → 编程设计 → 《在IE浏览器中使用Windows窗体控件(二)返回上一页 
 
1楼 

在IE浏览器中使用Windows窗体控件(二)

  网上购物、在线购物、购物搜索 欢迎光临本站购买图书、影视、音乐、数码、百货,手机等商品。

  在IE浏览器中使用Windows窗体控件(二)
  作者::Thiru Thangarathinam
  翻译:秋枫
  通过windows窗体控件访问Web Service
  窗体控件一个重要优点就是你可以通过它在客户端实现丰富的用户信息。比如说,你可以通过窗体控件对Web服务的访问从而在IE中显示而不需要重新刷新该页面。为了演示这点,我们先来创建一个Web服务,接着再来演示怎样通过窗体控件调用Web服务。
  创建Web service
  我们创建一个 Visual C# Asp.net web service 新项目,名字取为AuthorsWebService。
  建立以后,我们修改服务类名称为AuthorsService,同时在类里面增加一个GetAuthors方法到里面,该方法的代码如下:
  [WebMethod]
  public DataSet GetAuthors()
  {
   string connString = System.Configuration.ConfigurationSettings.AppSettings["connectionString"];
   SqlConnection sqlConn = new SqlConnection(connString);
   DataSet dstAuthors = new DataSet("Authors");
   SqlDataAdapter adapter = new SqlDataAdapter("Select * from Authors",sqlConn);
   adapter.Fill(dstAuthors,"Author");
   sqlConn.Close();
   sqlConn.Dispose();
   return dstAuthors;
  }
  上面方法的代码比较简单,我们把数据库连接字符串储存到了Web.config文件的appSettings节点上,如下:
  <appSettings>
   <add key="connectionString" value="server=localhost;uid=sa;pwd=thiru;database=Pubs"></add>
  </appSettings>
  上面代码中,
  我们创建了一个SqlConnnection实例,同时把上面的连接字符串作为参数传入。接着创建一个SqlDataAdapter对象,传入两个参数――查询字符串和SqlConnnection实例。调用SqlDataAdapter实例的Fill方法来执行数据库查询并把结果填充到DataSet。现在我们完成了Web服务的创建,接下去来建立一个他的一个客户端调用。
  创建windows窗体控件作为Web服务客户端
  在这里,我们是想用一个窗体控件来调用Web Service,因此新建一个Visual C#窗体控件项目取名AuthorsWebServiceClientControl:。
  完成后,修改默认用户控件名称为AuthorsControl.。我们在上面添加了一个DataGrid控件取名GridAuthors 同时添加一个按钮取名BtnClick。注册按钮的点击事件,在事件处理函数中,将会调用WebService。在这之前我们需要添加项目的Web引用,输入刚才创建的Web服务地址。编辑器会生成该服务的代理,添加Web服务引用如下:
  图

  服务代理创建以后,我们在按钮事件中添加代码:
  private void BtnClick_Click(object sender, System.EventArgs e)
  {
   this.Cursor = Cursors.WaitCursor;
   AuthorsWebServiceProxy.AuthorsService authorsSvc = new
   AuthorsWebServiceProxy.AuthorsService();
   this.GridAuthors.DataSource = authorsSvc.GetAuthors();
   this.Cursor = Cursors.Default;
  }
  在上面代码中,我们创建了web服务代理的一个实例,并调用GetAuthors方法把返回的数据集赋值给GridAuthors的DataSource属性。接着编译这个窗体控件,然后配置虚拟目录。
  创建Html页面和建立虚拟路径
  在这一步中,我们通过创建一个Html页面来使用上面创建的那个AuthorsWebServiceClientControl。下面是他的代码:
  <html>
  <body>
  <p>Authors Display Control<br><br>
  <object id="AuthorsControl1"
  classid="http:AuthorsWebServiceClientControl.dll#AuthorsWebServiceClientControl.AuthorsControl"
  height="500" width="500" VIEWASTEXT>
  </object>
  <br><br>
  </body>
  </html>
  现在我们需要创建一个虚拟目录使该控件能正常工作,并把AuthorsDisplay.htm和AuthorsWebServiceClientControl.dll放在一起。打开该浏览器输入地址,你就会看到一个按钮和一个空的DataGrid,如果你点击该命令按钮,控件就会调用Web服务同时把结果写到了DataGrid中。页面结果如下所示。

  在下一节中我们看看对进程的调试。

在IE浏览器中使用Windows窗体控件(二) 作者::Thiru Thangarathinam 翻译:秋枫 通过windows窗体控件访问Web Service 窗体控件一个重要优点就是你可以通过它在客户端实现丰富的用户信息。比如说,你可以通过窗体控件对Web服务的访问从而在IE中显示而不需要重新刷新该页面。为了演示这点,我们先来创建一个Web服务,接着再来演示怎样通过窗体控件调用Web服务。 创建Web service 我们创建一个 Visual C# Asp.net web service 新项目,名字取为AuthorsWebService。 建立以后,我们修改服务类名称为AuthorsService,同时在类里面增加一个GetAuthors方法到里面,该方法的代码如下: [WebMethod] public DataSet GetAuthors() { string connString = System.Configuration.ConfigurationSettings.AppSettings["connectionString"]; SqlConnection sqlConn = new SqlConnection(connString); DataSet dstAuthors = new DataSet("Authors"); SqlDataAdapter adapter = new SqlDataAdapter("Select * from Authors",sqlConn); adapter.Fill(dstAuthors,"Author"); sqlConn.Close(); sqlConn.Dispose(); return dstAuthors; } 上面方法的代码比较简单,我们把数据库连接字符串储存到了Web.config文件的appSettings节点上,如下: <appSettings> <add key="connectionString" value="server=localhost;uid=sa;pwd=thiru;database=Pubs"></add> </appSettings> 上面代码中, 我们创建了一个SqlConnnection实例,同时把上面的连接字符串作为参数传入。接着创建一个SqlDataAdapter对象,传入两个参数――查询字符串和SqlConnnection实例。调用SqlDataAdapter实例的Fill方法来执行数据库查询并把结果填充到DataSet。现在我们完成了Web服务的创建,接下去来建立一个他的一个客户端调用。 创建windows窗体控件作为Web服务客户端 在这里,我们是想用一个窗体控件来调用Web Service,因此新建一个Visual C#窗体控件项目取名AuthorsWebServiceClientControl:。 完成后,修改默认用户控件名称为AuthorsControl.。我们在上面添加了一个DataGrid控件取名GridAuthors 同时添加一个按钮取名BtnClick。注册按钮的点击事件,在事件处理函数中,将会调用WebService。在这之前我们需要添加项目的Web引用,输入刚才创建的Web服务地址。编辑器会生成该服务的代理,添加Web服务引用如下: 图 [url=http://www.wangchao.net.cn/bbsdetail_35636.html][img]http://dev.csdn.net/Develop/ArticleImages/27/27639/CSDN_Dev_Image_2004-5-91552050.gif[/img][/url] 服务代理创建以后,我们在按钮事件中添加代码: private void BtnClick_Click(object sender, System.EventArgs e) { this.Cursor = Cursors.WaitCursor; AuthorsWebServiceProxy.AuthorsService authorsSvc = new AuthorsWebServiceProxy.AuthorsService(); this.GridAuthors.DataSource = authorsSvc.GetAuthors(); this.Cursor = Cursors.Default; } 在上面代码中,我们创建了web服务代理的一个实例,并调用GetAuthors方法把返回的数据集赋值给GridAuthors的DataSource属性。接着编译这个窗体控件,然后配置虚拟目录。 创建Html页面和建立虚拟路径 在这一步中,我们通过创建一个Html页面来使用上面创建的那个AuthorsWebServiceClientControl。下面是他的代码: <html> <body> <p>Authors Display Control<br><br> <object id="AuthorsControl1" classid="http:AuthorsWebServiceClientControl.dll#AuthorsWebServiceClientControl.AuthorsControl" height="500" width="500" VIEWASTEXT> </object> <br><br> </body> </html> 现在我们需要创建一个虚拟目录使该控件能正常工作,并把AuthorsDisplay.htm和AuthorsWebServiceClientControl.dll放在一起。打开该浏览器输入地址,你就会看到一个按钮和一个空的DataGrid,如果你点击该命令按钮,控件就会调用Web服务同时把结果写到了DataGrid中。页面结果如下所示。 [url=http://www.wangchao.net.cn/bbsdetail_35636.html][img]http://dev.csdn.net/Develop/ArticleImages/27/27639/CSDN_Dev_Image_2004-5-91552052.gif[/img][/url] 在下一节中我们看看对进程的调试。

 
标签: IE  Windows  中使用  控件  浏览  窗体  
 
您可以将本页贴到其他网站
UBB代码HTML代码
 
 
 
 
手机图片下载手机图片下载手机图片下载手机图片下载手机图片下载手机图片下载更多图铃
 
 
 
 
 
 
 更多内容
 ·在IE浏览器中使用Windows窗体控件 ·从"在 Internet Explorer 中 ·Windows Server操作系统和本地环 ·用WinRAR制作安装程序
 ·负载均衡更高效 —— Windows Se ·Windows 2000 的注册表备份和恢复 ·Linux下Apache服务器的配置! ·用WinDbg探索CLR世界 [3] 跟踪方
 ·WindowsForm登陆窗体的建立 ·从一个问题程序看Windows的1/10秒 ·IIS6中对站点标识符进行修改 ·Linux编程
 ·探测远程Windows主机的NetBIOS信 ·改造 MFC 编写的控件在 Win32ASM ·用WinDbg探索CLR世界 [2] 线程 ·用WinDbg探索CLR世界[1] - 安装与
 ·热爱Linux ·用IE登录Linux服务器上的em出现的 ·WinForm中类似WebForm中的CheckB ·wincvs中branch和tag使用专题
 ·Linux/Unix终端图形库curses简介 ·5年后完全由汉语开发的操作系统能 ·Windows消息大全祥解 ·ARM Linux 进程调度(3)
 
 
 
最新评论  点此查看所有评论
 
 
 
 
发表评论(支持UBB码)


验证码:  
 
 
 
 
© 2005- 王朝网络 版权所有