快速业务通道

Java EE应用中对前端用户的数据库操作的审计 - 编程入门网

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-06-23
entAccountingInformation(String s) throws SQLException;

Java EE应用中对前端用户的数据库操作的审计(2)

时间:2010-11-03 IBM 库俊国

在获得连接后,通过上面的方法在连接上设置用户信息,在使用完毕后通过置空来清除连接上的用户信息。示例代码如下:

清单 2. 使用 DB2Connection 传递用户标识

DB2Connection conn ; DriverManager.registerDriver(new com.ibm.db2.jcc.DB2Driver()); String connString = "jdbc:db2://hostname:50000/dbname" ; conn = (DB2Connection)DriverManager.getConnection(connString, "connUser", "connPasswd"); // 上面的连接也可以从 DataSource 上获取 conn.setDB2ClientUser(“loginUser”) ; //do something on the connection  conn.setDB2ClientUser(null) ; conn.close() ;

在开放式平台上,通过下面的 DB2 命令来查看传递过来的用户信息:db2 get snapshot for applications on databasealias,输出结果示例:

TP Monitor client user ID = DB2UserID  TP Monitor client workstation name = yourApplication  TP Monitor client application name = clientWorkstation  TP Monitor client accounting string = yourAccountingInfo

在主机(z/OS)上,通过 DB2 命令: -DISPLAY THREAD(*) DETAIL 来查看,输出结果示例:

DSNV401I -DB8G DISPLAY THREAD REPORT FOLLOWS - DSNV402I -DB8G ACTIVE THREADS -NAME ST A REQ ID AUTHID PLAN ASID TOKEN SERVER RA * 4 V2.27.1302 DB2USER DISTSERV 0042 17 V437-WORKSTATION=clientWorkstation, USERID=DB2UserID, APPLICATION NAME=yourApplication

针对 Oracle 的标识传递

在 Oracle 11g Release 1 之前的版本中,Oracle JDBC driver 提供了接口 oracle.jdbc.driver.OracleConnection,通过 OracleConnection 上的两个方法 setClientIdentifier() 和 clearClientIdentifier() 可以完成标识传递。OracleConnection 只能传递一个属性 clientIdentifier,但通常这已经足够。

示例如下:

清单 3. 使用 OracleConnection 传递用户标识

OracleDataSource dataSource = new OracleDataSource(); dataSource.setURL("jdbc:oracle:thin:@hostname:1521:orcl"); dataSource.setUser("username"); dataSource.setPassword("passwd"); conn = (OracleConnection) dataSource.getConnection(); conn.setClientIdentifier(clientId) ; // do something on the connection    conn.clearClientIdentifier(clientId) ; conn.close() ; dataSource.close() ;

这个 client_id 传到 oracle 后,可以通过下面 sql 语句来查看每个 session 上的用户标识。

select client_identifier from v$session

那如何看到每个 client_id 执行的 sql 呢?需打开 oracle 的审计开关。例如可以打开对查询语句的审计:

audit select table by session;

然后执行:

select sql_text,CLIENT_ID from dba_audit_trail where username=''connectionUser'' order by EXTENDED_TIMESTAMP desc

Java EE应用中对前端用户的数据库操作的审计(3)

时间:2010-11-03 IBM 库俊国

可以列出每个用户执行的 sql 语句。

数据源在 WebSphere 应用服务器上的情形

如果是采用 WebSphere 应用服务器上配置的数据源,则无法将数据源上获得的连接转化为 OracleConnection 或 DB2Connection,须采用 WAS 提供的 connection wrapper 类 com.ibm.websphere.rsadapter.WSConne

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号