yzc164 发表于 2017-2-4 12:22:05

Eclipse+Tomcat调试时的一些错误笔记

  No.1:

  今天在测试Eclipse+Tomcat写的应用程序的时候出现了这样警告:

  


  




2008-10-11 21:33:55 org.apache.tomcat.util.digester.SetPropertiesRule begin



警告
: {Server/Service/Engine/Host/Context} Setting property 'source' to 'org.eclipse.jst.jee.server:TestTomcat6.0.16' did not find a matching property.



2008-10-11 21:33:55 org.apache.catalina.core.AprLifecycleListener init



信息
:
The APR based Apache Tomcat Native library which allows optimal
performance in production environments was not found on the
java.library.path: D:\study tools\Java\jdk1.5.0_06\bin;.;C:\WINDOWS\system32;C:\WINDOWS;D:/study
tools/Java/jdk1.5.0_06/bin/../jre/bin/client;D:/study
tools/Java/jdk1.5.0_06/bin/../jre/bin;D:\study
tools\Borland\Delphi7\Bin;D:\study
tools\Borland\Delphi7\Projects\Bpl\;D:\study
tools\Java\jdk1.5.0_06\bin;C:\WINDOWS\system32;C:\WINDOWS;C:\WINDOWS\System32\Wbem;D:\study
tools\MySQL\MySQL Server 5.0\bin;C:\Program Files\Microsoft SQL
Server\80\Tools\BINN











  出现SetPropertiesRule
警告的原因是因为Tomcat
在server.xml
的Context
节点中不支持source
属性:
<Context docBase="…" path="/…" source="org.eclipse.jst.j2ee.server:…"/>



  





  解决方法是在Servers
视图里双击创建的server
,然后在其server
的配置界面中选中"Publish module contexts to separate XML files"
选项。如下图:




  不过,不知道这样做的具体意义是什么,因为即使出现这个Warning,程序也正常执行。

  


  


  NO2:

  


  还有一个错误信息是:

  信息: The Apache Tomcat Native
library which allows optimal performance in production environments was
not found on the java.library.path: 
  


  这个具体信息参考:Apache Tomcat Native library


  解决方法是:http://tomcat.heanet.ie/native/
下载你需要的版本的tcnative-1.dll放入System32下面或者放在Tomcat
的bin目录下即可。

  NO3:

  这个跟Mysql有关,就是在插入Date类型数据时候,Java改如何写插入语句:


Date newDate = java.sql.Date.valueOf(time);
rs.moveToInsertRow();
rs.updateDate(5, newDate);
rs.insertRow();
  NO4,:

  今天用javamail做了一个发送邮件的功能.遇到了一系列的问题.

  1:在本地(windows环境)测试一切正常,上传到服务器(Linux环境)就出了问题.[java.lang.SecurityException:   Access   to   default   session   denied

],也就是获得默认的session时无法获得.郁闷了N久,在网上搜了下,有朋友遇到同样的问题,但都没人给予解决方案,我在csdn,javaeye发帖也没人回.后来在又看了一朋友的blog,他写的解决办法是,
把mailSession = Session.getDefaultInstance(props,sa);改成mailSession = Session.getInstance(props,sa);
就是新创建一个session,我试了下,可以解决问题.但还是找到为什么不能获取默认session的原因.而且担心这样没次都Session.getInstance(props,sa);会不会出问题.

  2.发送email内容为html时,出现乱码.同样是在本地测试正常,传到服务器上就出问题.后来经过测试,发现是服务器默认编码的问题,服务器
的默认编码UTF-8,我的email内容是本地一html文件,在读取文件内容时没有设置编码,所以读取出来的就已经是乱码了,.后来该成
FileInputStream fis = new FileInputStream(filename);BufferedReader in =
new BufferedReader(new InputStreamReader(fis,"GBK"));就OK了.
InputStreamReader不指定编码方式的话将采用底层操作系统的默认编码方式,所以这里要在构造器重指定编码的方式.

  3.static变量的问题.         我定义了一个静态类变量public static boolean isRunning =
false;来判断状态,刚开始一切正常,但是在一次出了异常之后.就无法执行了,有让我郁闷了好大一会.后来才发现.是static的原因.(
static变量属于类变量,在这个类的所有 new出来的对象中只存在一个该变量,每个对象是对同一变量进行操作,static的变量和初始化块仅仅运行一次。不象没有static的变量,每次new的时候,都会重新初始化
。)因为static变量只初始化一次,之后使用的值都是之前的状态值.所以我的问题就出在当运行正常时,运行时会把状态改为true,结束后会把状态改为false.但是出现异常时,后面就没把状态改成false.所以下次执行时就无法往下执行了. from:http://hi.baidu.com/xublog/blog/item/7f7d5bfc8f356381b901a0e7.html
页: [1]
查看完整版本: Eclipse+Tomcat调试时的一些错误笔记