|
眾所周知,Oracle的數據庫、中間件都可以在網上自由下載,沒有任何license注冊碼的限制。
現在,Oracle以85億美元收購了BEA,帶來的最直接的好處是,以前嚴格保密的License文件現在都可以直接下載了。請看下面頁面:
http://commerce.bea.com/products/all_products.jsp#WL
WebLogic Family License Keys
http://download2.bea.com/pub/license/All%20Products/BEA_WebLogic.zip
AquaLogic Family License Keys
http://download2.bea.com/pub/license/All%20Products/BEA_AquaLogic.zip
摘錄部分內容如下:
========================================
= Read Me -- BEA WebLogic License Keys =
========================================

Some BEA products require multiple license keys for full functionality, or use a license key which is not intuitively identified as being for that product.

Please refer to the legend below to determine which license keys are required for the BEA products you own.



BEA WebLogic Server Products (Product, Version, License ID/file)
================================================================

BEA WebLogic Server Advantage Edition 10.0 - 10.0mp1 LIC-WLSA10.txt
9.2 - 9.2mp3 LIC-WLSA92.txt
9.0 LIC-WLSA90.txt

BEA WebLogic Server Premium Edition 10.0 - 10.0mp1 LIC-WLSP10.txt
9.2 - 9.2mp3 LIC-WLSP92.txt
9.0 LIC-WLSP90.txt

BEA WebLogic Server SDK 10.x LIC-WLSP10-DEV
9.2 LIC-WLSP92-DEV
9.1 LIC-WLSP91-DEV
9.0 LIC-WLSP90-DEV

BEA WebLogic Server Premium for Linux s/390 and z/Series
7.0sp1 LIC-WLS70-CLS-56

BEA WebLogic Server Mid-Market Edition 10.0 - 10.0mp1 LIC-WLS10-MME.txt
9.2 - 9.2mp3 LIC-WLS92-MME.txt


BEA WebLogic Platform Products (Product, Version, License ID/file)
==================================================================
BEA WebLogic Platform 10.2 ISV LIC-PLAT102-ISVED
10.2 LIC-AUTONOMY

LIC-PORT102
LIC-WLI102
9.2mp3 ISV LIC-PLAT92-ISVED
9.2 - 9.2mp3 LIC-PFRM92.txt
8.1 - 8.1sp6 LIC-PFRM81-128.txt
7.0 - 7.0sp7 LIC-PFRM70-128.txt
<license
component="WebLogic"
cpus="unvalued"
expiration="never"
ip="any"
licensee="Customer"
serial="454493271161-2642447506228"
type="RTK"
units="unlimited"
signature="MCwCFHRYQyBkRqhyayiKQBDxfTq/bWfYAhQj+RMMeDMVxjiYhBaXuHobbHe/JA=="
/>
呵呵,都什么年代了,您還在Google、baidu中搜索“weblogic 破解”這樣的關鍵字嗎,用不著了。但是這并不意味著您可以免費使用這些產品,熟悉Oracle的人都知道,如果您想在企業級應用中部署這些產品,您還是得付money!
稱為是最好的JAVA IDE開發平臺!包括:J2EE支持、Ant、JUnit、集成CVS。包含一個智能編輯器,代碼輔助和增強的自動代碼工具。可提高JAVA開發人員的效率。
JetBrains已經發布了IntelliJ IDEA 7.0,IntelliJ IDEA 7里程碑1包括許多新的特性和提高,尤其是在對Java EE的支持上,包括Spring和Hibernate,代碼分析,擴展版本控制支持,Rational ClearCase集成,增強了調試,代碼查詢,可用性和性能。
正使用IntelliJ IDEA 6.0的用戶可以免費使用IntelliJ IDEA 7.0到2007年12月31號,評估用戶可以從官方網站下載并有30天的免費試用期。
IntelliJ IDEA 7.0的新特性包括:
1.性能提高
IDE的啟動速度得到改善
編輯JSP的速度加快
更快的XML的格式化
2.對Hibernate的支持
代碼助手
3.對Spring的支持
代碼助手
觀察依賴的可視化圖表
專門的文件設置編輯器
4.與Eclipse的協作能力
導入(從現有的Eclipse工程中創建IntelliJ IDEA .iml和.ipr文件 )
導出(從現有的IntelliJ IDEA .iml文件中創建Eclipse工程文件)
同步
5.版本控制
支持Rational ClearCase
6.JavaScript
支持JSON文件類型
JSDoc和DoJo樣式類型注釋提供了更準確的完成和參數類型信息
JSDoc和DoJo樣式注釋的豐富文檔
JavaScript命名空間完成/驗證
一份注冊碼如下,Enjoy!
=============================================================
user name:在路上...
License:12008-M3132-RY84C-0GSMK-V7TNK-33XV0
customer id:12008
product id:IDEA
license type:COMMERCIAL
major version:7
minor version:0
generationDate:Mon Oct 22 16:31:47 CST 2007
expirationDate:Sun Jan 20 16:31:47 CST 2008
一個典型應用中,使用delphi作為客戶端,J2EE服務端,兩者之間用XML作為數據交換,為了提高效率,對XML數據進行壓縮,為此需要找到一種壓縮/解壓算法能夠兩個平臺之間交互處理,使用ZLIB算法就是一個不錯的解決方案。
1、JAVA實現
在JDK中,在java.util.zip包中已經內置了ZLIB的實現,示例代碼如下:
1 //解壓
2 public String decompressData(String encdata) {
3 try {
4 ByteArrayOutputStream bos = new ByteArrayOutputStream();
5 InflaterOutputStream zos = new InflaterOutputStream(bos);
6 zos.write(convertFromBase64(encdata));
7 zos.close();
8 return new String(bos.toByteArray());
9 } catch (Exception ex) {
10 ex.printStackTrace();
11 return "UNZIP_ERR";
12 }
13 }
14
15 //壓縮
16 public String compressData(String data) {
17 try {
18 ByteArrayOutputStream bos = new ByteArrayOutputStream();
19 DeflaterOutputStream zos = new DeflaterOutputStream(bos);
20 zos.write(data.getBytes());
21 zos.close();
22 return new String(convertToBase64(bos.toByteArray()));
23 } catch (Exception ex) {
24 ex.printStackTrace();
25 return "ZIP_ERR";
26 }
27 }
2、DELPHI中的實現
在DELPHI中,有第3方的控件可以利用來實現壓縮/解壓,這里我們選擇VCLZIP V3.04,可以從這里下載http://www.vclzip.net
為了提高通用性,我們可以編寫一個標準的DLL,就可以在Win32平臺隨意調用了,關鍵代碼如下:
function Cmip_CompressStr(txt: PChar): pchar; stdcall;
var
zip: TVclZip;
compr: string;
data: PChar;
begin
zip := TVclZip.Create(nil);
compr := zip.ZLibCompressString(txt);
data := pchar(Base64EncodeStr(compr));
Result := StrNew(data);
zip.Free
end;

