<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    2006年10月31日

    原文來自: HttpClient POST 的 UTF-8 編碼問題

    Apache HttpClient ( http://jakarta.apache.org/commons/httpclient/ ) 是一個純 Java 的HTTP 協(xié)議的客戶端編程工具包, 對 HTTP 協(xié)議的支持相當(dāng)全面, 更多細節(jié)也可以參考IBM 網(wǎng)站上的這篇文章 HttpClient入門 ( http://www-128.ibm.com/developerworks/cn/opensource/os-httpclient/ ).

    問題分析

    不過在實際使用中, 還是發(fā)現(xiàn)按照最基本的方式調(diào)用 HttpClient 時, 并不支持 UTF-8 編碼, 在網(wǎng)絡(luò)上找過一些文章, 也不得要領(lǐng), 于是查看了 commons-httpclient-3.0.1 的一些代碼, 首先在 PostMethod 中找到了 generateRequestEntity() 方法:
    ????/**
    ?????*?Generates?a?request?entity?from?the?post?parameters,?if?present.??Calls
    ?????*?{@link?EntityEnclosingMethod#generateRequestBody()}?if?parameters?have?not?been?set.
    ?????*?
    ?????*?@since?3.0
    ?????*/
    ????protected?RequestEntity?generateRequestEntity()?{
    ????????if?(!this.params.isEmpty())?{
    ????????????//?Use?a?ByteArrayRequestEntity?instead?of?a?StringRequestEntity.
    ????????????//?This?is?to?avoid?potential?encoding?issues.??Form?url?encoded?strings
    ????????????//?are?ASCII?by?definition?but?the?content?type?may?not?be.??Treating?the?content
    ????????????//?as?bytes?allows?us?to?keep?the?current?charset?without?worrying?about?how
    ????????????//?this?charset?will?effect?the?encoding?of?the?form?url?encoded?string.
    ????????????String?content?=?EncodingUtil.formUrlEncode(getParameters(),?getRequestCharSet());
    ????????????ByteArrayRequestEntity?entity?=?new?ByteArrayRequestEntity(
    ????????????????EncodingUtil.getAsciiBytes(content),
    ????????????????FORM_URL_ENCODED_CONTENT_TYPE
    ????????????);
    ????????????return?entity;
    ????????}?else?{
    ????????????return?super.generateRequestEntity();
    ????????}
    ????}

    原來使用 NameValuePair 加入的 HTTP 請求的參數(shù)最終都會轉(zhuǎn)化為 RequestEntity 提交到 HTTP 服務(wù)器, 接著在 PostMethod 的父類 EntityEnclosingMethod 中找到了如下的代碼:
    ????/**
    ?????*?Returns?the?request's?charset.??The?charset?is?parsed?from?the?request?entity's?
    ?????*?content?type,?unless?the?content?type?header?has?been?set?manually.?
    ?????*?
    ?????*?@see?RequestEntity#getContentType()
    ?????*?
    ?????*?@since?3.0
    ?????*/
    ????public?String?getRequestCharSet()?{
    ????????if?(getRequestHeader("Content-Type")?==?null)?{
    ????????????//?check?the?content?type?from?request?entity
    ????????????//?We?can't?call?getRequestEntity()?since?it?will?probably?call
    ????????????//?this?method.
    ????????????if?(this.requestEntity?!=?null)?{
    ????????????????return?getContentCharSet(
    ????????????????????new?Header("Content-Type",?requestEntity.getContentType()));
    ????????????}?else?{
    ????????????????return?super.getRequestCharSet();
    ????????????}
    ????????}?else?{
    ????????????return?super.getRequestCharSet();
    ????????}
    ????}


    解決方案

    從上面兩段代碼可以看出是 HttpClient 是如何依據(jù) "Content-Type" 獲得請求的編碼(字符集), 而這個編碼又是如何應(yīng)用到提交內(nèi)容的編碼過程中去的. 按照這個原來, 其實我們只需要重載 getRequestCharSet() 方法, 返回我們需要的編碼(字符集)名稱, 就可以解決 UTF-8 或者其它非默認(rèn)編碼提交 POST 請求時的亂碼問題了.

    測試

    首先在 Tomcat 的 ROOT WebApp 下部署一個頁面 test.jsp, 作為測試頁面, 主要代碼片段如下:
    <%@?page?contentType="text/html;charset=UTF-8"%>
    <%@?page?session="false"?%>
    <%
    request.setCharacterEncoding("UTF-8");
    String?val?=?request.getParameter("TEXT");
    System.out.println(">>>>?The?result?is?"?+?val);
    %>


    接著寫一個測試類, 主要代碼如下:
    ????public?static?void?main(String[]?args)?throws?Exception,?IOException?{
    ????????String?url?=?"http://localhost:8080/test.jsp";
    ????????PostMethod?postMethod?=?new?UTF8PostMethod(url);
    ????????//填入各個表單域的值
    ????????NameValuePair[]?data?=?{
    ????????????????new?NameValuePair("TEXT",?"中文"),
    ????????};
    ????????//將表單的值放入postMethod中
    ????????postMethod.setRequestBody(data);
    ????????//執(zhí)行postMethod
    ????????HttpClient?httpClient?=?new?HttpClient();
    ????????httpClient.executeMethod(postMethod);
    ????}
    ????
    ????//Inner?class?for?UTF-8?support
    ????public?static?class?UTF8PostMethod?extends?PostMethod{
    ????????public?UTF8PostMethod(String?url){
    ????????????super(url);
    ????????}
    ????????@Override
    ????????public?String?getRequestCharSet()?{
    ????????????//return?super.getRequestCharSet();
    ????????????return?"UTF-8";
    ????????}
    ????}


    運行這個測試程序, 在 Tomcat 的后臺輸出中可以正確打印出 ">>>> The result is 中文" .

    代碼下載

    本文所提到的所有代碼, 以及測試程序(可直接導(dǎo)入 eclipse)提供打包下載: att:HttpClient POST 的 UTF-8 編碼問題.httpClientUTF8.tar.bz2

    END


    posted @ 2006-10-31 23:00 thinkbase.net 閱讀(7706) | 評論 (8)編輯 收藏

    2006年10月10日

    原文來自:? 使用 Apache 反向代理實現(xiàn)負載均衡及熱備


    初步設(shè)想

    • 早些時候在 JavaEye 上看到過一些使用 lighttpd 或者 apache 作前端, 通過負載均衡, 實現(xiàn)高性能的 Web 系統(tǒng)的討論, 于是留意了一下這方面的技術(shù);
    • 考慮到對不同的 App Server 而言, 實現(xiàn) Session 復(fù)制的配置各不相同(通常是需要配置集群), 因此從通用的角度, 覺得使用 session sticky 方式實現(xiàn)的負載均衡比較方便;
    • 由于沒有看到有資料說 lighttpd 能夠?qū)崿F(xiàn) session sticky, 所以決定先使用 Apache 試試.
    參考資料:

    環(huán)境準(zhǔn)備

    • 下載安裝 Apache, 測試時使用的是 XAMPP ( http://www.apachefriends.org/en/xampp.html ) 的 Linux 版本 (xampp-linux-1.5.4.tar.gz), 按照安裝說明, 解壓到 /opt/lampp 目錄下就可以使用了;
      • 啟動 Apache: sudo /opt/lampp/lampp startapache
      • 重新加載 Apache: sudo /opt/lampp/lampp reloadapache (在 httpd.conf 文件被修改后可以不重啟, 而是直接 reload 就可以了)
      • 停止服務(wù): sudo /opt/lampp/lampp stop
    • 準(zhǔn)備兩個運行同樣程序的 Web 服務(wù)器, 這里使用的是 Tomcat 5.5, 并使用一個 jsp 文件作為測試文件(相關(guān)源代碼參見文章最后的附件);
      • 這兩個 Tomcat 服務(wù)器需要將 HTTP 服務(wù)配置在不同的端口上, 同時由于測試時運行在同一臺機器上, 其它端口也需要避免沖突;
    • 下載安裝 JMeter ( jakarta-jmeter-2.2), 用于壓力測試, 驗證負載均衡的效果;

    測試 jsp 文件的說明

    測試用的 jsp 文件 (test.jsp) 具有如下功能:
    • 顯示當(dāng)前運行的服務(wù)器的 IP 地址及端口號, 這樣從返回的頁面就能夠知道是運行在哪一個 Web 服務(wù)器上的了;
    • 統(tǒng)計每個客戶端(不同的 session)向同一臺服務(wù)器發(fā)出請求的次數(shù), 通過這個計數(shù)可以驗證是否實現(xiàn)了 session sticky;
    • 通過 clear 請求參數(shù)(即 .../test.jsp?clear=1)清除請求次數(shù)的計數(shù)結(jié)果, 以便進行下一次測試;
    • 模擬 JSESSIONID +jvmRoute 的機制, 自行實現(xiàn)了一個 STICK_PORT_TOKEN 的 Cookie, 直接使用不同服務(wù)器的 HTTP 端口號作為 route;
      • 說明1: 考慮到方案的通用性, 這里沒有直接使用 JSESSIONID +jvmRoute 的機制;
      • 說明2: 雖然作為一個例子, 相關(guān)代碼是寫死在 jsp 文件中的, 但是這個機制可以很方便的用一個 Filter 統(tǒng)一實現(xiàn);

    Apache 的配置

    編輯 Apache 的 httpd.conf 文件(如果使用 xampp-linux 的話, 應(yīng)該在 /opt/lampp/etc 目錄下), 在文件的最后加上如下內(nèi)容:
    ###############################################################################
    # Reverse Proxy and Load Balance ##############################################
    ###############################################################################
    # 1)簡單的反向代理
    ProxyRequests Off
    <Proxy *>
    Order deny,allow
    Allow from all
    </Proxy>
    ProxyPass /1 http://localhost:8080/test
    #ProxyPassReverse /1 http://localhost:8080/test
    ProxyPass /2 http://localhost:18080/test
    #ProxyPassReverse /2 http://localhost:18080/test
    # 2)非 stickysession 的 balance
    ProxyPass /3 balancer://non-sticky-cluster nofailover=On
    <Proxy balancer://non-sticky-cluster>
    BalancerMember http://localhost:8080/test
    BalancerMember http://localhost:18080/test smax=10
    </Proxy>
    # 3)stickysession 的 balance
    ProxyPass /4 balancer://sticky-cluster stickysession=STICK_PORT_TOKEN nofailover=On
    <Proxy balancer://sticky-cluster>
    BalancerMember http://localhost:8080/test route=8080
    BalancerMember http://localhost:18080/test route=18080 loadfactor=2
    </Proxy>
    這個配置分為3個部分, 包括了 1)簡單的反向代理, 2)非 session sticky 的 load balance, 以及 3)session sticky 的 load balance 三種方式的配置(這里假設(shè)兩個 Tomcat 服務(wù)器的 HTTP 服務(wù)被配置在 8080 和 18080 端口), 其中第 2) 和 3) 的配置中 "nofailover=On" 適合于沒有 session 復(fù)制的情況下, 這種情況下, 如果其中一臺 HTTP 服務(wù)器出錯, 那么原來分配在這個出錯機器上的瀏覽器客戶端不會被自動轉(zhuǎn)移到另外的服務(wù)器上, 必須重新啟動瀏覽器才能將請求分配到另外一臺服務(wù)器上去.

    使用 JMeter 測試結(jié)果

    使用 JMeter 對 "3)session sticky 的 load balance" 的效果進行測試, 通過壓力測試的方式, 檢查兩臺 Tomcat 服務(wù)器被分配到的請求數(shù)量, 相關(guān)的測試腳本參見文章最后的附件.

    注意如果重復(fù)測試, 在下一次測試開始之前請對每個 Tomcat 服務(wù)器執(zhí)行 .../test.jsp?clear=1 的請求, 清除上一次的計數(shù)結(jié)果.

    從下圖的測試結(jié)果可見: 50個線程中有21個被分配在 8080 端口的服務(wù)器上, 29個則被分配到 18080 端口的服務(wù)器; 另外, 所有的 session 請求次數(shù)都是 20 次, 說明 session sticky 達到了預(yù)期的效果.

    附件


    后記

    如何禁用 XAMPP 自帶的內(nèi)容, 使之成為一個單純的轉(zhuǎn)發(fā)服務(wù)器:
    • 1)注釋掉 /opt/lampp/etc/httpd.conf 中 "Include etc/extra/httpd-xampp.conf" 這一行;
    • 2)刪除或者移走 /opt/lampp/htdocs 目錄下的內(nèi)容(但是此目錄需要保留).
    posted @ 2006-10-10 13:12 thinkbase.net 閱讀(7049) | 評論 (7)編輯 收藏

    2006年7月29日

    (原文來自: 2006-07-28 介紹一個 RSA 加密小工具 bmrsa)

    因為要做一個不對稱加密/解密相關(guān)的應(yīng)用(其實是想用在軟件的注冊控制方面), 本來的想法是去找找有沒有 RSA 加密/解密的源代碼的例子, 結(jié)果在 sourceforge 找到來 bmrsa(RSA Cryptographic Text Processor), 可以從 http://sourceforge.net/projects/bmrsa 訪問.

    項目 README 里的描述:

     This program is an exercise in prime number generation,
    RSA key generation, RSA encryption and conversion between
    decimal, hexadecimal, base64 and text. Take note that RSA
    is generally not used to encrypt entire messages because it
    is too slow. It is normally used to encrypt keys used in
    other encryption algorithms or other relatively small
    values. For more detailed documentation, execute bmrsa
    from a command line without passing any arguments. You will
    probably want to pipe the output through more like this

    試用了一下, 總結(jié)該軟件有如下特點:
    • 開源, GPL 協(xié)議;
    • 跨平臺, 而且完全使用 C++ 編寫, 下載包里包含了 Windows 和 Linux 下的可執(zhí)行文件;
    • 命令行程序, 運行時使用 stdin 和 stdout, 應(yīng)該說被其它程序調(diào)用還算方便;
    • 只能處理文本, 不支持中文, 因此對于中文文本或者二進制文件可能需要先 base64 一下.

    我用的是 2003-03-16 16:00 的 bmrsa10.zip 這個包, 可以從項目主頁找到下載, 也可以從下面的鏈接下載:
    下面簡單說明產(chǎn)生 公鑰/私鑰 和 加密/解密 的整個過程:
    • 首先將下載后的 bmrsa10.zip 解壓縮到一個目錄, 進入這個目錄;
    • 如果是 linux 環(huán)境下, 為了后面輸入命令方便, 可以執(zhí)行 export PATH=.:$PATH , 將當(dāng)前目錄加入 PATH;
    • 首先生成一個 768 位的密鑰文件 _keys.768-bit.txt:
    bmrsa -mkh -g 48 -f _keys.768-bit.txt
    • 接走我們建立另外兩個文本文件 _private-key.768-bit.txt_public-key.768-bit.txt, 分別對應(yīng)私鑰和公鑰. 這兩個文件都是對 _keys.768-bit.txt 中內(nèi)容的裁減, 基本上類似這個樣子:
      • _private-key.768-bit.txt
    public mod=7ECF58B12DAB4557B9B39589D26CA444BDF96...
    private key=3C4B0676352943057A3B6B0D54A8B0E56265B...
    private p=ED66018402DEED19082ED5EA500B778DAFA7A0...
    private q=88BF09780DC8C15C429AE72AC6F91B0795C4E68...
    • 和:
      • _public-key.768-bit.txt
    public mod=7ECF58B12DAB4557B9B39589D26CA444BDF96...
    public key=BA562B6FEF44681C8937C54FCB985B205DAF0A...
    • 在實際使用中, 我們可以把公鑰公布出來, 而用私鑰加密傳遞的信息, 接收到信息的人可以使用公鑰對信息進行解密(另外也可以反過來使用公鑰加密, 接收方使用私鑰解密);
      • 具體到這個例子中, 也就是說我們可以把 _public-key.768-bit.txt 公開給需要接收我們的信息的人, 而 _private-key.768-bit.txt 必需妥善保管, 因為一旦別人拿到這個私鑰, 那就意味著他可以冒充你發(fā)送消息了;
    • 下面我們建立一個文本文件 _demo.txt 作為加密的原文:
    NAME=thinkbase
    URL =http://www.thinkbase.net
    IP =218.81.120.31
    • 我們使用密鑰 _private-key.768-bit.txt_demo.txt 進行加密, 加密后的文件是 _demo.enc.txt
    bmrsa -mkh -mit -moh -pr -f _private-key.768-bit.txt <_demo.txt >_demo.enc.txt
    • 接收方拿到加密后的文件 _demo.enc.txt 后, 可以使用公鑰 _public-key.768-bit.txt 對信息進行解密:
    bmrsa -mkh -mih -mot -pu -f _public-key.768-bit.txt <_demo.enc.txt

    具體的運行界面參見下圖:




    在實驗過程中使用的一些文件也可以下載, 供參考:
    posted @ 2006-07-29 00:18 thinkbase.net 閱讀(2047) | 評論 (0)編輯 收藏
     

    (原文來自: 2006-06-18 嘗試了一下用 swig 編寫 JNI 程序)

    總是覺得編寫 JNI (Java Native Interface) 程序是件復(fù)雜的事情, 于是開始漫無目的地搜索是否有簡單一點的方法, 倒是有些商業(yè)軟件提供這樣的功能, 比如 http://www.jniwrapper.com 就提供了通過 Java 直接調(diào)用 DLL 的功能(可惜是商業(yè)軟件, 哈哈).

    搜索中無意到了 swig 的網(wǎng)站( http://www.swig.org ), 看到一個用 swig 產(chǎn)生 Java 模塊的例子(原來知道 swig 是因為 python 的緣故), 于是就照著例子自己嘗試了一下(比例子稍微復(fù)雜一點, 另外我是用 mingw 上的 gcc 進行編譯的).

    源代碼包括 3 個文件, Example.c, Example.i, net/thinkbase/test/Test.java:

    /**?Example.c?****************************************************************/
    #include?<time.h>

    /**A?variable*/
    double? PI?=? 3.1415927 ;

    /**Return?n!*/
    int? fact ( int? n )?{
    ???? if? ( n?<=? 1 )
    ???????? return? 1 ;
    ???? else
    ???????? return? n*fact ( n- 1 ) ;
    }

    /**mod?function*/
    int? mod ( int? x,? int? y )?{
    ???? return? ( x%y ) ;
    }

    /**Get?time?as?String*/
    char? *?getTime (){
    ???? time_t?ltime;
    ???? time ( &ltime ) ;
    ???? return? ctime ( &ltime ) ;
    }

    /**to?upper?case*/
    char? *?toUpperCase ( char? *?result ){
    ???? char? *?p?=?result;
    ???? while ( '\0' !=*p ){
    ???????? char? c?=?*p;
    ???????? if? (?( c?>? 'a' ) && ( c?<? 'x' )?){
    ???????? *p?=?c- 32 ;
    ???????? }
    ???????? p++;
    ???? }
    ???? return? result;
    }


    /**?Example.i?****************************************************************/
    %module?Example
    % {
    ???? /*?Put?header?files?here?or?function?declarations?like?below?*/
    ???? extern? double? PI;
    ???? extern? int? fact ( int? n ) ;
    ???? extern? int? mod ( int? x,? int? y ) ;
    ???? extern? char? *?getTime () ;
    ???? extern? char? *?toUpperCase ( char? *?str ) ;
    % }

    extern? double? PI;
    extern? int? fact ( int? n ) ;
    extern? int? mod ( int? x,? int? y ) ;
    extern? char? *?getTime () ;
    extern? char? *?toUpperCase ( char? *?str ) ;


    /**?net/thinkbase/test/Test.java?*********************************************/
    package? net.thinkbase.test;

    import? net.thinkbase.test.swig.Example;

    public?class? Test? {
    ???? public?static? void? main ( String?argv [])?{
    ???????? System.loadLibrary ( "Example" ) ;
    ???????? System.out.println (
    ???????????? "????Example.getPI()??????=?"? +?Example.getPI ()) ;
    ???????? System.out.println (
    ???????????? "????Example.fact(6)??????=?"? +?Example.fact ( 6 )) ;

    ???????? System.loadLibrary ( "Example" ) ;
    ???????? System.out.println (
    ???????????? "????Example.mod(100,?30)?=?"? +?Example.mod ( 100 ,? 30 )) ;
    ???????? System.out.println (
    ???????????? "????Example.getTime()????=?"? +?Example.getTime ()) ;
    ???????? System.out.println (
    ???????????? "????Example.toUpperCase(\"Hello,?world!\")?=?"? +
    ???????????? Example.toUpperCase ( "Hello,?world!" )) ;
    ???? }
    }



    試驗步驟

    建立必要的目錄:
    • mkdir "net/thinkbase/test/swig"
    • mkdir ".out"
    使用 swig 建立相關(guān)接口:
    • swig -java -package net.thinkbase.test.swig -outdir net/thinkbase/test/swig Example.i
    編譯 c 文件得到 dll:
    • gcc -c Example.c -o .out/Example.o -I%JAVA_HOME%/include -I%JAVA_HOME%/include/win32
    • gcc -c Example_wrap.c -o .out/Example_wrap.o -I%JAVA_HOME%/include -I%JAVA_HOME%/include/win32
    • gcc -shared .out/Example.o .out/Example_wrap.o -mno-cygwin -Wl,--add-stdcall-alias -o .out/Example.dll
    編譯測試用的 Java 程序:
    • javac -sourcepath . net/thinkbase/test/Test.java -d .out
    運行測試:
    • java -cp .out -Djava.library.path=.out net.thinkbase.test.Test
    運行及測試結(jié)果:
    源代碼可以從這里下載:
    posted @ 2006-07-29 00:16 thinkbase.net 閱讀(4149) | 評論 (0)編輯 收藏

    2006年6月15日

    一個方便的SSL證書配置工具的介紹, 以及Tomcat上配置雙向SSL(就是必須要客戶端數(shù)字證書才能訪問)的具體例子; 文章的主要內(nèi)容完成于一年半以前, 現(xiàn)在發(fā)表基本上算是炒冷飯了, 不過最近加上了 Tomcat 5 和 Tomcat 4 上的實際配置例子, 所以整理了一下重新發(fā)出來.

    配置適用于正式使用環(huán)境下的Tomcat Web服務(wù)器雙向SSL認(rèn)證

    在 Tomcat 5.5 上的配置實例
    在 Tomcat 4.1.31 上的配置實例
    posted @ 2006-06-15 00:16 thinkbase.net 閱讀(5470) | 評論 (14)編輯 收藏

    2006年6月5日

    (如果看不到圖請點擊標(biāo)題進入)
    類別: ubuntu
    將 Java 開發(fā)環(huán)境遷移到 Ubuntu 基本完成了, 現(xiàn)在初步有了一個穩(wěn)定的開發(fā)環(huán)境:
    • Eclipse, 這個不用說了;
    • Firefox, 這個也不用說了;
    • JFileSync, 很好用的文件同步工具, 我主要用來和 Windows 機器上的某些目錄進行文件同步;
      http://jfilesync.sourceforge.net/
    • Meld, 文件比較工具, 大概和 Windows 下的 WinMerge 功能差不多, 不過這個東東是用 Python 寫的, 也許在 Windows 下面也能運行;
      http://meld.sourceforge.net/
    • NetBeans, 和 Eclipse 齊名的開源 Java IDE, 偶爾用用;
    • SVN Client, 其實就是另外一個 Eclipse(只是 Platform, 不含 JDT), 安裝了 subclipse 插件, 換了個圖標(biāo);
    • vmplayer, 可以認(rèn)為是著名的 VMWare 的簡化版, 只能運行, 不能創(chuàng)建虛擬機; 這是唯一一個非開源的軟件.

    posted @ 2006-06-05 00:41 thinkbase.net 閱讀(2556) | 評論 (1)編輯 收藏
     

    類別:? java | javamail | mail

    Aspirin(阿司匹林, https://aspirin.dev.java.net/ ), 按照網(wǎng)站上的介紹, "Aspirin is an embeddable send-only SMTP server.".

    為什么叫阿司匹林呢? 因為它就是用來解決令人頭痛的發(fā)送郵件問題的.

    Aspirin 項目中使用了部分來自 Apache James (Apache 著名的郵件服務(wù)器項目, http://james.apache.org/ )的代碼, 通過建立一個小型的 SMTP 服務(wù)器, 實現(xiàn)了一個不需要外部 SMTP 服務(wù)器的, 簡單的 mail 發(fā)送工具;

    不依賴于外部 SMTP 服務(wù)器, 意味著我們在通過 Java 程序發(fā)送郵件時, 可以不再需要安裝和配置 postfix, sendmail 等 email 服務(wù)器, 使應(yīng)用程序配置更簡單, 更方便做到跨平臺.

    使用 Aspirin 發(fā)送郵件的代碼很簡單, 代碼片斷如下:

    ...
    import? javax.mail.Message.RecipientType;
    import? javax.mail.internet.InternetAddress;
    import? javax.mail.internet.MimeMessage;

    import? org.masukomi.aspirin.core.MailQue;
    import? org.masukomi.aspirin.core.SimpleMimeMessageGenerator;

    ...

    ???????? MimeMessage?msg?=?SimpleMimeMessageGenerator.getNewMimeMessage () ;
    ???????? msg.setSubject ( subject ) ;
    ???????? msg.setText ( mailText ) ;
    ???????? msg.setFrom ( new? InternetAddress ( fromAddress )) ;
    ???????? msg.setRecipient ( RecipientType.TO,? new? InternetAddress ( toAddress )) ;
    ???????? MailQue.addWatcher ( new? DefaultWatch ()) ;
    ???????? MailQue.queMail ( msg ) ;

    ...


    另外需要注意的是,郵件其實是首先存放在一個隊列里面,然后再發(fā)送的,所以如果第一次發(fā)送失敗(比如 DNS 解析失敗),程序還是會進行重試的,所以郵件可能會比實際發(fā)送時間晚幾分鐘(甚至更長)發(fā)出;具體重試幾次,怎么樣算失敗,我還沒有仔細去研究.
    posted @ 2006-06-05 00:32 thinkbase.net 閱讀(2559) | 評論 (3)編輯 收藏

    2006年5月13日

    (如果看不到圖請點擊標(biāo)題進入)

    類別標(biāo)簽: NTLM | subclipse | subversion | ubuntu

    一開始使用 subclipse (Eclipse 的 Subversion 插件)不能通過 NTLM 認(rèn)證訪問 SVN 服務(wù)器, 始終報告如下圖所示的錯誤(svn: HTTP authorization method 'NTLM' is not supported):

    今天再看了一下, 在 Eclipse Perferences 中的 SVN 設(shè)置中發(fā)現(xiàn)不能選擇使用 "JavaHL" 作為 SVN 接口(報告的錯誤是在 java.library.path 中找不到 libsvnjavahl-1.so), 心想不知道使用 JavaHL 是否可以解決 NTLM 認(rèn)證的這個問題, 應(yīng)該嘗試一下, 上網(wǎng)查了查, 從 http://packages.ubuntulinux.org/dapper/devel/libsvn-javahl 找到了 libsvn-javahl 的下載 deb 包 libsvn-javahl_1.3.1-3ubuntu1_i386.deb, 下載完畢后使用
      sudo dpkg -i libsvn-javahl_1.3.1-3ubuntu1_i386.deb
    進行安裝, 卻被告知依賴的 libsvn0 還沒有被安裝, 直接用 apt-get install libsvn0 安裝后再次使用 dpkg -i 安裝下載的 libsvn-javahl_1.3.1-3ubuntu1_i386.deb, 卻被告知 libsvn0 版本不對:
    xxx@xxxlinux:~/Desktop$ sudo dpkg -i libsvn-javahl_1.3.1-3ubuntu1_i386.deb
    選中了曾被取消選擇的軟件包 libsvn-javahl。
    (正在讀取數(shù)據(jù)庫 ... 系統(tǒng)當(dāng)前總共安裝有 60192 個文件和目錄。)
    正在解壓縮 libsvn-javahl (從 libsvn-javahl_1.3.1-3ubuntu1_i386.deb) ...
    dpkg:依賴關(guān)系問題使得 libsvn-javahl 的配置工作不能繼續(xù):
    libsvn-javahl 依賴于 libsvn0 (= 1.3.1-3ubuntu1);然而:
    系統(tǒng)里的 libsvn0 的版本是 1.2.0-1ubuntu1.
    dpkg:處理 libsvn-javahl (--install)時出錯:
    依賴關(guān)系問題 - 仍未被配置
    在處理時有錯誤發(fā)生:
    libsvn-javahl
    于是又從 http://packages.ubuntulinux.org/dapper/devel/libsvn-javahl 頁面上找到 libsvn-javahl 的依賴庫 libsvn0 (= 1.3.1-3ubuntu1) 的 deb 文件, 然后安裝時又被告知依賴于其它的模塊(未安裝或者版本不對), 于是繼續(xù)使用 apt-get install 安裝這些模塊, 或者繼續(xù)在 http://packages.ubuntulinux.org/dapper/devel/ 下面各個依賴模塊的頁面上找到這些下一層的依賴模塊的 deb 安裝包, 如此循環(huán)往復(fù), 花了不少時間, 總算把 JavaHL 安裝好了.

    然后進入 $JAVA_HOME/jre/lib/i386/client/ 目錄, 執(zhí)行:
      sudo ln -s /usr/lib/jni/libsvnjavahl-1.so libsvnjavahl-1.so
    然后再啟動 Eclipse, 進入 SVN 的設(shè)置頁面, 果然現(xiàn)在可以選擇 "JavaHL (JNI)" 方式了:
    連接到 SVN 服務(wù)器測試, 果然現(xiàn)在能夠正確彈出輸入用戶名和密碼的對話框了:


    終于解決了這個問題, 現(xiàn)在可以將大部分工作都轉(zhuǎn)移到 Ubuntu 上面來啦 :)
    posted @ 2006-05-13 15:01 thinkbase.net 閱讀(1653) | 評論 (1)編輯 收藏
     
    (如果看不到圖,或者格式混亂,請點擊標(biāo)題進入)
    類別標(biāo)簽: font | ubuntu

    首先說一下, 這篇文章主要是針對 Java 開發(fā)者的, 如果是做 Windows 開發(fā), 那么基本上沒有辦法把工作環(huán)境移植到 Ubuntu 上的(當(dāng)然也不能說死, 也許以后可以使用 WINE 試試, 呵呵).

    1.系統(tǒng)默認(rèn)編碼


    我們知道在中文 Windows 下一般來說系統(tǒng)的默認(rèn)編碼是 GBK, 從 Java 開發(fā)的角度來說, 就是在進行諸如 Java 源代碼編譯, 文件讀寫等操作時, 默認(rèn)使用的編碼是 GBK; 而我們參照一般的 Ubuntu 中文安裝文檔, 可能會建議將默認(rèn)的語言設(shè)置為 zh_CN.UTF-8, 這樣會帶來一些問題, 比如我在 Windows 使用 Eclipse 時的編輯器的默認(rèn)編碼是 GBK, 但是在 Ubuntu 下面就是 UTF-8, 同樣是使用 Eclipse, 在 Windows 下的中文文檔到了 Ubuntu 中會產(chǎn)生亂碼, 必須手工逐個文檔設(shè)置屬性中的編碼為 GBK 才可以正常; 一些測試代碼也是以默認(rèn)編碼讀取文件的, 這些代碼讀取出來的文件內(nèi)容也會包含亂碼.

    所以, 最好是將系統(tǒng)的默認(rèn)編碼設(shè)置為 GBK, 這樣和 Windows 下面的開發(fā)環(huán)境最接近. 設(shè)置的方法應(yīng)該不止一種, 我采用的是編輯 /etc/environment, 改成這個樣子:
      LANGUAGE="zh_CN:zh:en_US:en"
    GST_ID3_TAG_ENCODING=GBK
    LANG=zh_CN.GBK
    LC_CTYLE=zh_CN.GBK

    2.中文字體


    Ubuntu 5.10 默認(rèn)安裝后的中文字體不是點陣字體, 因此在小字顯示的時候模模糊糊比較難看, 而且, 在瀏覽網(wǎng)頁時, 無法顯示中文粗體. 關(guān)于字體美化的文章網(wǎng)上太多了, 有些是采用 Windows 字體來進行的; 最近 "文泉驛"( http://wqy.sourceforge.net/ ) 的開源點陣字體受到很多好評, 而且點陣字體正好合適用于小字的顯示, 我用的是最新的 0.7 beta 版(0.6.9 pcf update 3), 按照 文泉驛點陣宋體安裝指南 上的步驟安裝, 修改了 xorg.conf, 也執(zhí)行了 fc-cache -f -v , 安裝過程還算順利, 就是有一點需要注意, 那就是字體一定要放在 /usr/share/fonts/ 的子目錄下面, 不然執(zhí)行 fc-cache 不會起作用的. 安裝完畢后需要配置一下系統(tǒng)的默認(rèn)字體, Firefox 也需要配置一下字體, 效果還是不錯的(見下面截圖).


    3.Java(Swing)程序的字體


    這個我主要參考了 最簡單的對JDK1.5的中文亂碼處理方法 , 按照其中更簡單的那個方法, 在 $JAVA_HOME/jre/lib/fonts/ 目錄下創(chuàng)建 fallback 目錄, 并把一個中文的 TTF 字體鏈接或者安裝到 fallback 目錄下就可以了.

    和參考文章說的稍有差別, 我是下載了文泉驛 0.6.9 ttf update 3 的 TTF 字體, 直接解壓后復(fù)制到 fallback 目錄下, 接著執(zhí)行 mkfontdir 和 mkfontscale, 果然問題得以解決; 現(xiàn)在 NetBeans 或者 JMeter 的 "打開" 文件對話框中的按鈕和標(biāo)簽就正確顯示出中文了.

    安裝在 Ubuntu 上面的 NetBeans 5.0:
    存在中文問題的"打開項目"對話框:
    經(jīng)過處理后可以正確顯示中文的對話框:

    參考:
    posted @ 2006-05-13 14:53 thinkbase.net 閱讀(2644) | 評論 (2)編輯 收藏
     
    .
    Ubuntu,源于非洲祖魯人和科薩人的語言,發(fā)作“oo-boon-too”的音。學(xué)會這個發(fā)音還是
    有價值的,你不是第一個人問這個問題了。
    大多數(shù)的美國人讀"ubuntu"時,將"u"作為元音發(fā)音,類似單詞 "who" 或者 "boo",重
    音在第二個音節(jié)即u'buntu,oo-boon-too。如果你喜歡添加一些非洲撒哈拉的味道,你可以在
    第一個"u",后面帶些嗡嗡聲:oom-boon-too。
    .
    (摘自 Ubuntu中文 的 FAQ: http://www.ubuntu.org.cn/support/documentation/faq/faqsection_view?section=Ubuntu )

    關(guān)于 Ubuntu 的詳細信息, 可以去看看這兩個網(wǎng)站:
    Qemu 是一個開源的 CPU 仿真器, 一般介紹都認(rèn)為它比 Bochs 快(當(dāng)然比不上 VMWare 啦), 試用一段時間后, 覺得速度還是慢, 不過倒是比較方便, Qemu 的所有配置都是在命令行上輸入的, 因此也就沒有什么配置文件了, 也不需要安裝過程, 解壓縮后就可以使用了.

    關(guān)于 Qemu, 可以看看如下鏈接:
    言歸正傳, 說說在 Qemu 上安裝 Ubuntu 5.10 的經(jīng)歷, 原先安裝了兩次都沒有成功, 報告磁盤是只讀的什么, 后來想想安裝時候都是指定在一個 2GB 的 Qemu 模擬硬盤上的, 估計是磁盤空間還是不夠, 所以這次用了一個 4GB 的模擬硬盤, 大概花了一個下午安裝才完成, 果然需要大于 2G 的空間. 閑話少說, 給幾張圖片 :)




    posted @ 2006-05-13 14:38 thinkbase.net 閱讀(2095) | 評論 (0)編輯 收藏
    僅列出標(biāo)題  
     
    主站蜘蛛池模板: 午夜网站免费版在线观看| 91精品视频在线免费观看| 亚洲一区二区三区高清不卡| 亚洲第一区精品日韩在线播放| 日本精品人妻无码免费大全| 国产精品免费高清在线观看| 一级看片免费视频| 青青青视频免费观看| 亚洲色成人WWW永久在线观看| 亚洲第一极品精品无码久久| 亚洲一区二区视频在线观看| 亚洲AV中文无码乱人伦| 成全视频免费高清| 免费理论片51人人看电影| 色吊丝最新永久免费观看网站| 成人免费福利视频| 成人无遮挡毛片免费看| 日本免费v片一二三区| 免费h黄肉动漫在线观看| 久久亚洲av无码精品浪潮| 免费A级毛片无码A∨男男| 免费在线视频一区| 亚洲午夜日韩高清一区| 亚洲精品国产精品乱码不卡| 狠狠亚洲婷婷综合色香五月排名| 日本亚洲视频在线| 亚洲日韩图片专区第1页| 亚洲黄色片免费看| 亚洲妇女熟BBW| 中文字幕视频在线免费观看| 91短视频在线免费观看| 国产乱子伦精品免费女| 国产亚洲真人做受在线观看| 亚洲精品国产精品国自产网站 | 亚洲国产欧洲综合997久久| 免费一级毛片在线播放放视频 | 亚洲日韩AV无码一区二区三区人 | 免费观看男人免费桶女人视频| 亚洲国产精品成人| 亚洲中文字幕无码mv| 国产情侣久久久久aⅴ免费|