`
hsyzijvaa
  • 浏览: 111816 次
  • 性别: Icon_minigender_1
  • 来自: 成都
社区版块
存档分类
最新评论

OpenLaszlo在Resin上的部署以及开发

    博客分类:
  • java
阅读更多
    早就关注过openlaszlo这个开源的ria的东东了,感觉做出的界面还是比较美观的,但由于时间原因一直都没有亲自尝试使用,正好前几天有个小的需求,所以就拿来进行一下实验,看看效果如何。
由于公司用的服务器都是apache+resin的,在网上找了很久,也没有找到关于openlaszlo与resin整合的资料。不过好在j2ee标准针对每个j2ee容器应该还是差别不大的。于是下载完了完整的for unix的版本以后,直接把下边的web-inf和lps目录copy出来,在resin里面建立一个webapp,将这两个文件夹复制进去。 然后启动resin。
写一个最简单的lzx文件,内容如下:
<canvas><br/><text>hello,world!</text><br/></canvas>
直接在浏览器浏览<a href='http://localhost:8080/laszlo/main.lzx'>http://localhost:8080/laszlo/main.lzx</a>
这时如果浏览器出现了一个空白的flash,并且左上角有"hello,world"的字,说明配置已经成功了。
如果提示错误,就得查看一下自己的配置了,如果是一个全新的resin问题可能不会很大,但如果是已经跑了应用的resin,lib下面有一些常用的jar,就可能会出问题了,有时会出现xml解析器相关的错误,这有可能是xercesimpl这个包活着是jdom的版本过低造成的,换上一个最新版本应该就会ok。
再写一个带窗口的程序:
<canvas><br/><text>hello,world!</text><br/><window x="10" y="10" width="400" height="300" title="测试" font="宋体" fontsize="14"><br/></window><br/></canvas>
再浏览一下,很可能会出现如下的错误:
<h1>compilation errors</h1><code class='error'>base/basecomponent.lzx:50:1: syntax error: the token "{" was not expected at this position.</code>
<code class='error'>不知道是否还是xml解析器的问题,打开base/basecomponent.lzx文件,找到提示的第50行,发现这里的属性值中间有换行符,所以可能解析出错了。将属性的值中间的换行删掉,再刷新页面,又发现另外一个地方一样的这样的提示,再找到修改,就这样一直找一直改,提示哪个文件就修改哪个文件,最后终于出现了期待已久的页面。不过这样的工作量实在很大,而且解决的不彻底,但目前我还未找到有效的办法解决,只好用这种笨方法暂时解决一下了,有谁知道如何解决这个问题的就拜托指点一下了。</code>
<code class='error'>经过千辛万苦,还好终于把环境和程序都调试通过了,感觉界面很清爽,而且比普通的html页面使用起来也方便,数据的请求和提交也不用再刷新页面了。这样比普通的ajax效率更高,而且支持更好,用ie和firefox都测试ok。事实上只要是支持flash的浏览器应该都会支持的不错。</code>
<code class='error'><code class='error'>另外,运行了一段时间以后,可能会出现out of memory的错误,这是由于分配给jvm的内存不够了,可以通过类似./<font size='2'>httpd.sh -xms128m -xmx256m 的方式启动resin,这样基本上就会解决。</font></code>
<code class='error'><font size='2'>另外,中文显示的问题,如果将lzx文件保存成utf-8格式显示的中文就没有问题了,否则中文会是乱码的。</font></code>
</code><code class='error'>研究了两天的时间,大概也了解了openlaszlo的运行方式、数据绑定和更新等一系列的东东,感觉这个东西还真的是比较强大。只是目前国内似乎做这方面开发的非常少,资料也不怎么好找,所以遇到问题只好去查english的帮助文档了。不知以后是否会有更多的人来支持这个强大开源的ria解决方案。</code>
<code class='error'>最后献上做的那个小应用的源码:</code>
<code class='error'>很简单,首先登录,然后根据手机号或者用户id查询用户信息:</code>
<code class='error'><canvas></code>
<code class='error'> <window name="loginwin" width="300" height="230" x="350" y="700" font="宋体" fontsize="14" title="登录窗口"><br/>  <animator attribute="y" to="180" duration="1500"/><br/>  <method event="oninit"><br/>   <br/>  </method><br/>  <view id="msgview" x="70" y="15"><br/>   <text id="message">输入用户名密码登录</text><br/>  </view><br/>  <view x="50" y="50"><br/>   <simplelayout axis="y" spacing="10"/><br/>   <view><br/>    <simplelayout axis="x" spacing="10"/><br/>    <text>用户名</text><br/>    <edittext id="username"></edittext><br/>   </view><br/>   <view><br/>    <simplelayout axis="x" spacing="10"/><br/>    <text>密 码</text><br/>    <edittext id="password"></edittext><br/>   </view><br/>   <view><br/>    <simplelayout axis="x" spacing="30"/><br/>    <button isdefault="true" onclick="check()">登 录    <br/>    </button><br/>    <button>取 消<br/>     <method event="onclick"><br/>      canvas.loginwin.close();<br/>     </method><br/>    </button><br/>   </view><br/>  </view><br/> </window><br/> <script><br/>  function check(){<br/>   var ds = canvas.datasets.login;<br/>   var p = new lzparam();</code>
<code class='error'>   p.addvalue("u",username.gettext());<br/>   p.addvalue("p",password.gettext());<br/>   ds.setquerystring(p);<br/>   ds.dorequest();<br/>   debug.write("login..." + username.text + " " + password.text);<br/>  }<br/> </script><br/> <dataset type="http" name="login" querystring="u=xiaowei&amp;amp;p=xiaowei" src="login.jsp" request="false"/><br/> <datapointer xpath="login:/result"><br/>  <handler name="ondata"><br/>  <![cdata[<br/>   <br/>   debug.write("recv data...");<br/>   var result = this.xpathquery("*/text()");<br/>   debug.write("result=" + result);<br/>   if(result != "ok")<br/>   {<br/>    msgview.setx(100);<br/>    message.settext(result);      <br/>   }else<br/>   {  <br/>    msgview.setx(100);<br/>    message.settext("<font color=\"#00ff00\">登录成功!</font>");<br/>    canvas.loginwin.animate("y",900,1500,false);<br/>    canvas.datawin.setvisible(true);<br/>    canvas.datawin.myanimator.dostart();<br/>   }<br/>  ]]><br/>  </handler><br/>  <handler name="onerror"><br/>  <![cdata[   <br/>   debug.write("on error");<br/>  ]]><br/>  </handler><br/> </datapointer><br/> </code>
<code class='error'> <dataset name="user" src="query.jsp" request="true" type="http"/></code>
<code class='error'> <window name="datawin" x="200" y="900" width="500" height="400" title="查询邦号" font="宋体" fontsize="14"><br/>  <animator name="myanimator" attribute="y" to="120" duration="1500" start="false"/><br/>  <method event="oninit"><br/>   this.setvisible(false);<br/>  </method><br/>  <view x="10" y="20" width="500" height="50"><br/>   <simplelayout axis="x" spacing="10"/><br/>   <text>查询方式</text><br/>   <combobox id="q_type" editable="false" font="宋体" fontsize="14"><br/>    <textlistitem font="宋体" fontsize="14" text="userid"/><br/>    <textlistitem font="宋体" fontsize="14" text="mobile"/><br/>   </combobox><br/>   <text>输入号码</text><br/>   <edittext id="number" width="120" height="22"></edittext><br/>   <button isdefault="true">查 询<br/>    <method event="onclick"><br/>     <![cdata[<br/>      var p = new lzparam();<br/>      debug.write(q_type.getvalue());<br/>      p.addvalue("type",q_type.getvalue());<br/>      p.addvalue("value",number.gettext());<br/>      user.setquerystring(p);<br/>      user.dorequest();<br/>     ]]><br/>    </method><br/>   </button><br/>  </view><br/>  <view x="10" y="70" width="500" height="50"><br/>   <simplelayout axis="x" spacing="10"/>           <br/>   <grid datapath="user:/users/"><br/>    <gridtext datapath="@userid" sortable="true" sortpath="@userid" editable="false" text="用户邦号"/><br/>    <gridtext datapath="@passwd" sortable="true" sortpath="@passwd" editable="false" text="用户密码"/><br/>    <gridtext datapath="@name" sortable="true" sortpath="@name" editable="false" text="昵称"/><br/>    <gridtext datapath="@mob_num" sortable="true" sortpath="@mob_num" editable="false" text="手机号码"/><br/>    <gridtext datapath="@bind" sortable="true" sortpath="@bind" editable="false" text="绑定情况"/><br/>   </grid><br/>   <br/>  </view></code>
<code class='error'> </window></code>
<code class='error'/>
<code class='error'></canvas></code>
 
0
1
分享到:
评论

相关推荐

    OpenLaszlo-SAMSIG-05.ppt

    ### OpenLaszlo:领先的开源富互联网应用开发平台 #### 一、项目概述与历史 OpenLaszlo 是一个开放源代码平台,旨在为全球范围内的互联网提供丰富的应用程序开发及交付服务。它由 Laszlo Systems 公司于 2001 年...

    openlaszlo本地帮助文档

    LZX的灵活性在于它可以编译为Flash或JavaScript,这意味着OpenLaszlo的应用程序可以在多种浏览器和操作系统上运行,包括桌面和移动设备。 手册中的"labs.openlaszlo.org"可能是一个指向OpenLaszlo官方实验室的链接...

    OpenLaszlo —— 一个快速构建和部署富 Internet 应用程序的平台

    OpenLaszlo —— 一个快速构建和部署富 Internet 应用程序的平台 -- Linux,C,C++,Java,Ajax,XML,perl,php,python,ruby,MySQL,Gnome,KDE,Qt,Gtk,bash,shell,嵌入式,网络,信息安全,操作系统,数据结构,编译原理

    Applet & Openlaszlo

    Applet和Openlaszlo是两个在Web开发领域中用于创建动态、交互式用户体验的技术。本文将深入探讨这两个概念以及它们之间的通信机制。 首先,Applet是Java编程语言的一个组成部分,它允许开发者创建可以在Web浏览器中...

    openlaszlo-4.9.0-windows-dev-install.part2.rar

    openlaszlo应用程序开发使用的是基于XML的LZX语言,它可以被编译成DHMTL,SWF等格式。 openlaszlo可作为openmeetings客户端的编译。 因安装程序90+MB,所以切分为两个压缩包。 openlaszlo-4.9.0-windows-dev-install....

    openlaszlo-4.9.0-windows-dev-install.part1.rar

    openlaszlo应用程序开发使用的是基于XML的LZX语言,它可以被编译成DHMTL,SWF等格式。 openlaszlo可作为openmeetings客户端的编译。 因安装程序90+MB,所以切分为两个压缩包。 openlaszlo-4.9.0-windows-dev-install....

    openlaszlo-4.7.3-windows-dev-install (1).exe

    openlaszlo应用程序开发使用的是基于XML的LZX语言,它可以被编译成DHMTL,SWF等格式。 是openmeetings视频会议系统的默认开发编译工具。

    openlaszlo计算器

    这是用Openlaszlo开发的计算器程序,可以实现基本的计算操作。 我是刚学openlaszlo,欢迎朋友们提出宝贵意见!

    Laszlo技术手册续

    LZX文件在Laszlo Presentation Server (LPS)上运行,该服务器将LZX编译为Java Servlet,能够在Java Servlet容器中运行。OpenLaszlo Server是一个完整的解决方案,包含了LPS和Tomcat,使得Laszlo应用能够无缝集成到...

    OpenLaszlo-开源

    这种跨平台的特性使得OpenLaszlo成为那些希望其应用能在各种设备和操作系统上运行的开发者的理想选择。 在"lps-4.9.0-src"这个压缩包中,很可能是OpenLaszlo的源代码文件,版本为4.9.0。源代码的获取意味着开发者...

    论文研究-使用OpenLaszlo构建J2EE中的RIA程序 .pdf

    使用OpenLaszlo构建J2EE中的RIA程序,高春阳,龚群侃,当前,Web 应用程序就要进入了一个新的时期,富互联网客户端(RIA ,Rich Internet Application) 以其极大地用户交互性、优秀的外观设计、良好��

    Openlaslzo+jsf

    这意味着OpenLaszlo已经成功部署到了Tomcat服务器上。 ##### 2.2 运行示例LZX文件 - 在浏览器中输入以下URL:`http://localhost:8080/openlaszlo-3.3.3-servlet/my-apps/copy-of-hello.lzx?lzt=html`。稍等片刻后...

    Laszlo技术手册

    在技术开发部分,手册探讨了OpenLaszlo的语法结构,包括两种部署方式、组件系统、事件处理、约束机制和动画。特别是动画标记的使用,如,为创建复杂的动画效果提供了可能。数据绑定特性和远程过程调用(RPC)的介绍...

    spket1.6.18

    OpenLaszlo结合了XML和脚本语言,允许开发者使用单一的源代码在Flash和HTML5之间进行部署。Spket对OpenLaszlo的支持意味着开发者可以享受到与JavaScript同样的代码辅助功能,如智能感知、代码导航和重构,这使得...

    geoar:WMSWFS OpenLaszlo 客户端

    它是在 LZX (OpenLaszlo) 上开发的,因此它向用户的浏览器提供 dhtml 或 flash,从而提供在它们之间进行选择的机会,但只有一个服务器的源代码。版本遵循 [语义版本规范] ( ) 当前版本 &gt; 1.5.0作者

    openMeetings二次开发高手的七篇文章

    PhMeetings是基于开源WEB视频会议系统OpenMeetings开发的一个实验性...由于资料的缺乏以及对OpenLaszlo编程的陌生,其中艰辛不足为外人道。今日发一声感慨:如果你想折磨一个程序员,那就让他去干开源软件的二次开发!

    OpenMeeting二次开发

    正如文章所述,OpenMeeting的二次开发之路充满艰辛,尤其是在对OpenLaszlo编程不熟悉的情况下,整个过程更是困难重重。 #### PhMeetings:OpenMeeting的商业版 PhMeetings是基于OpenMeeting开发的一款实验性商业...

    开源BI平台Openi的开发数据仓库系统.docx

    本文基于开源BI平台Openi的数据仓库系统进行了整体设计与开发,重点介绍了商业智能系统的基本概念、当前市场趋势以及具体的系统设计细节。通过这样的设计与开发,旨在为企业提供一个高效、灵活的数据分析平台,帮助...

    huoyan.zip_火焰识别c++

    总的来说,"huoyan.zip_火焰识别c++"这个项目涵盖了C++编程、API接口使用、图像处理、计算机视觉、可能的机器学习应用,以及与富互联网应用开发平台OpenLaszlo的结合。对于想要深入理解和实践这些领域的开发者来说,...

    Laszlo与web工程

    【Laszlo 与 Web 应用】 Laszlo 是一个开源项目,它遵循 GNU General Public License (GPL) 协议。该项目的核心是 LZX 文件,这...在实际开发中,可以根据具体需求调整配置,优化性能,以及解决可能出现的兼容性问题。

Global site tag (gtag.js) - Google Analytics