2008年4月3日木曜日

jakarta-poi でExcelファイルを操作したときにはまったこと



3年くらい前に作ったプログラムの修正を今になってする


ぐうたらな話です。



poi-2.5.1-final-20040804.jar


POIを利用して、Excelファイルを読み取って、DBにインポートする


プログラムです。


開発やテストをしているときは、特に問題がなかったのですが


運用しているうちに、たまにセルのデータを読み込むと、


文字の後に空白(スペース)がくっつく現象が起こりました。


すべてにスペースがつくわけではないし、


スペースがつかないセルをコピーして上書きすると


その現象が解消されます。


再現性はあり、一度だめになったExcelデータは何度やってもだめで


同じようになります。


これは、Excelのデータ形式と、POIの読み取りの間でなんかあるなぁ~と思って


いろいろネットで調べていると


http://www.atmarkit.co.jp/bbs/phpBB/viewtopic.php?topic=31297&forum=12&4


どうも、ふりがな機能というのが悪さをしているようなことでした。(バグではないのか!?)


ん~、手っ取り早くなんとかならないかなぁ~ということで、バージョンアップ!!



poi-3.0.2-FINAL-20080204.jar


を使ってみることに。


ものの見事に、直っていました。(手抜きです。笑)


(※私の状況が改善されただけですので、直る保証はありません。)


特に、バージョン間の互換も問題なさそうだったので、そのまま使うことに。





とりあえず、同じ状況の人のために備忘録です。





2008年4月2日水曜日

validator-rule.xml の修正



struts1.2.4 -> struts1.2.9 にアップデートした際に


入力規制がことごとく、Exceptionを吐いていた。



validator.ValidatorForm (ValidatorForm.java:112) - org.apache.struts.validator.FieldChecks.validateRequired(java.lang.Object, org.apache.commons.validator.ValidatorAction, org.apache.commons.validator.Field, org.apache.struts.action.ActionMessages, javax.servlet.http.HttpServletRequest)
org.apache.commons.validator.ValidatorException: org.apache.struts.validator.FieldChecks.validateRequired(java.lang.Object, org.apache.commons.validator.ValidatorAction, org.apache.commons.validator.Field, org.apache.struts.action.ActionMessages, javax.servlet.http.HttpServletRequest)
at org.apache.commons.validator.ValidatorAction.loadValidationMethod(ValidatorAction.java:627)
at org.apache.commons.validator.ValidatorAction.executeValidationMethod(ValidatorAction.java:557)
at org.apache.commons.validator.Field.validateForRule(Field.java:827)
at org.apache.commons.validator.Field.validate(Field.java:906)
at org.apache.commons.validator.Form.validate(Form.java:174)
at org.apache.commons.validator.Validator.validate(Validator.java:367)
at org.apache.struts.validator.ValidatorForm.validate(ValidatorForm.java:110)
at org.apache.struts.action.RequestProcessor.processValidate(RequestProcessor.java:950)
at org.apache.struts.action.RequestProcessor.process(RequestProcessor.java:207)
at org.apache.struts.action.ActionServlet.process(ActionServlet.java:1196)
at org.apache.struts.action.ActionServlet.doPost(ActionServlet.java:432)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:709)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:802)






仕様は、そんなに変わってないだろーと、安易に考えていたのが間違い!!


設定ファイルの修正がいるとは、露知らず、あたふた。。。


どうも、struts1.2.7 くらいからそうなってたみたいね。


struts1.2.4 validator-rule.xml



<validator name="required"
classname="org.apache.struts.validator.FieldChecks"
method="validateRequired"
methodParams="java.lang.Object,
org.apache.commons.validator.ValidatorAction,
org.apache.commons.validator.Field,
org.apache.struts.action.ActionMessages,
javax.servlet.http.HttpServletRequest"
msg="errors.required"/>




struts1.2.9 validator-rule.xml



<validator name="required"
classname="org.apache.struts.validator.FieldChecks"
method="validateRequired"
methodParams="java.lang.Object,
org.apache.commons.validator.ValidatorAction,
org.apache.commons.validator.Field,
org.apache.struts.action.ActionMessages,
org.apache.commons.validator.Validator, <---- ここ追加
javax.servlet.http.HttpServletRequest"
msg="errors.required"/>



org.apache.struts.validator.FieldChecks の引数の個数が


5→6個に変更って知りませんでした。。。


他の、validator もすべて、methodParamsの修正が必要です。


以後、バージョンアップは気をつけます。