The new forums will be named Coin Return (based on the most recent vote)! You can check on the status and timeline of the transition to the new forums here.
The Guiding Principles and New Rules document is now in effect.

Tomcat 5.5 and Velocity Servlets. I think I hate them.

Jimmy KingJimmy King Registered User regular
edited May 2008 in Help / Advice Forum
So, I'm kind of hoping someone here might know there way around Tomcat and VelocityViewServlet way more than I do. I had written some stuff not too long ago using a regular VelocityServlet. That all works just great. Seeing as how VelocityServlet is deprecated, though, I'm trying to convert things to VelocityViewServlet. I need your help. Everything within reach and smashable in my house wants you to help me.

Root cause stack trace is spoilered as it's a bit long. The short version is that something is dying in init(). Judging by the stack trace it's trying to read something... who the fuck knows what it might be trying to read, though. VelocityViewServlet works fine on my XP machine running the servlet on tomcat from ecplipse. Regular old deprecated VelocityServlet type servlets work fine on the server. VelocityViewServlet type servlets die on the server. I have granted everything in catalina.home/common/ (which is where the velocity libs live) read access to everything in my servlet.
exception

javax.servlet.ServletException
org.apache.velocity.tools.view.servlet.VelocityViewServlet.initVelocity(VelocityViewServlet.java:385)
org.apache.velocity.tools.view.servlet.VelocityViewServlet.init(VelocityViewServlet.java:209)
sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
java.lang.reflect.Method.invoke(Method.java:585)
org.apache.catalina.security.SecurityUtil$1.run(SecurityUtil.java:243)
java.security.AccessController.doPrivileged(Native Method)
javax.security.auth.Subject.doAsPrivileged(Subject.java:517)
org.apache.catalina.security.SecurityUtil.execute(SecurityUtil.java:275)
org.apache.catalina.security.SecurityUtil.doAsPrivilege(SecurityUtil.java:161)
org.apache.catalina.security.SecurityUtil.doAsPrivilege(SecurityUtil.java:114)
org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:105)
org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:541)
org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:148)
org.apache.jk.server.JkCoyoteHandler.invoke(JkCoyoteHandler.java:199)
org.apache.jk.common.HandlerRequest.invoke(HandlerRequest.java:282)
org.apache.jk.common.ChannelSocket.invoke(ChannelSocket.java:767)
org.apache.jk.common.ChannelSocket.processConnection(ChannelSocket.java:697)
org.apache.jk.common.ChannelSocket$SocketConnection.runIt(ChannelSocket.java:889)
org.apache.tomcat.util.threads.ThreadPool$ControlRunnable.run(ThreadPool.java:684)
java.lang.Thread.run(Thread.java:595)

root cause

java.lang.NullPointerException
java.io.Reader.<init>(Reader.java:61)
java.io.InputStreamReader.<init>(InputStreamReader.java:80)
org.apache.commons.collections.ExtendedProperties.load(ExtendedProperties.java:544)
org.apache.commons.collections.ExtendedProperties.load(ExtendedProperties.java:520)
org.apache.velocity.runtime.RuntimeInstance.setDefaultProperties(RuntimeInstance.java:346)
org.apache.velocity.runtime.RuntimeInstance.initializeProperties(RuntimeInstance.java:515)
org.apache.velocity.runtime.RuntimeInstance.init(RuntimeInstance.java:239)
org.apache.velocity.app.VelocityEngine.init(VelocityEngine.java:116)
org.apache.velocity.tools.view.servlet.VelocityViewServlet.initVelocity(VelocityViewServlet.java:380)
org.apache.velocity.tools.view.servlet.VelocityViewServlet.init(VelocityViewServlet.java:209)
sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
java.lang.reflect.Method.invoke(Method.java:585)
org.apache.catalina.security.SecurityUtil$1.run(SecurityUtil.java:243)
java.security.AccessController.doPrivileged(Native Method)
javax.security.auth.Subject.doAsPrivileged(Subject.java:517)
org.apache.catalina.security.SecurityUtil.execute(SecurityUtil.java:275)
org.apache.catalina.security.SecurityUtil.doAsPrivilege(SecurityUtil.java:161)
org.apache.catalina.security.SecurityUtil.doAsPrivilege(SecurityUtil.java:114)
org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:105)
org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:541)
org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:148)
org.apache.jk.server.JkCoyoteHandler.invoke(JkCoyoteHandler.java:199)
org.apache.jk.common.HandlerRequest.invoke(HandlerRequest.java:282)
org.apache.jk.common.ChannelSocket.invoke(ChannelSocket.java:767)
org.apache.jk.common.ChannelSocket.processConnection(ChannelSocket.java:697)
org.apache.jk.common.ChannelSocket$SocketConnection.runIt(ChannelSocket.java:889)
org.apache.tomcat.util.threads.ThreadPool$ControlRunnable.run(ThreadPool.java:684)
java.lang.Thread.run(Thread.java:595)

edit: Ok, it's definitely something related to the security manager settings. My best guess is that something is unable to read org.apache.velocity.runtime.defaults.velocity.properties. I set "read" PropertyPermission to allow all web apps to access org.apache.velocity.runtime.defaults.*. This did not work, but I don't know what else to do. For now I have disabled the security manager on tomcat, which resolves the issue, but not in the most desirable way.

Jimmy King on
Sign In or Register to comment.