The sun-web-proxy-server_4_0.dtd file defines the structure of the server.xml file, including the elements it can contain and the subelements and attributes these elements can have. The sun-web-proxy-server_4_0.dtd file is located in the <Install_Directory>/bin/proxy/dtds directory.
Each element defined in a DTD file (which may be present in the corresponding XML file) can contain the following:
Elements can contain subelements. For example, the following file fragment defines the VSCLASS element:
<!ELEMENT LS (DESCRIPTION?, SSLPARAMS?)>
The ELEMENT tag specifies that a LSCLASS element can contain DESCRIPTION, and SSLPARAMS elements in that order.
The following table shows how optional suffix characters of subelements determine the requirement rules, or number of allowed occurrences, for the subelements.
Table 2–1 Requirement Rules and Subelement Suffixes| Subelement Suffix | Requirement Rule | 
|---|---|
| element* | Can contain zero or more of this subelement | 
| element? | Can contain zero or one of this subelement | 
| element+ | Must contain one or more of this subelement | 
| element (no suffix) | Must contain only one of this subelement | 
If an element cannot contain other elements, you see EMPTY or (#PCDATA) instead of a list of element names in parentheses.
Some elements contain character data instead of subelements. These elements have definitions of the following format:
<!ELEMENT element-name (#PCDATA)>
For example:
<!ELEMENT DESCRIPTION (#PCDATA)>
In the server.xml file, white space is treated as part of the data in a data element. Therefore, no extra white space should appear before or after the data delimited by a data element. For example:
<DESCRIPTION>myserver</DESCRIPTION>
Elements that have ATTLIST tags contain attributes (name-value pairs). For example:
<!ATTLIST ACLFILE
id ID #REQUIRED
file CDATA #REQUIRED
An ACLFILE element can contain id, and file attributes.
The #REQUIRED label means that a value must be supplied. The #IMPLIED label means that the attribute is optional, and that Sun Java System Web Proxy Server generates a default value. Wherever possible, explicit defaults for optional attributes (such as “true”) are listed.
Attribute declarations specify the type of the attribute. For example, CDATA means character data, and %boolean is a predefined enumeration.