Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Failing import in on-the-fly JSP compilation

Tags:

jsp

tomcat

We have a large web app installation, using Apache/Tomcat/Jasper and jboss. In development environment, JSPs are compiled on the fly. Unfortunately, there is one package in particular that the on-the-fly compilation cannot seem to import. For some of the classes, using fully-qualified references rather than imports works, but not for all. All the classes in question are in a single jar (nonEjb.jar). Pre-compiling the JSPs works fine, but it's of course very painful to have to do that every time we need to change one of the affected files. This problem has existed for quite some time, and I'd really like to resolve it as I'm set to do some work in the affected area.

Here is a small test page. It fails for the first import. The two classes being imported are very similar, the only significant difference is their package placement. (And yes, I've verified that the package declarations are correct for both classes.)

<%@ page contentType="text/html; charset=utf-8" %>
<%@ page errorPage="/error.jsp" %>

<%@ page import="com.elementk.lms.product.otr.OtrProviderType" %>
<%@ page import="com.elementk.lms.product.course.CourseType" %>

<html>
<body>
<hr>
Displaying the page...
<br>
<%= OtrProviderType.B24x7_PROVIDER.getId() %> value
<br>
<%= CourseType.SELF_STUDY.getId() %> value
</hr>
</body>
<html>

Result:

09 Mar 2010 21:29:40,555 ERROR [K] [RequestTimingFilter.doFilter:65] Unable to compile class for JSP:

An error occurred at line: 6 in the generated java file
The import com.elementk.lms.product.otr cannot be resolved

I get the same error if I remove the import and fully-qualify the reference (as com.elementk.lms.product.org.OtrProviderType).

What might be causing the JSP compiler to locate one of the classes but not the other?

like image 588
JST Avatar asked Jan 21 '26 17:01

JST


1 Answers

We finally determined why this was happening. Apparently, the on-the-fly compiler doesn't differentiate case, and the package com.elementk.lms.product contains a class named Otr. The compiler couldn't tell the difference between the package "com.elementk.lms.product.otr" and the class "com.elementk.lms.product.Otr". This explains why the error message only cites "com.elementk.lms.product.otr" even when the originating import was "com.elementk.lms.product.otr.OtrProviderType".

We had to repair by essentially avoiding the problem: we renamed the package.

like image 88
JST Avatar answered Jan 23 '26 19:01

JST



Donate For Us

If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!