没有找到合适的产品?
联系客服协助选型:023-68661681
提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
翻译|其它|编辑:郝浩|2007-12-10 13:38:26.000|阅读 717 次
概述:
# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>
一、方法
WebLogic 页面与数据通信时,一般采用 Java 控件直接访问数据连接池,数据的直接操作都定义在
Java 控件中,页面流做为数据的逻辑处理单元,普通页面做为显示层。可以看出 WebLogic 这个方法是
典型的三层结构,数据层(Java 控件),业务逻辑层(页面流),显示层(页面)
二、建立连接池,数据源
配置 config.xml 文件,这里用的是 WebLogic 自带的E:\bea\weblogic81\samples\domains\workshop
的 cgServer。
<JDBCConnectionPool DriverName="oracle.jdbc.driver.OracleDriver"
LoginDelaySeconds="1" MaxCapacity="20" Name="liwei"
PasswordEncrypted="{3DES}WBNJPYUOAvE=" Properties="user=liwei"
Targets="cgServer" URL="jdbc:oracle:thin:@localhost:1521:wincn"/>
<JDBCTxDataSource JNDIName="liwei" Name="liwei" PoolName="liwei" Targets="cgServer"/>
或者 工具->WebLogic Server->数据源查看器->新建数据源 步骤比较简单,主要输入对应参数:
DriverName="oracle.jdbc.driver.OracleDriver"
URL="jdbc:oracle:thin:@localhost:1521:wincn"
然后用户名密码即可。
以上内容可参看《Weblogic 中 JSP 连接数据库》一文
三、相关页面
Test\TestWeb\recordset\RecordsetController.jpf
Test\TestWeb\recordset\index.jsp
Test\TestWeb\recordset\test.jcx java 控件
四、数据库
CREATE TABLE TEST(
A VARCHAR2(10),
B VARCHAR2(10),
C VARCHAR2(10),
D VARCHAR2(10)
)
五、数据层(JAVA 控件)
本次示例使用 tblTest 自定义静态类实现返回数据集。(还可以使用 netui:gird RecordSet 实现,参见自带示例)其中 update 方法与 insert 方法十分类似,故未提供具体的实现代码。数据层并没有什么复杂之处,只是对逻辑层(页面流)提供足够的数据操作接口。tblTest 自定义的静态类是完成数据传递必不可少的环节。
Test\TestWeb\recordset\test.jcx 全代码
package recordset;
import com.bea.control.*;
import java.sql.SQLException;
/*
* @jc:connection data-source-jndi-name="liwei"
*/
public interface test extends DatabaseControl, com.bea.control.ControlExtension
{
/**
* @jc:sql statement::
* INSERT INTO TEST (A,B,C,D)
* VALUES ({_A},{_B},{_C},{_D})
* ::
*/
public int insert( String _A, String _B,String _C,String _D );
/**
* @jc:sql statement::
* UPDATE TEST SET B = {_B} ,C = {_C} ,D = {_D} WHERE A = {_A}
* ::
*/
public int update( String _A, String _B,String _C,String _D );
/**
* @jc:sql statement::
* DELETE TEST WHERE A = {_A}
* ::
*/
public int delete( String _A );
/**
* @jc:sql statement::
* SELECT * FROM TEST WHERE A = {_A}
* ::
*/
public tblTest select( String _A );
/**
* @jc:sql statement::
* SELECT * FROM TEST
* ::
*/
public tblTest[] selectAll();
public static class tblTest implements java.io.Serializable
{
public String A;
public String B;
public String C;
public String D;
}
}
六、逻辑层(页面流)
Test\TestWeb\recordset\RecordsetController.jpf 主要代码,省略了自动生成部分
public class RecordsetController extends PageFlowController
{
/*
*
* @common:control
*/
private test recTest; //定义数据接口
private test.tblTest[] recNew; //定义数据集
//因为示例连接的是英文数据库,会存在乱码问题,下面是转码的函数,这也充分
//说明了,逻辑层在处理数据的关键所在。
private String getGBString(String strIn)
{
try
{
byte[] tmpByte=strIn.getBytes("ISO8859-1");
return new String(tmpByte,"gb2312");
}
catch(Exception e)
{
return "";
}
}
//返回全记录,调用 recTest 的 selectAll,接口函数
public test.tblTest[] getAll()
{
recNew=recTest.selectAll();
int i;
for(i=0;i<recNew.length;i )
{
recNew[i].A=getGBString(recNew[i].A);
recNew[i].B=getGBString(recNew[i].B);
recNew[i].C=getGBString(recNew[i].C);
recNew[i].D=getGBString(recNew[i].D);
}
return recNew;
}
//添加数据,这时通过页面传递的参数值,调用接口 Add 数据
/**
* @jpf:action
* @jpf:forward name="success" path="index.jsp"
*/
public Forward add()
{
recTest.insert(this.getRequest().getParameter("a"), this.getRequest().getParameter("b"),this.getRequest().getParameter("c"),this.getRequest().getParameter("d"));
return new Forward( "success" );
(阅读次数:)
}
//删除数据
/**
* @jpf:action
* @jpf:forward name="success" path="index.jsp"
*/
public Forward delete()
{
recTest.delete(this.getRequest().getParameter("ToDelete"));
return new Forward( "success");
}
/**
* 此方法代表进入页面流的入口
* @jpf:action
* @jpf:forward name="success" path="index.jsp"
*/
protected Forward begin()
{
return new Forward("success");
}
}
七、显示层(页面)
Test\TestWeb\recordset\index.jsp 最外层显示,查看下面完全代码时,可以看到 netui 控件的极大
灵活性。
技术难点并不多,这里使用的是 netui-data:repeater,重复获取记录集数据。
<body>
<table border=1>
<tr>
<td width="100" class="header-text">A</td>
<td width="100" class="header-text">B</td>
<td width="100" class="header-text">C</td>
<td width="100" class="header-text">D</td>
</tr>
<netui-data:repeater dataSource="{pageFlow.all}">
<netui-data:repeaterHeader> </netui-data:repeaterHeader>
<netui-data:repeaterItem>
<tr>
<td width="100" class="row-text"><a href="#" onclick="window.alert('<netui:content value='{container.item.A}-{container.item.B}-{container.item.C}-{container.item.D}'/>')"><netui:label value="{container.item.A}"/></a></td>
<td width="100" class="row-text"><netui:label value="{container.item.B}"/></td>
<td width="100" class="row-text"><netui:label value="{container.item.C}"/></td>
<td width="100" class="row-text"><netui:label value="{container.item.D}"/></td>
<td>
<netui:anchor action="delete" onClick="return(window.confirm('Del?'))">
<netui:parameter name="ToDelete" value="{container.item.A}"/>
Delete
</netui:anchor>
</td>
</tr>
</netui-data:repeaterItem>
<netui-data:repeaterFooter> </netui-data:repeaterFooter>
</netui-data:repeater>
</table>
<hr>
<netui:form action="add" >
A:<input type="text" name="a"/><br>
B:<input type="text" name="b"/><br>
C:<input type="text" name="c"/><br>
D:<input type="text" name="d"/><br>
<input type="submit" value="add">
</netui:form>
</body>
八、小结
以前对 java 的了解为0,因项目迫切需要适当的研究下 WebLogic,作为入门级的选手就能感受到 WebLogic魅力的一二。清晰的层次非常便于组织项目的架构。页面流在 Web 开发过程可为核心,结合表示层的netui控件,将大量脚本可以化为简单轻松的面向对象的java语句。不管是前面提到的树形,还是本文的数据,随意而不零乱却是有机的整体。强!感觉需要选本书系统的学习一下 WebLogic 的思想。
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@evget.com
文章转载自:开源社区面对“数字中国”建设和中国制造2025战略实施的机遇期,中车信息公司紧跟时代的步伐,以“集约化、专业化、标准化、精益化、一体化、平台化”为工作目标,大力推进信息服务、工业软件等核心产品及业务的发展。在慧都3D解决方案的实施下,清软英泰建成了多模型来源的综合轻量化显示平台、实现文件不失真的百倍压缩比、针对模型中的大模型文件,在展示平台上进行流畅展示,提升工作效率,优化了使用体验。
本站的模型资源均免费下载,登录后即可下载。模型仅供学习交流,勿做商业用途。
本站的模型资源均免费下载,登录后即可下载。模型仅供学习交流,勿做商业用途。
本站的模型资源均免费下载,登录后即可下载。模型仅供学习交流,勿做商业用途。
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@evget.com
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢
慧都科技 版权所有 Copyright 2003-
2025 渝ICP备12000582号-13 渝公网安备
50010702500608号