• 软件测试技术
  • 软件测试博客
  • 软件测试视频
  • 开源软件测试技术
  • 软件测试论坛
  • 软件测试沙龙
  • 软件测试资料下载
  • 软件测试杂志
  • 软件测试人才招聘
    暂时没有公告

字号: | 推荐给好友 上一篇 | 下一篇

ASP、VB和XML建互联网应用程序2

发布: 2007-9-07 19:42 | 作者: Wayne 天极网 | 来源: eNet论坛 | 查看: 17次 | 进入软件测试论坛讨论

领测软件测试网 用ASP、VB和XML建立互联网应用程序(2)


让我们先分析一下客户端/服务器应用程序。在一个标准的客户端/服务器应用程序中,在应用程序开始时,你能够初始化数据库连接字符串,这就意味着,客户有使用数据库连接字符串的权利,这包括用户名和口令。但是客观情况如果不允许你在网络上发送这些信息的话,你就必需在不联接数据库的情况下直接从客户端取得数据发送给客户。那么解决方案之一就是在服务器上创建一个ASP页(在本例中称为getData.asp)接收特定格式的POST数据,它要求一个包含XML字符串,用来创建ADO对象并运行存储过程或动态SQL语句命令。如果信息有效的话,getData.asp执行存储过程,并返回一个XML格式的数据集、返回值列表或错误页面信息的XML字符串。对于返回数据的命令,客户端要么重新实例化要么返回值或使用XML DOM(Document Object Model文档对象模型)格式的错误页面。

  好,下面就让我们来讨论一下如何实现这个页面吧!

  getData.asp页面首先使用一个DOMDocument对象来保存客户端发送的数据:

  '创建DOMDocument对象
  Set xml = Server.CreateObject ('msxml2.DOMDocument')
  xml.async = False

  然后,它装载POST数据

  '装载POST数据
  xml.Load Request
  If xml.parseError.errorCode <> 0 Then
   Call responseError ('不能装载XML信息。' amp; 'Description: ' amp; xml.parseError.reason amp; '<br>Line: ' amp; xml.parseError.Line)
  End If

  它能够返回commandtext元素值和returndata或returnvalue元素值。下面我只给出返回commandtext元素值的代码,其余代码请参看我下面所附的源程序。

  Set N = xml.selectSingleNode('command/commandtext')
  If N Is Nothing Then
   Call responseError ('缺少 <sp_name> 参数。')
  Else sp_name = N.Text
  End If

  接着,应该让页面创建一个Command对象,读入所有<param>元素,并且为request中的每一个元素创建一个参数。最后,让页面打开一个连接使用存储过程adExecuteNoRecords选项来执行request。

  set conn = Server.CreateObject('ADODB.Connection')
  conn.Mode=adModeReadWrite
  conn.open Application('ConnectionString')
  set cm.ActiveConnection=conn
  ' 返回数据
  if not returnsData then
    cm.Execute
  else
   set R = server.CreateObject('ADODB.Recordset')
   R.CursorLocation = adUseClient
   R.Open cm, ,adOpenStatic, adLockReadOnly
  end if

  如果能够返回数据的话,那么returnData变量就为真值,并且把结果数据集返回到客户端,仍然是一个XML文档。

  if returnsData then
   R.Save Response, adPersistXML
    if err.number <> 0 then
     call responseError ('数据集发生存储错误' amp; '在命令'' amp; CommandText amp; '': ' amp;    Err.Description)
     Response.end
    end if

  如果输出参数返回值,那么这个页面将返回一个包含这些值的XML字符串。文档的根元素是一个<values>标记,每一个返回值都有其相应的子元素,如果发生任何错误,页面都会格式化并返回一个包含错误信息的XML字符串:

  Sub responseError(sDescription)
   Response.Write '<response><data>错误: ' amp; sDescription amp; '</data></response>'
   Response.end
  End Sub


延伸阅读

文章来源于领测软件测试网 https://www.ltesting.net/


关于领测软件测试网 | 领测软件测试网合作伙伴 | 广告服务 | 投稿指南 | 联系我们 | 网站地图 | 友情链接
版权所有(C) 2003-2010 TestAge(领测软件测试网)|领测国际科技(北京)有限公司|软件测试工程师培训网 All Rights Reserved
北京市海淀区中关村南大街9号北京理工科技大厦1402室 京ICP备10010545号-5
技术支持和业务联系:info@testage.com.cn 电话:010-51297073

软件测试 | 领测国际ISTQBISTQB官网TMMiTMMi认证国际软件测试工程师认证领测软件测试网