当前位置: 代码迷 >> Web前端 >> webSphere遗忘管理控制台密码怎么处理
  详细解决方案

webSphere遗忘管理控制台密码怎么处理

热度:195   发布时间:2012-08-30 09:55:54.0
webSphere遗忘管理控制台密码怎么办

webSphere遗忘管理控制台密码怎么办? 常在河边走,哪有不湿鞋,WebSphere管理中最让人无语的是把密码忘记了。管理控制台也好,数据源的密码也好,配置的时候为了满足安全管理的要求设置了8位以上、大小写皆有、毫无意义的密码,现在两眼一抹黑,怎么都试不出来。怎么办?重装?生产环境好不好。其实不用着急,IBM还是给我们留了一条后路的。 管理控制台密码遗忘有两种补救措施:

方法一:命令行――从$WAS_HOME/profiles/xxx 概要文件名/bin目录下,运行 wsadmin -conntype NONE .? 当wsadmin的命令行窗口出现之后,运行 securityoff 上述操作在应用服务器启动或停止的状态都能发出。再次启用WAS时,就是停用管理安全性的状态了。

方法二:修改配置文件――修改$WAS_HOME\config\cells\xxx 下的security.xml,把第一个enable改成false就取消安全性了。 以上两种方法是禁用了全局安全性(global security),最后别忘了设置新的密码然后再次启用。 下文是讲述如何“破解”出WebSphere中其它密码的方法: WebSphere会在配置文件(一堆的XML)当中存放各种密码(包括数据源、认证别名等等),例如在$WAS_Profile_HOME\config\cells\security.xml文件里面有类似””,就是存放认证别名为oracleDBA的用户名和密码。 可以看到在这里密码被重新编码(encode)了,编码的方式是XOR(eXclusive OR异或),很明显这种并不是一种强加密的算法,仅仅是一种编码而已,所以准确来说WebSphere为了避免密码被明文记录,只是很简单地“编码”(encode)而不是“加密”(encrypt)。 万一阁下一个不小心忘记了存放在WebSphere里面的密码,但是又想恢复过来的话,WebSphere这种只是编码而不是加密的存放密码形式,就帮助了你了。当然如果你想干坏事的话,WebSphere也算是给自己留下了一个“后门”了 -_-b。嘿嘿嘿,不要以为IBM那帮老爷子就是这么懒,如果阁下真的是要对存放在WebSphere配置文件里面的密码要加密的话(对于广大客户肯定是有这个诉求的),其实IBM也提供了一种自定义加密算法的插件形式去解决这个问题的,详情可以参考这个链接,在这里就不对这个问题进行展开讨论了。 好了,现在就对各个版本的WAS的密码编码和反编码进行讨论:

WAS 5.X的编码: > cd $WAS_INSTALL_DIR/lib > ../java/bin/java -cp securityimpl.jar:iwsorb.jar com.ibm.ws.security.util.PasswordEncoder 123456 WAS 5.X的反编码: > cd $WAS_INSTALL_DIR/lib > ../java/bin/java -cp securityimpl.jar:iwsorb.jar com.ibm.ws.security.util.PasswordDecoder {xor}bm1sa2pp WAS 6.0的编码: > cd $WAS_INSTALL_DIR/lib > ../java/bin/java -cp securityimpl.jar:iwsorb.jar::ras.jar:wsexception.jar:bootstrap.jar:emf.jar:ffdc.jar com.ibm.ws.security.util.PasswordEncoder 123456 WAS 6.0的反编码: > cd $WAS_INSTALL_DIR/lib > ../java/bin/java -cp securityimpl.jar:iwsorb.jar::ras.jar:wsexception.jar:bootstrap.jar:emf.jar:ffdc.jar com.ibm.ws.security.util.PasswordDecoder {xor}bm1sa2pp WAS 6.1的编码: > cd $WAS_INSTALL_DIR/bin\ProfileManagement\plugins\com.ibm.websphere.v61_6.1.200 > java -cp ws_runtime.jar com.ibm.ws.security.util.PasswordEncoder 123456 WAS 6.1的反编码: > cd $WAS_INSTALL_DIR/bin\ProfileManagement\plugins\com.ibm.websphere.v61_6.1.200 > java -cp ws_runtime.jar com.ibm.ws.security.util.PasswordDecoder {xor}bm1sa2pp