Question #3: simple work is still tiring
Even a very simple job, such as header and footer, is still very difficult in JSP. Assume that a "header" and a "footer" template are included on all pages, and each template must contain the current page title in the content.
In JSP, the best solution is:
<% String title = "The Page Title"; %>
<% @ Include file = "/header. jsp" %>
... Your page content...
<% @ Include file = "/footer. jsp" %>
The page designer should remember not to omit the semicolon of the first line and define the title as a string. In addition,/header. jsp and/footer. jsp must be in the root directory and must be a complete file that can be accessed.
It is relatively simple to include headers and footers in WebMacro:
# Set $ title = "The Page Title"
# Parse "header. wm"
Your content here
# Parse "footer. wm"
There is no semicolon or title definition to remember for the designer. The. wm file can be placed in a customizable search path.
Question #4: a dry Loop
It is difficult to loop in JSP. The name of each ISP object is repeatedly printed using JSP.
<%
Enumeration e = list. elements ();
While (e. hasMoreElements ()){
Out. print ("The next name is ");
Out. println (ISP) e. nextElement (). getName ());
Out. print ("<br> ");
}
%>
Maybe there will be user-defined tags for these loops. This is also true for "if. JSP pages may seem odd java code. At the same time, the webmacro cycle is very beautiful:
# Foreach $ isp in $ isps {
The next name is $ isp. Name <br>
}
If necessary, the # foreach command can be replaced easily by the custom # foreach-backwards command.
Jsp is likely to change like this: (here is a possible <foreach> MARK)
<Foreach item = "isp" list = "isps">
The next name is <jsp: getProperty name = "isp" property = "name"/> <br>
</Foreach>
The designer will certainly choose the former.
Question #5: useless error messages
JSP often has some surprising error messages. This is because the page is first converted into a servlet before compilation. Good JSP tools can increase the possibility of finding error locations, but even the best tools cannot make all error information easy to understand. Due to the conversion process, some errors may not be identified by tools at all.
For example, assume that the JSP page needs to create a general title for all pages. The following code is correct:
<% Static String title = "Global title"; %>
However, Tomcat provides the following error information:
Work/% 3A8080% 2F/JC_0002ejspJC_jsp_1.java: 70: Statement expected.
Static int count = 0;
^
This information assumes that the above script is put into the _ jspService () method, while static variables are not allowed in the method. This syntax should be <%! %>. It is difficult for page designers to understand the error information. Even the best platform is not doing enough in this regard. Even if all Java code is removed from the page, the problem cannot be solved. What are the following expressions?
<% Count %>
Tomcat provides:
Work/ 8080/_ 0002ftest_0002ejsptest_jsp_0.java: 56: Class count not found in
Type declaration.
Count
^
Work/ 8080/_ 0002ftest_0002ejsptest_jsp_0.java: 59: Invalid declaration.
Out. write ("");
^
In other words, a tag is missing. It should be <% = count %>.
Since the template engine can be directly generated in the template file without any dramatic conversion to the Code, it is very easy to give appropriate error reports. And so on, when the C language command is injected into the Unix shell command line, you do not want the shell to generate a C program to run this command, the shell simply needs to explain the command and execute it. If there is an error, it will be given directly.
Question #6: A compiler is required.
JSP requires a compiler placed in webserver. Sun refused to discard the tools. jar library containing their javac compiler, which became problematic. The Web server can include a third-party compiler such as ibm jikes. However, such compilers cannot work smoothly on all platforms (written in C ++) and are not conducive to the establishment of pure Java web servers. JSP also has a pre-compilation option that can play a certain role, but it is not perfect.
Question #7: waste of space
JSP consumes additional memory and hard disk space. For each 30 k jsp file on the server, a class file larger than 30 K must be generated. In fact, this doubles the hard disk space. Considering that JSP files can easily include a large data file through <% @ include> at any time, such attention is of great practical significance. At the same time, the file data of each JSP class must be loaded into the server's memory, which means that the server's memory must always save the entire JSP document tree. A few JVMs have the ability to remove file-like data from the memory. However, programmers generally cannot control such a rule to redeclare the data, and it may not be very effective for large sites to redeclare the data. No second file is generated for template engines, which saves space. Template engines also provides programmers with full control over the caching of templates in the memory.
There are also some problems with using template engine
Question about Template #1: not strictly defined
How template engine works is not strictly defined. However, this is not very important for jsp. Unlike JSP, template engines has no special requirements on web servers-any server supporting servlet can support template engines (including API 2.0 servers such as Apache/JServ, which do not fully support JSP )! If a healthy competition is provided for the best template engine design, it can lead to a dazzling innovation, especially the promotion of open source code (which can push ideas and promote each other ), so today's WebMacro will be like Perl, without strict definition, but the promotion of open source code organizations is its standard.
Question about Template #2: Not recognized
Template engines is not widely known. JSP has occupied a huge commercial market and is deeply rooted in the hearts of the people. However, using g template engines is only an unknown alternative technology.
Question about Template #3: not ready yet
Template engines has not been highly tuned yet. No performance tests and comparisons were conducted for template engine and JSP. Theoretically, a well-deployed template engine implementation should match a well-deployed JSP. However, considering that the third party has made such a far-reaching push for jsp, as a result, only jsp is well configured.
JSP role
Of course, JSP will certainly have its position. Even from the name, we can see that JSP and ASP are similar, they only have one letter difference. So if we want to turn asp users to java, a very similar jsp environment will play a great role in promoting this, the role of maintaining this relationship with asp should also be taken into account by the designers who launched jsp at that time.
However, it is important to emphasize that it is very different from whether it is the best way to transfer people to the new environment or not.
The development of JSP has increasingly indicated that it is becoming one of the most important java technologies. It leaves people from the ASP world-and Sun will support this powerful commercial case, java-related technical support will also be given greater support.
Unfortunately, this is not the best solution for the java platform. This will make the java solution seem to have no java solution.