当前位置: 首页 > 工具软件 > Enhydra Shark > 使用案例 >

java shark_JAVA项目开发笔记(3)Shark部分: Shark API | 学步园

太叔京
2023-12-01

本文主要列出项目中使用的Shark API ,并列出已知的Shark1.1和shark2.0(TWS)的差别,不定时更新。

Shark1.1和shark2.0的设计上的总体差别

1.事务:

Shark2.0支持jotm 所以在API中把所有方法中带有 SharkTransaction 参数的重载版本都去掉了,转而使用jotm来对事物进行控制,这么做的后果就是你要像shark的demo中一样在调用shark API时都要手动启动一个事务,不然会报 Transaction is not begun(没有事务曾经被启动)的错误。这样很麻烦,因为Spring 提供了一个jotm的事务管理器所为我在项目中使用了Spring声明式事务,这样就不用在代码中夹杂着jotm事务处理的代码了,有关这方式的使用我会在框架融合部分的文章中加以说明。

2.管理接口:

Shark2.0去掉了 AdminInterface接口和取得该接口实例的方法Shark.getInstance().getAdminInterface(),(在shark1.1中该接口提供取得其它管理接口的方法,如AdminMisc、PackageAdministrator等),而把AdminInterface的方法直接拿到了Shark.getInstance()中去。

也就是说在shark1.0中要取得AdminMisc的代码为

Shark.getInstance().getAdminInterface().getAdminMisc()

而在Shark2.0中是这样的

Shark.getInstance().getAdminMisc()

3.Shark用户管理

在shark1.1中用个用户管理的接口:UserGroupAdministration,在文档中有明确的体现,用法如下

UserGroupAdministration ugAdmin = Shark.getInstance()

.getAdminInterface()

.getUserGroupAdministration();

ugAdmin.createGroup("developers","sweat-shop");

ugAdmin.createUser("developers",

"user",

"secret",

"Jane",

"Doe",

"some@email.address");

System.out.println("Group and user created!");

可以使用这个类来管理用户、用户组、权限,之后使用Sharkconnection的connect方法来登录,如果用户名或密码错误会抛出异常。但是在Shark2.0中这个UserGroupAdministration 被去掉了,在shark的文档中也没找到可以达到相同功能的接口,而且Sharkconnection的connect方法表现的也十分怪异,当使用connect方法时无论你提供的密码是对是错都会成功返回Sharkconnection而且不抛出任何异常,如果用户名也是错误的话,那么Shark 引擎会创建这个用户。后来想想设计者也对的,因为connect方法是“连接”而不是“验证”,那么shark2.0怎样来管理用户、用户组、权限和用户的登录呢。这个问题我找了很久后来终于在shark 的源码中找到了答案原来shark2.0提供了另一个接口来做这些事,那就是org.enhydra.shark.api.admin.UserGroupManagerAdmin(注意,这个包下的类在Shark API文档中并没有被提到,但是文档中有对它的父类org.enhydra.shark.api.internal.usergroup.UserGroupManager的说明,方法差不多大家可以参考一下 ),但是怎么得到这个接口的实例呢(为了这个问题我可是看了好长时间shark的源码,你们有福了有我告诉你们),我根据shark源码改动后的方法如下,可以返回这个接口的实例:

publicUserGroupManagerAdmin getUserGroupAdmin() {

UserGroupManagerAdmin userGroupAdmin =null;

try{

Object ama = Shark.getInstance().getPlugIn(

SharkConstants.PLUGIN_USER_GROUP);

if(amainstanceofUserGroupManagerAdmin) {

userGroupAdmin = (UserGroupManagerAdmin) ama;

}

}catch(Exception e) {

}

returnuserGroupAdmin;

}

有了这个接口用可以实现用户管理相关的功能了,如验证用户的登录:

if(getUserGroupAdmin().validateUser(

connectInfo.getUserIdentification(), connectInfo.getPassword())) {

System.out.println("********************Vaildateuser is true");

}else{

System.out.println("********************Vaildateuser is False");

}

注:因为加入了单独的验证功能,所以Shark1.1中的connect方法也就不会再抛出ConnectFailed, NotConnected 异常了。

4.管理接口中的用户认证

在shark1.1中有的管理接口在使用之前需要对登录的用户进行认证如ExecutionAdministration在使用之前要有如下代码(shark2.0的SharkConnection的connect方法的参数也进行了改动):

privateExecutionAdministration ea =null;

ea = Shark.getInstance().getAdminInterface()

.getExecutionAdministration();

ea.connect(userName, password, SharkAdapter.engineName,null);

这样在使用时不但要对SharkConnection进行登录而且还需要对使用到的管理接口进行登录,  而在Shark2.0中则不需要这么做了,shark2.0去掉了ExecutionAdministration 等管理接口的connect方法,可以在获得管理接口后直接调用管理接口的方法,而在方法中加入了一个用户会话信息的参数:WMSessionHandle.而这个参数可以 通过SharkConnection 的getSessionHandle()获得。代码如下(项目中的代码片断,取得所有加载的包,getSharkLogon().getSConn()返回的是已认证的SharkConnection ):

PackageAdministration pa = Shark.getInstance()

.getPackageAdministration();

packageInfos.clear();

String pkIDs[] = pa.getOpenedPackageIds(getSharkLogon().getSConn()

.getSessionHandle());

5.异常处理:

不知是什么原因Shark2.0的API方法不再抛出某些Shark自定义的异常,目前本人只发现好像BaseException不会再被抛出了,而是直接抛出Exception类的异常,而某些方法还是会抛出Shark自定义的异常,如complete会抛出CannotComplete异常,我们在使用时可能捕获不同的异常进行不同的处理是很方便的如(代码中使用了JSF,shark版本为1.1):

publicString logonActive() {

FacesContext facesContext = FacesContext.getCurrentInstance();

try{

LogonInfo logonInfo =newLogonInfo();

logonInfo.logon(userName, password);

HttpServletRequest request = (HttpServletRequest) facesContext

.getExternalContext().getRequest();

HttpSession session = request.getSession();

session.setAttribute("logonInfo", logonInfo);

return"success";

}catch(BaseException e) {

FacesMessage msg = MessageFactory.getMessage(facesContext,

"error_cannot_login","");

msg.setSeverity(FacesMessage.SEVERITY_ERROR);

facesContext.addMessage(null, msg);

return"error";

}catch(ConnectFailed e) {

FacesMessage msg = MessageFactory.getMessage(facesContext,

"error_userorpassword","");

msg.setSeverity(FacesMessage.SEVERITY_WARN);

facesContext.addMessage(null, msg);

return"failure";

}catch(NotConnected e) {

FacesMessage msg = MessageFactory.getMessage(facesContext,

"error_cannot_login","");

msg.setSeverity(FacesMessage.SEVERITY_ERROR);

facesContext.addMessage(null, msg);

return"error";

}

}

但是shark1.1中的异常类并没有被删除,通过import还可以正常导入使用只是shark API不会再抛出这种异常了。

具体的API用法及Shark1.1同2.0的差别:

本来想在这部分写一些shark的API方法的,可是发现这么做不如只接去看shark API的javadoc(安装shark自带,很全)所以只列出某些用法上有说道的方法

待继...........

 类似资料: