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

2016-01-29 17:27 7 1 收藏

用ASP、VB和XML建立互联网应用程序(2),用ASP、VB和XML建立互联网应用程序(2)

【 tulaoshi.com - ASP 】

  让我们先分析一下客户端/服务器应用程序。在一个标准的客户端/服务器应用程序中,在应用程序开始时,你能够初始化数据库连接字符串,这就意味着,客户有使用数据库连接字符串的权利,这包括用户名和口令。但是客观情况如果不允许你在网络上发送这些信息的话,你就必需在不联接数据库的情况下直接从客户端取得数据发送给客户。那么解决方案之一就是在服务器上创建一个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信息。" & "Description: " & xml.parseError.reason & "<br>Line: " & 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 ("数据集发生存储错误" & "在命令'" & CommandText & "': " &    Err.Description)
     Response.end
    end if

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

  Sub responseError(sDescription)
   Response.Write "<response><data>错误: " & sDescription & "</data></response>"
   Response.end
  End Sub



 

来源:http://www.tulaoshi.com/n/20160129/1501412.html

延伸阅读
标签: Web开发
简介 Perl的普及与互联网的蓬勃发展有直接的关系。在互联网发展的早期,人们发现仅仅使用静态的HTML文档不能生成有效的交互式环境,于是引进了公用网关接口(CGI)的概念。Perl强大的功能和容易扩充的特性使得它成为开发CGI应用最自然的选择,并由此迅速地成为CGI脚本的首选语言。CGI本身并非十全十美。但由于得到了众多开发商的青睐,CGI的应...
标签: 理财 投资
今年 互联网 金融的发展用“异军突起”来形容是最贴切不过了,但是如何投资都有风险,咱们今天就来讲讲如何规避互联网金融雷区 现如今,投资者投资渠道狭窄。传统银行理财,因线下运营成本过高,收益普遍偏低。部分人选择投资收益过高的P2P个人借贷平台,但其中有些P2P平台盲目追求交易量扩张,忽视了其中蕴含的信用风险。...
标签: 育儿知识
你知道吗?宝宝大脑内有个互联网,它越密集,说明宝宝大脑发育越好。DHA是使这个互联网更发达的秘密武器,丰富的早教同样可以使它更完善。全球科学研究相继证实:人的大脑里,确实存在一个“互联网”。在深入探讨中,国际学术界普遍认为:“大脑互联网”的发达程度是脑部发育是否完善、聪明与否的重要体现。作为大脑最基本构成的单位,神经细胞...
网银、第三方支付、移动支付作为 互联网 支付的主要表现形式。互联网支付方式有哪些? 简介: 当支付遇到互联网,一场革命自然不可避免。成为现实的是传统的现金支付已经“退居二线”,各种在线支付方式成为人们日常消费的主要支付方式。银行推出的网银以及民营企业推出的各种各样的第三方支付平台大大方便了人们的生活...
♦ 引言   在上讲中,我们介绍了如何利用Record Store把数据保存在终端内。本讲,我们将阐述MIDP Java网络的相关功能。由于N800终端只能使用HTTP通信,所以我们将以HTTP为主要范例进行讲解。到目前为止,只能制作终端内的单机型应用程序,假如利用网络,连接网络服务器,那么就能够制作出多种应用程序。 1. 利用网络  ...

经验教程

511

收藏

5
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部