function Cmip_DeCompressStr(txt: PChar): pchar; stdcall;
var
zip: TVCLUnZip;
compr: string;
data: PChar;
begin
zip := TVCLUnZip.Create(nil);
compr := zip.ZLibDecompressString(Base64DecodeStr(txt));
data := StrNew(pchar(compr));
Result := data;
zip.Free
end;
在我們當前的項目中,采用的方案是Powerbuilder +DLL與J2EE平臺進行xml數據交換的方式。
在這里可以下載Resin Plugin for IntelliJ IDEA ,但是對于3.1X好像還不支持。http://plugins.intellij.net/plugin/?id=215
作者更新太慢,不好意思自己動手反編譯修改了幾個地方,現在可以支持Resin Pro 3.1.2,如果需要地可以從這里
* 下載:Resin_2640_31.zip
* 安裝:
修改文件名為Resin_2640_31.jar,復制到C:\Documents and Settings\[username]\.IntelliJIdea60\config\plugins下面
* 修改記錄
1、將3.1.2的resin.conf文件命名為resin31.conf加到org\intellij\j2ee\web\resin\resin下面
2、將ResinVersion.java修改為如下方法判斷是否3.1版本
 public static final ResinVersion VERSION_3_X = new ResinVersion("Resin 3.x") {

public boolean isOfVersion(File file)
 {
return (new File(new File(file, "lib"), "jsdk-15.jar")).exists();
}

public String getStartupClass()
 {
return "com.caucho.server.resin.Resin";
}

}
3、修改Resin3XConfigurationStrategy.java文件中部分判斷http port、host的代碼
原來的XML節點為root->server->host->http->port and root->server->host->web-app
3.1下面的XML節點為root->cluster->server-default->http->port and root->cluster->host->web-app
改過的代碼為
Element httpElement = document.getRootElement().getChild("cluster", ns).getChild("server-default", ns).getChild("http", ns);
Element host = getHost(document.getRootElement().getChild("cluster", ns), ns, webApp);
List hosts = document.getRootElement().getChild("cluster", ns).getChildren("host", ns);
public InputStream getDefaultResinConfContent()
{
return getClass().getResourceAsStream("/org/intellij/j2ee/web/resin/resin/resin31.conf");
}
原來的作者沒有開源,所以不好做進一步的修改完善,對于3.0的版本應該就不支持了。
PowerBuilder在顯示圖片方面的確是一個弱項,以前一直沒有找到好的方法,如果自己用delphi寫個ActiveX控件,在關閉的時候總會出現錯誤,實在是很郁悶,后來發現Kodak Image Edit Control就沒有這個問題,而且可以支持BMP,DCX,GIF,JPG-JFIF,PCX,TIFF,WIFF,XIF等常見的圖片格式,該控件在win98,win2000等環境中都已經安裝好了,對于XP環境也可以簡單的從Win2000移植過來。 1、鼠標放大、縮小效果 在OLE控件的other事件中加入下面的代碼
1 Choose Case Message.Number 2 Case 522 3 if IntHigh(message.wordparm) = 120 then //鼠標滾輪向上 4 if int(ole_1.object.zoom)<=20 then return 5 ole_1.object.zoom= ole_1.object.zoom -10 6 else 7 ole_1.object.zoom= ole_1.object.zoom+10 8 end if 9 ole_1.object.display() 10 End Choose
2、鼠標拖動效果 如果不想選擇框老是出現的話,需要加入 ole_1.object.SelectionRectangle = False
1 //1.定義Instance變量 2 int mousex,mousey 3 int moveon
以下代碼屬于OLE控件的事件
1 //Event MouseDown事件 2 moveon=1 3 mousex=ocx_x 4 mousey=ocx_y
1 //MouseMove事件 2 if moveon=0 then return 3 ole_1.object.ScrollPositionX =ole_1.object.ScrollPositionX+(MouseX -ocx_x) 4 ole_1.object.ScrollPositionY =ole_1.object.ScrollPositionY+(MouseY -ocx_y) 5 ole_1.object.refresh() 6 mousex=ocx_x 7 mousey=ocx_y
1 //mouseUp事件 2 moveon=0
通常在weblogic的config.xml文件中,對于關鍵字符串、密碼會自動加密,例如LDAP密碼、數據庫JDBC連接池連接密碼等。通常加密之后前面會加上{3DES}的標識。 3DES就是DES算法的增強,相關資料如下: 1、DES(Data Encryption Standard)是一種經典的對稱算法。其數據分組長度為64位,使用的密鑰為64位,有效密鑰長度為56位(有8位用于奇偶校驗)。它由IBM公司在70年代開發,經過政府的加密標準篩選后,于1976年11月被美國政府采用,隨后被美國國家標準局和美國國家標準協會(American National Standard Institute, ANSI) 承認。
該技術算法公開,在各行業有著廣泛的應用。DES算法從公布到現在已有20多年的歷史,由于計算機能力的飛速發展,DES的56位密鑰長度顯得有些太短了,已經有可能通過窮舉的
方法來對其進行攻擊。但是除此以外,直到現在還沒有發現窮舉以外的能有效破譯DES的方法。 2、DES算法現在已經不能提供足夠的安全性,因為其有效密鑰只有56位。因此,后來又提出了三重DES(或稱3DES),該方法的強度大約和112比特的密鑰強度相當。 這種方法用兩個密鑰對明文進行三次運算。設兩個密鑰是K1和K2,其算法的步驟如圖3所示: 1. 用密鑰K1進行DES加密。 2. 用K2對步驟1的結果進行DES解密。 3. 用步驟2的結果使用密鑰K1進行DES加密。
首先需要找到加密的密鑰,根據BEA文檔可以發現是文件SerializedSystemIni.dat,查找一下安裝目錄就可以找到整個問見,通常系統管理員應該將該文件設置為不能直接訪問,以提高安全性。 加密、解密的大致演示算法代碼如下,在WebLogic 9.2下面調試通過,運行編譯前應該先運行setExamplesEnv.cmd(參考)的環境變量,以保證相關類庫已經被引用了。對于低版本的WebLogic,例如WebLogic 7.0/8.1可能不能直接在命令行執行,因為SerializedSystemIni必須在控制臺Console環境下面才能調用,有興趣的朋友可以自行測試看看。
?1 import?weblogic.security.internal.*; ?2 import?weblogic.security.internal.encryption.EncryptionService; ?3 import?weblogic.utils.encoders.BASE64Decoder; ?4 import?weblogic.utils.encoders.BASE64Encoder; ?5 public?class?CrackData? ?6  { ?7 ????public?static?void?main(String[]?args)? ?8 ???? { ?9 ????????byte[]?salt,keys; 10 ????????salt=SerializedSystemIni.getSalt(); 11 ????????keys=SerializedSystemIni.getEncryptedSecretKey(); 12 ????????String?data=""; 13 ????????for(int?i=0;i<salt.length;i++) { 14 ????????????data+=salt[i]+","; 15 ????????} 16 ????????System.out.println("salt:"+data); 17 ????????data=""; 18 ????????for(int?i=0;i<keys.length;i++) { 19 ????????????data+=keys[i]+","; 20 ????????} 21 ????????System.out.println("Key:"+data); 22 ????????//EncryptionService?svr=SerializedSystemIni.getExistingEncryptionService(); 23 ????????EncryptionService?svr=SerializedSystemIni.getEncryptionService(); 24 ????????System.out.println(svr); 25 ????????System.out.println(svr.getAlgorithm()); 26 ????????if(args.length>1) { 27 ????????????if(args[0].equals("encrypt")) { 28 ????????????????byte[]?edata=svr.encryptString(args[1]); 29 ????????????????String?s?=?(new?BASE64Encoder()).encodeBuffer(edata); 30 ????????????????System.out.println("Encode:"+s); 31 ????????????} 32 ????????????if(args[0].equals("decrypt")) { 33 ????????????????try { 34 ????????????????byte[]?edata?=?(new?BASE64Decoder()).decodeBuffer(args[1]); 35 ????????????????String?txt=svr.decryptString(edata); 36 ????????????????System.out.println("Decode:"+txt); 37 ????????????????}catch(Exception?ex) { 38 ????????????????????ex.printStackTrace(); 39 ????????????????} 40 ????????????} 41 ????????} 42 ???????? 43 ????} 44 } 45 測試運行結果如下:
root@srdsh?#?/rdsh/bea92/jdk150_04/bin/java?CrackData?decrypt?nMttUc5jNe9RNJXslXjbJQ==
-86,123,19,107,
-42,-28,-75,-100,31,0,25,-93,75,115,40,-3,-15,42,-53,41,-25,-13,-6,8,36,85,-81,2
8,66,-110,31,38,-29,-79,-44,-48,
weblogic.security.internal.encryption.JSafeEncryptionServiceImpl@199f91c
3DES
Decode:weblogic
root@srdsh?#?/rdsh/bea92/jdk150_04/bin/java?CrackData?decrypt?erzD515N5z2zSnOk7uG1cYQthCbYA5OU6Bw+Zt5BsjPruTQaOZASh+ZZW4kuBGvfbZ2BXWSACbgOZ2MY4bHtpOPps/6WfZJg
-86,123,19,107,
-42,-28,-75,-100,31,0,25,-93,75,115,40,-3,-15,42,-53,41,-25,-13,-6,8,36,85,-81,2
8,66,-110,31,38,-29,-79,-44,-48,
weblogic.security.internal.encryption.JSafeEncryptionServiceImpl@199f91c
3DES
Decode:0xa778f572127d2282247ec653147c35d4e4040aca016c6d1e06ab325af5798fca
root@srdsh?#
在安裝了Oracle 9i之后XDB的http默認占用了8080,ftp會占用2100端口,其實XDB就是XML Database提供的一種服務,在oracle中有一個package可以用來維護管理該服務的配置信息。這個包就是dbms_xdb. 解決方法有下面幾種: 1、sqlplus "/ as sysdba"連入數據庫 SQL> -- Change the HTTP/WEBDAV port from 8080 to 8081 SQL> call dbms_xdb.cfg_update(updateXML( 2 dbms_xdb.cfg_get() 3 , '/xdbconfig/sysconfig/protocolconfig/httpconfig/http-port/text()' 4 , 8081)) 5 /
Call completed.
SQL> -- Change the FTP port from 2100 to 2111 SQL> call dbms_xdb.cfg_update(updateXML( 2 dbms_xdb.cfg_get() 3 , '/xdbconfig/sysconfig/protocolconfig/ftpconfig/ftp-port/text()' 4 , 2111)) 5 /
Call completed.
SQL> COMMIT;
Commit complete.
SQL> EXEC dbms_xdb.cfg_refresh;
PL/SQL procedure successfully completed.
SQL> -- Verify the change SQL> set long 100000 SQL> set pagesize 9000 SQL> SELECT dbms_xdb.cfg_get FROM dual; 2、移除XDB服務,將實例信息去掉 dispatchers='(PROTOCOL=TCP) (SERVICE=<ORACLE_SID>XDB)'
3、使用Oracle Enterprise Manager 中的的XML Database 配置信息中修改掉端口就可以了
|