無聊人士

          搬家==》www.soapui.cn

            BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
            32 隨筆 :: 0 文章 :: 60 評論 :: 0 Trackbacks

          2006年10月12日 #

          struts 2.0.6GA開始試螃蟹,照著struts2的tag文檔寫成<@s.datetimepicker/>,結果老是報錯
          211672?[http-8080-Processor25]?ERROR?freemarker.runtime??-?
          on?line?
          7,?column?17?in?admin/index.ftl?s.datetimepicker?not?found.
          The?problematic?instruction:
          ----------
          ==>?user-directive?s.datetimepicker?[on?line?7,?column?17?in?admin/index.ftl]
          ----------

          Java?backtrace?for?programmers:
          ----------
          freemarker.core.InvalidReferenceException:?on?line?
          7,?column?17?in?admin/index.ftl?s.datetimepicker?not?found.

          試著google一下,正好有人也提交了這個bug,改成 <@s.dateTimePicker />,問題解決

          The?fix?is?as?follows:

          In?struts2-core-
          2.0.6:
          org.apache.struts2.views.freemarker.tags.StrutsModels

          has?a?method
          getDateTimePicker()

          Which?should?be?re-named:
          getDatetimepicker()

          to?match?with?the?naming?convention.


          hello,struts2.jpg
          posted @ 2007-04-20 10:26 mmwy 閱讀(2598) | 評論 (0)編輯 收藏

          來自:http://www.javaworld.com.tw/jute/post/print?bid=11&id=166588

          3.Re:BIRT報表工具的問題?[Re:?uxa]?????Copy?to?clipboard
          Posted?by:?uxa
          Posted?on:?
          2006-09-15?15:28

          經過幾次的失敗後~~小弟終於試出來了
          不過感覺它似乎只是support?xls?file?format並沒有excel的一些功能>?<

          1.?download?eclipse?plugin?BIRT,小弟抓的是birt-report-designer-all-in-one-2_1_0.zip
          將其解開後把eclipse\plugins和eclipse\features這兩個目錄放到eclipse的目錄底下
          現在將eclipse打開,您已經可以開始設計報表了。

          2.?BIRT預設有支援HTML和PDF的格式,以下說明如何支援xls格式
          a.?download?xls-emitter-bin_2
          .1.0.zip,解開後將plugins複製到eclipse\plugins下
          b.?download?poi-bin-
          3.0-alpha2-20060616.zip,解開後將jar檔複製到eclipse\plugins\?org.uguess.birt.report.engine.emitter.xls_2.1.0.200607031206\lib
          c.?xls-emitter-bin_2
          .1.0.zip解開後有個path的目錄,
          (
          1)?將org.eclipse.birt.report.designer.ui目錄下的檔案複製到eclipse\plugins\org.eclipse.birt.report.designer.ui.preview_2.1.0.*.jar
          (
          2)將org.eclipse.birt.report.viewer目錄下的檔案複製到eclipse\plugins\?org.eclipse.birt.report.viewer_2.1.0.*\birt\WEB-INF\lib\viewservlets.jar
          (
          3)將org.eclipse.birt.report.engine目錄下的檔案複製到eclipse\plugins\org.eclipse.birt.report.engine_2.1.0.*.jar

          完成後啟動eclipse可看到在view?report的按鈕上多了xls和ppt兩種格式

          BIRT下載位置:http://download.eclipse.org/birt/downloads/
          Tribix下載位置:https://sourceforge.net/projects/tribix
          ps:請注意版本的問題,BIRT2
          .1.0請搭配Tribix?XLS?Emitter?2.1.0版本,在置換檔名的部份也請注意路徑是否正確

          posted @ 2007-04-08 15:42 mmwy 閱讀(1627) | 評論 (2)編輯 收藏

          條碼顯示,在birt中最常見的有兩種方法:1、使用條碼字體(對pdf無效);2、用barcode的開源包,生成barcode,然后在報表里用動態地址去取圖片。

          今晚看birt文檔(第 23 章 使用 Java 編寫事件處理程序),例子中用java實現了一個LabelEventAdapter的適配器,對標簽元素進行事件控制。腦子里靈光一現,似乎條碼有著落了。

          我的測試例子很簡單,繼承ImageEventAdapter類,重載onCreate方法,以進行條形碼處理

          ?1?package?cn.ynzc.common.birt.test;
          ?2?
          ?3?import?java.io.File;
          ?4?import?java.io.FileOutputStream;
          ?5?
          ?6?import?jbarcodebean.Code128;
          ?7?import?jbarcodebean.JBarcodeBean;
          ?8?
          ?9?import?org.apache.commons.codec.digest.DigestUtils;
          10?import?org.eclipse.birt.report.engine.api.script.IReportContext;
          11?import?org.eclipse.birt.report.engine.api.script.eventadapter.ImageEventAdapter;
          12?import?org.eclipse.birt.report.engine.api.script.instance.IImageInstance;
          13?
          14?public?class?MyLabelClass?extends?ImageEventAdapter?{
          15?
          16???public?void?onCreate(IImageInstance?image,?IReportContext?reportContext)?{
          17?????try?{
          18???????//實際應用中,可以使用image.getRowData().getColumnValue("columnname")獲得字段值
          19???????String?code?=?"ABCDEF123-2222";
          20???????//似乎windows文件名中不允許使用“-”等符號,干脆將code進行md5散列處理
          21???????File?file?=?new?File(System.getProperty("java.io.tmpdir"),?DigestUtils.md5Hex(code));
          22???????//避免每次都進行條碼文件生成
          23???????if?(!file.exists())?{
          24?????????JBarcodeBean?bb?=?new?JBarcodeBean();
          25?????????bb.setCodeType(new?Code128());
          26?????????bb.setShowText(true);
          27?????????bb.setBarcodeHeight(45);?//條碼高度
          28?????????bb.setCode(code);
          29?????????bb.gifEncode(new?FileOutputStream(file));
          30???????}
          31???????image.setFile(file.getAbsolutePath());
          32?????}
          33?????catch?(Exception?e)?{
          34???????e.printStackTrace();
          35?????}
          36???}
          37?
          38?}
          39?

          測試用的birt報表文件簡單得要死,就往上面扔了個image元素,設置其Event Handler Class為剛才寫好的java類,最終得到的rptdesign文件內容如下:
          ?1?<?xml?version="1.0"?encoding="UTF-8"?>
          ?2?<!--?Written?by?Eclipse?BIRT?2.0?-->
          ?3?<report?xmlns="http://www.eclipse.org/birt/2005/design"?version="3.2.6"?id="1">
          ?4?????<property?name="createdBy">Eclipse?BIRT?Designer?Version?2.1.2.v20070205-1728?Build?&lt;20070205-1728></property>
          ?5?????<property?name="units">in</property>
          ?6?????<page-setup>
          ?7?????????<simple-master-page?name="Simple?MasterPage"?id="2"/>
          ?8?????</page-setup>
          ?9?????<body>
          10?????????<image?id="4">
          11?????????????<property?name="eventHandlerClass">cn.ynzc.common.birt.test.MyLabelClass</property>
          12?????????</image>
          13?????</body>
          14?</report>

          運行測試,條形碼出來了
          birt.jpg

          遺留問題:
          這次是調用org.eclipse.birt.report.engine.api.script.instance.IImageInstance.setFile()來解決問題,從javadoc可以看到,IImageInstance有很多方法可以調用,其它方法分別有什么作用?比如我嘗試了半天的setData(byte[])方法,一開始以為是用這個方法直接把圖形數據set進去就ok,結果未成功。


          posted @ 2007-04-07 03:37 mmwy 閱讀(4233) | 評論 (4)編輯 收藏

          birt的IRunAndRenderTask接口提供了addScriptableJavaObject(java.lang.String jsName, java.lang.Object obj)方法,利用這個方法,在直接調用birt api操作處理報表的時候,我們可以將任何java對象通過addScriptableJavaObject("xxx",Object)加進birt去,然后在birt腳本中直接調用xxx.method()進行操作。

          我的測試是在一個webwork+spring+hibernate的webapp應用中進行的,進行報表處理的代碼參照http://wiki.eclipse.org/index.php/Servlet_Example編寫,在代碼中,寫了一句
          task.addScriptableJavaObject("ctx",
          WebApplicationContextUtils.getWebApplicationContext(sc));

          birt中定義了一個scripts datasource,然后定義一個data set,在dataset的open方法中編寫腳本

          infoManager=ctx.getBean("infoManager");
          infos=infoManager.loadAll();
          ...
          posted @ 2007-04-06 15:39 mmwy 閱讀(2067) | 評論 (3)編輯 收藏

          在apache網站上已經有很詳細的介紹
          http://tomcat.apache.org/connectors-doc/reference/iis.html

          有幾點注意的:
          1、除了照文檔的例子在注冊表"HKEY_LOCAL_MACHINE\SOFTWARE\Apache Software Foundation\Jakarta Isapi Redirector\1.0"建相應鍵值外,還可以在isapi_redirect.dll所在的目錄建“isapi_redirect.properties”文件。

          2、extension_uri=/jakarta/isapi_redirect.dll
          這個extension_uri寫成什么路徑,就得在iis站點中建相應名字的虛擬目錄(執行權限),以保證/jakarta/isapi_redirect.dll能被正常訪問到。

          3、除文檔上介紹的幾大步(注冊表、網站、虛擬路徑等)以外,win2003 iis上還得做下面這個步驟

          新建應用程序擴展
          在IIS管理器左側網站下面選中Web服務擴展,添加一個新的Web服務擴展,擴展名為jakarta,添加要求得文件為D:\Tomcat5.0\bin\jakart\isapi_redirect.dll,并設置擴展狀態為允許。
          (注:來自 http://www.cnrui.cn/blog/article.asp?id=179




          posted @ 2007-03-19 15:39 mmwy 閱讀(1836) | 評論 (2)編輯 收藏



          選中table的detail行,切換到script標簽,在onPrepare事件中輸入
          ?
          count=1;

          在onCreate事件中輸入
          1count++;
          2this.getStyle().backgroundColor=(count%2==0?"red":"blue");

          或是直接打開xml source,在相應的detail位置上修改源碼為
          ????????????????<detail>
          ??????????????????
          <row?id="66">
          ????????????????????.
          ????????????????????
          <method?name="onPrepare"><![CDATA[count=1;]]></method>
          ????????????????????
          <method?name="onCreate"><![CDATA[count++;this.getStyle().backgroundColor=(count%2==0?"red":"blue");]]></method>
          ????????????????????..

          xxxxx.jpg

          posted @ 2006-11-24 01:04 mmwy 閱讀(1882) | 評論 (0)編輯 收藏

          定義報表參數:

          3.jpg



          解決方法一:

          1.jpg


          2.jpg



          解決辦法二:

          在報表空白處點擊一下,然后切換到script標簽,選擇beforeFactory。

          4.jpg


          posted @ 2006-11-23 01:48 mmwy 閱讀(3287) | 評論 (0)編輯 收藏

          筆記一下:

          設hibernate.hbm2ddl.auto為update/create-drop/create后,在classpath中扔一個/import.sql進去,hibernate啟動時就會執行import.sql的內容。

          11860 [main] INFO? org.hibernate.tool.hbm2ddl.SchemaExport? - Running hbm2ddl schema export
          11860 [main] DEBUG org.hibernate.tool.hbm2ddl.SchemaExport? - import file not found: /import.sql
          11875 [main] INFO? org.hibernate.tool.hbm2ddl.SchemaExport? - exporting generated schema to database
          posted @ 2006-10-31 00:32 mmwy 閱讀(5765) | 評論 (2)編輯 收藏

          使用的安裝包:
          ?1?cronolog-1.6.2.tar.gz??????????????????????????????
          ?2httpd-2.0.59.tar.gz????????????????????????????????
          ?3instantclient-basic-linux32-10.2.0.2-20060331.zip??
          ?4instantclient-sdk-linux32-10.2.0.2-20060331.zip????
          ?5libmcrypt-2.5.7.tar.gz?????????????????????????????
          ?6mhash-0.9.7.1.tar.gz???????????????????????????????
          ?7mysql-3.23.58.tar.gz???????????????????????????????
          ?8php-4.4.4.tar.gz????

          參考文檔

          1. 為 Linux 和 Windows 安裝 PHP 和 Oracle 10g Instant Client
          2. Connecting to Oracle10g from PHP using OCI-8 (Linux)
          與文檔有出處的地方
          1. otn上只能下到zip格式的oracle 10g instant client basic和sdk包。解壓縮后,全部放到instantclient_10_2目錄下。
            [root@localhost?sdk]#?ls?-l?..
            total?
            115948
            -r--r--r--??
            1?root?root??1594191?Feb??5??2006?classes12.jar
            -rwxrwxr-x??
            2?root?root?18774535?Feb??5??2006?libclntsh.so
            -rwxrwxr-x??
            2?root?root?18774535?Feb??5??2006?libclntsh.so.10.1
            -r-xr-xr-x??
            1?root?root??5623929?Feb??5??2006?libnnz10.so
            -rwxrwxr-x??
            1?root?root??1398088?Feb??5??2006?libocci.so.10.1
            -rwxrwxr-x??
            1?root?root?70690282?Feb??5??2006?libociei.so
            -r-xr-xr-x??
            1?root?root???119919?Feb??5??2006?libocijdbc10.so
            -r--r--r--??
            1?root?root??1540457?Feb??5??2006?ojdbc14.jar
            drwxr-xr-x??
            4?root?root?????4096?Oct?17?04:27?sdk
            [root@localhost?sdk]#?ls?-l
            total?
            324
            drwxr-xr-x??
            2?root?root???4096?Oct?17?04:27?demo
            drwxr-xr-x??
            2?root?root???4096?Oct?17?04:27?include
            -r-xr-xr-x??
            1?root?root????346?Oct?17?04:27?ott
            -rw-r--r--??
            1?root?root?298274?Oct?17?04:27?ottclasses.zip
          2. php4.4.4已經提供了--with-oci8-instant-client參數的支持,同時修復了相關補丁,因此,文檔中為php打補丁、重建“configure”腳本的步驟可以省略。
          環境變量:
          1. 在LD_LIBRARY_PATH中添加oracle 10g instant client的路徑。
            export?LD_LIBRARY_PATH=/www/server/instantclient_10_2/:${LD_LIBRARY_PATH}
          2. 設置TNS_ADMIN為oracle tnsname.ora文件所在目錄。
            export?TNS_ADMIN=/u01/app/oracle/product/10g/network/admin/
          編譯腳本
          ./configure \
          --prefix
          =/www/server/php-4.4.4 \
          --with-apxs2
          =/www/server/httpd-2.0.59/bin/apxs \
          --with-mysql
          =/www/server/mysql-3.23.58 \
          --with-mcrypt
          =/www/server/libmcrypt-2.5.7 \
          --with-mhash
          =/www/server/mhash-0.9.7.1 \
          --with-gd?--with-zlib \
          --with-oci8-instant-client
          =/www/server/instantclient_10_2
          注:需要使用ln命令為libclntsh.so.10.1創建一個名為libclntsh.so的連接,否則在configure過程中將會出現error:Link xxxx not found的錯誤。(http://forums.oracle.com/forums/thread.jspa?messageID=1203218&#1203218

          測試
          1. 安裝成功的話,在phpinfo()信息中可以看到相應信息
            OCI8?Support????????????????? enabled
            Revision????????????????????? $Revision:?
            1.183.2.18.2.3?$
            Oracle?Version???????????????
            10.1
            Compile-time?ORACLE_HOME????? /www/server/instantclient_10_2
            Libraries?Used??????????????? no?value
          2. 測試代碼
            ?1?<?php?
            ?2?$conn?=?OCILogon("username",?"password",?"//127.0.0.1:1521/sid");
            ?3?$query?=?'select?table_name?from?user_tables';
            ?4?$stid?=?OCIParse($conn,?$query);
            ?5?OCIExecute($stid,?OCI_DEFAULT);
            ?6?
            ?7?while?($succ?=?OCIFetchInto($stid,?$row))?{
            ?8?????foreach?($row?as?$item)?{
            ?9?????????echo?$item."?";
            10?????????}
            11?????echo?"<br>\n";
            12??}
            13?OCILogoff($conn);
            14??>


          posted @ 2006-10-15 02:46 mmwy 閱讀(1337) | 評論 (1)編輯 收藏

          最近在“玩”hibernate Annotation,弄了個Attachment保存進數據庫的測試,附件內容保存在content屬性里面。
          ??@Lob
          ??@Column(columnDefinition?
          =?"LongBlob")
          ??
          public?byte[]?getContent()?{
          ????
          return?content;
          ??}
          一開始,配置mysql jdbc url如下
          jdbc.url????????????=????jdbc:mysql://localhost/test\
          ?????????????????????????????useUnicode
          =true\
          ????????????????????????????&characterEncoding
          =gbk
          一測試,報錯
          Caused?by:?java.sql.BatchUpdateException:?Syntax?error?or?access?violation?message?from?server:?"You?have?an?error?in?your?SQL?syntax?near?''D0CF11E0A1B11AE1000000000000000000000000000000003E000300FEFF0900060000000000000'?at?line?1"
          ????at?com.mysql.jdbc.PreparedStatement.executeBatch(PreparedStatement.java:
          1540)
          同樣的語句,直接在mysql命令行下運行就沒問題,偏偏jdbc上就有這臭毛病。換jdbc driver版本,改@Lob為 @Type(type = "org.springframework.orm.hibernate3.support.BlobByteArrayType"),改hibernate配置(比如hibernate.jdbc.use_streams_for_binary true),甚至是直接用jdbc來insert,亂七八糟折騰半天,問題照舊。最后只好用上“歪”招,把byte[]配成String,在保存的時候把byte[]保存成hex String格式,取的時候再解碼回來。

          歪招終歸是歪招,這兩天老為這東西心煩,晚上吃飯的時候無意中想起charset的問題,把代碼撿回來再測試了一下,問題解決,哈哈!
          jdbc.url????????????=????jdbc:mysql://localhost/mmwy_blog\
          ?????????????????????????????useUnicode
          =true\
          ????????????????????????????&characterEncoding
          =utf-8
          如果設成iso-8859-1、utf-8,保存一點問題都沒有,換用gbk、gb2312、big5之類的字符集,問題就出來了。

          posted @ 2006-10-12 15:54 mmwy 閱讀(1768) | 評論 (1)編輯 收藏

          最近開始嘗試hibernate annotations,終于成功的將手上一個小應用轉為annotations :)

          1、spring orm support
          與原來使用LocalSessionFactoryBean相比,變動不大(AnnotationSessionFactoryBean本來就是從LocalSessionFactoryBean類繼承過來的嘛)
          ?1????<bean
          ?2?????????id="sessionFactory"
          ?3?????????class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean"
          ?4?????????parent="AbstractSessionFactory">
          ?5?????????<property?name="annotatedClasses">
          ?6?????????????<list>
          ?7?????????????????<value>xxx.xxx.xxx.domain.Account</value>
          ?8?????????????</list>
          ?9?????????</property>
          10?????</bean>
          11?????<bean
          12?????????id="AbstractSessionFactory"
          13?????????class="org.springframework.orm.hibernate3.LocalSessionFactoryBean"
          14?????????abstract="true">
          15?????????<property
          16?????????????name="dataSource"
          17?????????????ref="DataSource"?/>
          18?????????<property?name="hibernateProperties">
          19?????????????<props>
          20?????????????????<prop?key="hibernate.dialect">${hibernate.dialect}</prop>
          21?????????????????<prop?key="hibernate.show_sql">${hibernate.show_sql}</prop>
          22?????????????????<prop?key="hibernate.hbm2ddl.auto">${hibernate.hbm2ddl.auto}</prop>
          23?????????????????<prop?key="hibernate.cache.use_query_cache">${hibernate.cache.use_query_cache}</prop>
          24?????????????????<prop?key="hibernate.cache.provider_class">${hibernate.cache.provider_class}</prop>
          25?????????????</props>
          26?????????</property>
          27?????????<property
          28?????????????name="lobHandler"
          29?????????????ref="DefaultLobHandler"?/>
          30?????</bean>
          2、id的配置
          非常簡單,在id的getter上面加個“@Id”就可以了。此時采用的id策略是javax.persistence.GenerationType.AUTO,也可以再加上“@GeneratedValue(generator =GenerationType.IDENTITY|GenerationType.SEQUENCE|GenerationType.TABLE)”換成其它策略。
          我的應用采用的是hibernate的uuid策略,就不得不在這兒使用hibernate的擴展了
          ??@Id
          ??@Column(length?
          =?32)
          ??@GeneratedValue(generator?
          =?"system-uuid")
          ??@GenericGenerator(name?
          =?"system-uuid",?strategy?=?"uuid")

          3、級聯策略
          在ejb3-persistence.jar中只定義了ALL、MERGE、PERSIST、REFRESH、REMOVE,比較惡心的就是,刪除對象的時候,并不會級聯刪除關聯對象,而是用update xx set parent_id=null where parent_id=?這類語句把關系干掉了事。不得已,在這兒用了hibernate的DELETE_ORPHAN。
          ??@OneToMany(targetEntity?=?Attachment.class)
          ??@Cascade(value?
          =?{org.hibernate.annotations.CascadeType.DELETE_ORPHAN,
          ??????org.hibernate.annotations.CascadeType.ALL})
          ??@JoinColumn(name?
          =?"info_id")
          4、CACHE
          ejb3-persistence.jar里面沒有找到cache的配置,繼續請出hibernate來干活
          import?org.hibernate.annotations.Cache;
          import?org.hibernate.annotations.CacheConcurrencyStrategy;

          @Entity
          @Table(name?
          =?"T_INFO")
          @Cache(usage?
          =?CacheConcurrencyStrategy.NONSTRICT_READ_WRITE)
          5、自定義字段類型
          我的POJO中有一個private String content;的屬性,按ejb3配成@Lob后,被處理成了text類型,text 64k的存儲容量還是比較可憐了。
          ??@Lob
          ??@Column(columnDefinition?
          =?"LongText")

          posted @ 2006-10-12 15:38 mmwy 閱讀(4888) | 評論 (0)編輯 收藏

          主站蜘蛛池模板: 芜湖县| 尚志市| 通渭县| 孙吴县| 杨浦区| 雷州市| 惠来县| 正定县| 张家口市| 新巴尔虎左旗| 东源县| 策勒县| 清河县| 罗源县| 东港市| 西青区| 龙里县| 阳山县| 沁源县| 河西区| 江门市| 宜丰县| 龙陵县| 奉贤区| 娄底市| 阿克陶县| 渭源县| 汾阳市| 桂平市| 周至县| 长海县| 芮城县| 驻马店市| 施秉县| 南木林县| 宁强县| 韶关市| 项城市| 漳平市| 武穴市| 瓦房店市|