注册 登录
编程论坛 PowerBuilder

用PB开发WEB应用

freele_china 发布于 2009-07-18 11:00, 2773 次点击
用PB开发WEB应用
烟台教育学院网络中心 孙连三
  一、PB Window plug -in 的用途
  PowerBuilder Window plug -in 的用途是在HTML 页面中插入PowerBuilder 中定义的窗口对象,此窗口对象上定义的功能在浏览器中一样被执行,相当于在浏览器客户端执行PowerBuilder 应用,因此可以将PowerBuilder 应用发布到Web 应用上。当浏览器访问内嵌了Window plug -in 的HTML 页面时,窗口会被显示在页面的一块固定位置上。用户可以使用页面上定义的控制,触发相应事件,执行相应代码。当浏览器浏览下一个页面时,前面已打开的窗口被自动关闭,打开窗口所需的PowerBuilder 动态链接库被从内存中卸载。插入在页面中的Window 对象及相关对象,如数据窗口对象,被存储在PowerBuilder 中定义的动态链接库(.PBD 文件)中,这些动态链接库被放置在Web 服务器上文档目录下。当页面被浏览器调用时这些动态链接库文件被卸载到客户机器上。浏览器和Web 服务器在PowerBuilder Window plug -in 的操作中,运行步骤如下:
  1、浏览器访问Web 服务器,检索HTML 文档,Web 服务器将文档传给浏览器。
  2、浏览器识别到Embed 元素时,在页面上预留插入元素所需的空间,并请求Web 服务器卸载.PBD 文件。
  3、Web 服务器给浏览器传送表明PBD 文件MIME 类型的标识符application/vnd.powerbuilder6 或application/vnd.powerbuilder6 -s。
  4、浏览器接收到PBD 文件的MIME 类型并准备接收PBD 文件。
  5、Web 服务器给浏览器传送PBD 文件。
  6、浏览器接收到PBD 文件。
  7、浏览器查找并调用对应与插入件MIME 类型(application/vnd.powerbuilder6)的动态库文件,该文件在浏览器目录下的plug -in。对于Window plug -in,该文件为NPPBA60.DLL 或NPPBS60.DLL。
  8、NPPBA60.DLL 或NPPBS60.DLL 文件调用Powerbuilder 的运行环境动态库。
  9、如Embed 元素定义了LIBRARY 属性,则再重复执行上面所述的第三步到第六步,直至所有PBD 文件被卸载到浏览器端。
  10、被插入的Child 窗口被显示在浏览器中,并执行其Open 事件下的事件处理程序。如此程序段中有CommandParm 函数调用,则会向浏览器取得Embed 元素中的COMMANDPARM 属性值。
  应用实例
  二、运行环境
  服务器端:Windows NT 4.0、IIS 4.0,SQL Server 6.5
  客户端:Windows 98、IE 4.01 、PB6.5
  三、IIS4.0 的配置
  单击开始| 程序|Windows NT 4.0 Option Pack|Microsoft Internet Information Server|Internet 服务管理器,进入Microsoft 管理控制台,在Internet Information Server 目录下的*SUN 服务器上单击鼠标右键,单击属性,在" 计算机MIME 映射" 框中,单击" 文件类型",单击" 新增类型",在" 相关的扩展名" 框中输入:.PBD,在" 内容类型" 框中输入:application/vnd.powerbuilder6,单击确定,退出Microsoft 管理控制台。
  四、客户端配置
  1. 运行C:\Windows\REGEDIT.EXE
  在HKEY_LOCAL_MACHINE 注册部分添加:
  SOFTWARE\Microsoft\Internet
   Explorer\Plugins\Extension\.psr
  SOFTWARE\Microsoft\Internet
  Explorer\Plugins\Extension\.pbd
  SOFTWARE\Microsoft\Internet
  Explorer\Plugins\MIME\application/datawindow
  SOFTWARE\Microsoft\Internet Explorer
   \Plugins\MIME\application/vnd.powerbuilder 6
  2. 在autoexec.bat 文件中添加如下一行:
  PATH D:\SYBASE\SHARED
  3. 打开我的电脑, 双击控制面板, 打开ODBC 数据源, 在系统数据源中, 单击" 添加", 选定SQL Server 驱动程序安装数据源, 单击" 完成", 在建立新的数据源到SQL 服务器窗口中, 在" 名称" 框中输入:sql,在" 描述" 框中输入:sql,在" 服务器" 框中输入:SUN,在"SQL 服务器应该如何验证登录标识号的真伪?" 栏中,分两种情况选择:
  a、客户端没有安装SQL Server 6.5 客户端软件,选择" 使用Windows NT 验证的网络登录标识号" 项,选择" 连接SQL 服务器以获得用于附加配置选项的默认设置" 项,单击" 下一步";或选择" 使用SQL 服务器验证的由用户输入的登录标识号和密码" 项,选择" 连接SQL 服务器以获得用于附加配置选项的默认设置" 项,在" 登录标识号" 框中输入:sa,在" 密码" 框中输入:sls,单击" 下一步"。
  b、客户端安装了SQL Server 6.5 客户端软件,选择" 使用Windows NT 验证的网络登录标识号" 项,单击" 客户端配置" 框,在弹出的窗口中,单击"Net Library",在"Default Network" 框中,从下拉列表框中选择:TCP/IP Sockets,单击"Advanced",在"Client Configuration" 框中,"Server" 框中输入:[url=http://www.ytet.]www.ytet.[/url],"Network Protocol" 框中选择:TCP/IP Sockets,"Connection String" 框中输入:dsn='connectstring=sql;uid=wlzx;pwd=wlzx',单击"Done" 按钮完成" 客户端配置",选择" 连接SQL 服务器以获得用于附加配置选项的默认设置" 项,单击" 下一步";或选择" 使用SQL 服务器验证的由用户输入的登录标识号和密码" 项,单击" 客户端配置" 框,在弹出的窗口中,单击"Net Library",在"Default Network" 框中,从下拉列表框中选择:TCP/IP Sockets,单击"Advanced",在"Client Configuration" 框中,"Server" 框中输入:[url=http://www.ytet.]www.ytet.[/url],"Network Protocol" 框中选择:TCP/IP Sockets,"Connection String" 框中输入:dsn='connectstring=sql;uid=sa;pwd=sls',单击"Done" 按钮完成" 客户端配置",选择" 连接SQL 服务器以获得用于附加配置选项的默认设置" 项,在" 登录标识号" 框中输入:sa,在" 密码" 框中输入:sls,单击" 下一步"。
  在下一窗口中,选择" 改变默认的数据库到",单击下拉列表框,选择LLL 数据库,选择" 为准备好的SQL 语句创建临时存储过程并放弃存储程" 中的" 只有当断开时",选择" 使用ANSI 引用的标识符",选择" 使用ANSI 的空值,填充和警告",单击" 下一步",在下一窗口中,在" 您希望如何执行字符集转换?" 项中选择" 让SQL 服务器ODBC 驱动程序选择转换方法",单击" 下一步",在下一窗口中,单击" 完成",在下一窗口中,单击" 确认",完成系统数据源的添加。
  五、创建PBD 文件
  1. 运行PB6.5,在SQL Server 6.5 的数据库LLL 上创建一个新表DAK(档案库),字段如下:BH(编号)、XM(姓名)、XB (性别)、CSRQ(出生日期)、ZZMM(政治面貌)、WHCD(文化程度)、BM(所在部门)、JG(籍贯),定义BH(编号)为主键。建立一个新的Grid 类型的数据窗口,选择DAK 表中的全部字段,将所在部门、性别、政治面貌、文化程度等字段的编辑类型设为下拉列表框,并填上相应的显示值和数据值,如性别字段:显示值分别为男和女,数据值分别为1 和2。移动鼠标到脚注区(Footer),按住鼠标左键下拉一定区域,放开鼠标左键,然后在脚注区放置3 个按钮对象,将其显示文字分别改为:插入、删除、更新,将这3 个按钮属性中的General 部分的Action 分别选择为:Insert Row、Delete Row、Update,存此窗口为dw_test。
  2. 点击窗口画笔,建立一个新的Child 类型的窗口,在窗口中添加数据窗口dw_test,定义窗口上的实例变量mytansaction,为窗口的OPEN 事件添加如下代码:
    mytransaction=create transaction
    mytransaction.dbms="ODBC"
    mytransaction.DBParm="Connectstring='DSN
=sql;UID=sa;PWD=sls'"
    connect using mytransaction;
    dw_1.settransobject(mytransaction)
    dw_1.retrieve ()
  存窗口为w_test,点击Library 画笔,点击菜单项Library 的Build Runtime Library 项,点击"OK",开始建造TEST.PBD 文件。
  六、拷贝TEST.PBD文件到Web服务器中有读权限的目录中
  本例拷贝TEST.PBD 文件到NT 服务器上的d:\inetpub\wwwroot 子目录下。
  七、在NT 服务器上的d:\inetpub\wwwroot子目录下建立HTML文件WINPLUG.HTM
  WINPLUG.HTM 文件内容如下
< html >
< head >
< title > PowerBuilder Window Plugin Example< /title >
< meta NAME="GENERATOR"
 CONTENT="Microsoft FrontPage 3.0" >
< /head >
< body BGCOLOR=" #FFFFFF" >
< h2 > PowerBuilder Window Plugin Example< /h2 >
< hr >
< p > < embed SRC="test.pbd" WIDTH="550"
  HEIGHT="400" WINDOW="w_test" > < /p >
< hr >
< /body >
< /html >
  八、客户端输入地址
  打开Internet Explorer,输入地址:HTTP:
//WWW.YTET.,回车,浏览器里显示如下:
 
  用户可在客户端通过浏览器完成对记录的添加、删除等操作。 
1 回复
#2
freele_china2009-07-18 11:01
1