我用appletviewer运行applet时是可以正常打印日志的,但是把applet打成jar包签入到html页面里运行,就会报找不到log4j.properties错误。如果把log4j.properties写成绝对路径时html页面里就也能找到,但是相对的就找不到,为什么呢?我已经把log4j.properties和html还有jar包放到同一个目录下了。applet代码如下:static private void InitLog()
{
try
{
m_logger = Logger.getLogger ( PhonePlugin.class.getName () );
// PropertyConfigurator.configure ( "C:\\phoneplugin\\log4j.properties" );
PropertyConfigurator.configure ( "log4j.properties" );
}
catch ( Exception ex )
{
ex.printStackTrace ();
}
}html页面代码如下: <applet code="PhonePlugin.class" codebase="./" name="PhonePlugin" archive="PhonePlugin.jar" width="0" height="0" MAYSCRIPT>

解决方案 »

  1.   

    PS:
    我在Applet代码里加了一段获取当前路径的代码如下:
    m_logger = Logger.getLogger ( PhonePlugin.class.getName () );
    PropertyConfigurator.configure ( "log4j.properties" );
    Properties property = System.getProperties();
    String str = property.getProperty("user.dir");
    在appletviewer里运行的时候,获取当前路径是E:\Flex\workspace\PhonePlugin
    就是我放TestTerminal.html、PhonePlugin.jar包和log4j.properties的路径
     
    但是在用浏览器打开TestTerminal.html运行的时候,获取到的当前路径却是桌面所以找不到log4j.properties应该怎样让浏览器打开TestTerminal.html运行时候的当前路径也是E:\Flex\workspace\PhonePlugin这个路径呢?
      

  2.   

    Applet 因所谓安全问题,未经签名不能访问本地资源!
      

  3.   


    那怎么把路径写死的C:\\phoneplugin\\log4j.properties 这样就能访问呢?
      

  4.   

    遭遇同样问题,表示签名了依然不能访问,PropertyConfigurator.configure ( "log4j.properties" );后就卡住不动了。。坐等大牛解答
      

  5.   

    情景二:applet引入第三方的jar包,网页调用。这种情况比较烦人,这也是我纠结两天没才弄出来的原因。步骤基本如下: 第一步:我写了一个applet。修改了init方法,重写了paint方法,代码如下。public void paint(Graphics g){Output outClass = new Output();g.drawString("hahaha",20,20);g.drawString(outClass.getString(),10,10);} public void init() { setLayout(new FlowLayout()); add(new Button("预览")); } Output为我写的一个工具类类(它的主要作用是为了测试引入第三方jar包时,applet调用的问题),它会引入了一个第三方的jar包叫做“jna.jar”。代码如下: import com.sun.jna.NativeLong;public class Output {public String getString(){NativeLong m_lUserID = new NativeLong(1);//用户登录句柄return "You are in the Output Class" +m_lUserID.intValue();}}第二步:写一个demo2.html<body><applet codebase="." code="DemoApplet.class" name="DemoApplet" archive="jna.jar"width="320" height="240"></applet></body> 参数说明:其他参数都一样,只有添加了archive="jna.jar"这个参数是用来书写你引入的jar包的。如果有多个jar包,通过","分割。【注】1.第三方的jar包要和编译过的TestSimpleApplet.class在同一个目录下。2.工具类(outclass)编译所产生的class文件(output.class 和引入的其他类的编译文件)也要放在codebase所表明的文件夹下。 第三步:找到浏览器默认的jre,在其目录,举例为:*盘:\*\j2re1.4.2_05\lib\security\java.policy在grant{}中添加如下一行代码:permission   java.security.AllPermission;   第四步:点击运行网页,就出现了我们要的结果了。 可能出现错误:1.红色的叉,提示class无法找到。这就要注意查看applet的code 和codebase是否写对,.class和.jar文件的位置是否正确。2.security之类的错误。这主要就是因为要调用用户本地的文件,但是由于jave的安全机制原因,不让applet访问用户本地文件,所以会发生异常。此时,就需要给applet赋予访问权限,从而避免错误。3.网页中显示空白一块,或是灰色。那就是发生了异常,但是没有显示出来。此时就要在IE的选项->高级->选择Java(Sun)将JRE***用于<applet>。从而当网页运行applet程序时就会显示Java控制台。显示相应的异常错误,仔细观察,相信可以找到错误的原因。如有不解,请参考http://blog.csdn.net/rdhj5566/article/details/7774997
      

  6.   

    另外给引入的log4j加签名,可不用执行以上第三步