Writers, O'Reilly and Associates 2003 This is a follow-up article after the first JSP best practice article, in the article, the author demonstrates how to expand the dynamic content of how to extend JSP technology in the text. The containment function. Understand the difference between static include directives and dynamic JSP: Include elements, find out how to mix the two to obtain optimal performance. In the previous article of the new JSP Best Practice Series, you understand how to use the JSP Include directive to include static contents such as headers, footers, and navigation components to the web page. As with the server side, the JSP Include directive allows a page to extract content or data from another page. Listing 1 Remove the include directive. Listing 1. JSP include directive
This may be a painful thing that is forced to see the browser or clear its cache for the changes to the included files. On the other hand, in order to end the development cycle, it is also a painful thing to completely check the page and modify hundreds of pages that use the include directive. My suggestion is to disable the browser cache during the test. In most cases, doing this can completely solve problems. There is also a very small number of situations, do not work, then you can constantly restart the web container on your browser or server to ensure that the cache is not performed. However, sometimes, the cache will be lost. If the content raised is from the program that uses dynamic data (such as a WebLog or database-driven JSP file), even if the content contained is HTML (such as timestamp), then whenever a web page is loaded, Display the latest version of these files or programs. Unfortunately, the JSP Include directive does not have this feature. In the test and development cycle (see Side Bar "JSP Test and Development"), disable caches in your browser usually solve this problem. However, for applications actually used, performance is an important factor in any design decision process, and disabled caches is not a feasible long-term meter. Better solution is to use JSP: Include tags. JSP: Include Tag JSP: INCLUDE is just a direct order different from the include in Include. The advantage of JSP: Include is that it always checks the changes in the file included. After a while we will study this new marker work. But first take a look at the different code of the INCLUDE, so that you can see the difference between the two. Listing 2 shows a simple page that uses the original JSP include directive. Listing 2. JSP include directive
In fact, the JSP prefix allows the JSP compiler to know: it should look for elements in the standard JSP tag set. Second, specify the properties of the files to be included to become paged from File. If you prefer, you can test the results of the new tag yourself. Simply change the content of the incruded.html file in the previous article (see Resources), then reload the browser page, see new content immediately. FLUSH properties You may have noticed the flush attribute in the JSP: Include Code Example. As the name suggests, Flush indicates whether it is clear any existing buffer before reading the content. The flush attribute is required in JSP 1.1, so if you don't need it in your code, you will get an error. However, in JSP 1.2, the Flush property is default to false. Because it is not an important issue most of the time, my suggestion is: For JSP 1.1, set flush to true; for JSP 1.2 and later, it is set to shut down. JSP: INCLUDE is how to work if you have a little love to the roots, then you may want to know why the JSP: Include tag is different from the include directive. The truth is actually very simple: JSP: Include contains the response included in the included URI, not the URI itself. This means: explains the NRI pointed out, so that the generated response is included. If the page is HTML, it will get HTML that has not changed. However, if it is a Perl script, a Java Servlet, or a CGI program, the result will be the result of the program. Although the page is usually HTML, the actual program happens to achieve the purpose of achieving the purpose. Moreover, since each request page is interpreted, it will never be cached as the use of the include directive. Although this is only a small change, it has led to all the differences in the behavior you have seen. A mixed-matching solution include that there is a place in some websites on some websites. For example, if the site contains some (if there is a change, few) have almost no change, footer, and navigation files, then the basic include directive is the best option for these components. Since the include directive uses a cache, it is only necessary to put into the included file, and its content will be cached, and the result will greatly improve the performance of the site. However, for many web applications or sites, the carpet type cache does not solve the problem. Although the headers and footers may be static, it is not possible that the entire site is static. For example, extracting a navigation link from a database is common, and many JSP-based sites are also extracted from other sites or dynamic JSP pages on other sites or applications. If you are processing dynamic content, you need to use JSP: include to process the content. Of course, the best solution is to mix these two methods to use the use, and each structure is used to use the most appropriate place. Listing 4 is an example of a mixed match containing a solution.

