Package org.apache.tika.parser.html
Class HtmlEncodingDetector
java.lang.Object
org.apache.tika.parser.html.HtmlEncodingDetector
- All Implemented Interfaces:
Serializable,SelfConfiguring,EncodingDetector
Character encoding detector for determining the character encoding of a
HTML document based on the potential charset parameter found in a
Content-Type http-equiv meta tag somewhere near the beginning. Especially
useful for determining the type among multiple closely related encodings
(ISO-8859-*) for which other types of encoding detection are unreliable.
- Since:
- Apache Tika 1.2
- See Also:
-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionstatic classConfiguration class for JSON deserialization. -
Constructor Summary
ConstructorsConstructorDescriptionDefault constructor for SPI loading.HtmlEncodingDetector(JsonConfig jsonConfig) Constructor for JSON configuration.Constructor with explicit Config object. -
Method Summary
Modifier and TypeMethodDescriptiondetect(TikaInputStream tis, Metadata metadata, ParseContext parseContext) Detects the character encoding of the given text document.
-
Constructor Details
-
HtmlEncodingDetector
public HtmlEncodingDetector()Default constructor for SPI loading. -
HtmlEncodingDetector
Constructor with explicit Config object.- Parameters:
config- the configuration
-
HtmlEncodingDetector
Constructor for JSON configuration. Requires Jackson on the classpath.- Parameters:
jsonConfig- JSON configuration
-
-
Method Details
-
detect
public List<EncodingResult> detect(TikaInputStream tis, Metadata metadata, ParseContext parseContext) throws IOException Description copied from interface:EncodingDetectorDetects the character encoding of the given text document.Returns an empty list if the encoding cannot be determined. Returns a ranked list of candidates in descending confidence order otherwise. The first entry is always the best guess.
If the document input stream is not available, then the first argument may be
null. Otherwise the detector may read bytes from the start of the stream to help in encoding detection. The given stream is guaranteed to support themark featureand the detector is expected tomarkthe stream before reading any bytes from it, and toresetthe stream before returning. The stream must not be closed by the detector.The given input metadata is only read, not modified, by the detector.
- Specified by:
detectin interfaceEncodingDetector- Parameters:
tis- text document input stream, ornullmetadata- input metadata for the documentparseContext- the parse context- Returns:
- ranked list of encoding results, empty if unknown; never
null - Throws:
IOException- if the document input stream could not be read
-
getDefaultConfig
-