- Mime type text java
- Method Summary
- Methods inherited from class java.lang.Object
- Constructor Detail
- MimeType
- MimeType
- MimeType
- Method Detail
- getPrimaryType
- setPrimaryType
- getSubType
- setSubType
- getParameters
- getParameter
- setParameter
- removeParameter
- toString
- getBaseType
- match
- match
- writeExternal
- readExternal
- Getting a File’s Mime Type in Java
- 1. Overview
- 2. Using Java 7
- 3. Using URLConnection
- 3.1. Using getContentType()
- 3.2. Using guessContentTypeFromName()
- 3.3. Using getFileNameMap()
- 4. Using MimeTypesFileTypeMap
- 5. Using jMimeMagic
- 6. Using Apache Tika
- 7. Conclusion
Mime type text java
Constructor that builds a MimeType with the given primary and sub type but has an empty parameter list.
Method Summary
Determine if the primary and sub type of this object is the same as the content type described in rawdata.
The object implements the readExternal method to restore its contents by calling the methods of DataInput for primitive types and readObject for objects, strings and arrays.
The object implements the writeExternal method to save its contents by calling the methods of DataOutput for its primitive values or calling the writeObject method of ObjectOutput for objects, strings and arrays.
Methods inherited from class java.lang.Object
Constructor Detail
MimeType
MimeType
public MimeType(String rawdata) throws MimeTypeParseException
MimeType
public MimeType(String primary, String sub) throws MimeTypeParseException
Constructor that builds a MimeType with the given primary and sub type but has an empty parameter list.
Method Detail
getPrimaryType
setPrimaryType
public void setPrimaryType(String primary) throws MimeTypeParseException
getSubType
setSubType
public void setSubType(String sub) throws MimeTypeParseException
getParameters
getParameter
setParameter
removeParameter
toString
getBaseType
match
match
public boolean match(String rawdata) throws MimeTypeParseException
Determine if the primary and sub type of this object is the same as the content type described in rawdata.
writeExternal
The object implements the writeExternal method to save its contents by calling the methods of DataOutput for its primitive values or calling the writeObject method of ObjectOutput for objects, strings and arrays.
readExternal
public void readExternal(ObjectInput in) throws IOException, ClassNotFoundException
The object implements the readExternal method to restore its contents by calling the methods of DataInput for primitive types and readObject for objects, strings and arrays. The readExternal method must read the values in the same sequence and with the same types as were written by writeExternal.
Submit a bug or feature
For further API reference and developer documentation, see Java SE Documentation. That documentation contains more detailed, developer-targeted descriptions, with conceptual overviews, definitions of terms, workarounds, and working code examples.
Copyright © 1993, 2023, Oracle and/or its affiliates. All rights reserved. Use is subject to license terms. Also see the documentation redistribution policy.
Getting a File’s Mime Type in Java
The Kubernetes ecosystem is huge and quite complex, so it’s easy to forget about costs when trying out all of the exciting tools.
To avoid overspending on your Kubernetes cluster, definitely have a look at the free K8s cost monitoring tool from the automation platform CAST AI. You can view your costs in real time, allocate them, calculate burn rates for projects, spot anomalies or spikes, and get insightful reports you can share with your team.
Connect your cluster and start monitoring your K8s costs right away:
We rely on other people’s code in our own work. Every day.
It might be the language you’re writing in, the framework you’re building on, or some esoteric piece of software that does one thing so well you never found the need to implement it yourself.
The problem is, of course, when things fall apart in production — debugging the implementation of a 3rd party library you have no intimate knowledge of is, to say the least, tricky.
Lightrun is a new kind of debugger.
It’s one geared specifically towards real-life production environments. Using Lightrun, you can drill down into running applications, including 3rd party dependencies, with real-time logs, snapshots, and metrics.
Learn more in this quick, 5-minute Lightrun tutorial:
Slow MySQL query performance is all too common. Of course it is. A good way to go is, naturally, a dedicated profiler that actually understands the ins and outs of MySQL.
The Jet Profiler was built for MySQL only, so it can do things like real-time query performance, focus on most used tables or most frequent queries, quickly identify performance issues and basically help you optimize your queries.
Critically, it has very minimal impact on your server’s performance, with most of the profiling work done separately — so it needs no server changes, agents or separate services.
Basically, you install the desktop application, connect to your MySQL server, hit the record button, and you’ll have results within minutes:
DbSchema is a super-flexible database designer, which can take you from designing the DB with your team all the way to safely deploying the schema.
The way it does all of that is by using a design model, a database-independent image of the schema, which can be shared in a team using GIT and compared or deployed on to any database.
And, of course, it can be heavily visual, allowing you to interact with the database using diagrams, visually compose queries, explore the data, generate random data, import data or build HTML5 database reports.
The Kubernetes ecosystem is huge and quite complex, so it’s easy to forget about costs when trying out all of the exciting tools.
To avoid overspending on your Kubernetes cluster, definitely have a look at the free K8s cost monitoring tool from the automation platform CAST AI. You can view your costs in real time, allocate them, calculate burn rates for projects, spot anomalies or spikes, and get insightful reports you can share with your team.
Connect your cluster and start monitoring your K8s costs right away:
We’re looking for a new Java technical editor to help review new articles for the site.
1. Overview
In this tutorial, we’ll take a look at various strategies for getting MIME types of a file. We’ll look at ways to extend the MIME types available to the strategies, wherever applicable.
We’ll also point out where we should favor one strategy over the other.
2. Using Java 7
Let’s start with Java 7 – which provides the method Files.probeContentType(path) for resolving the MIME type:
@Test public void whenUsingJava7_thenSuccess() < Path path = new File("product.png").toPath(); String mimeType = Files.probeContentType(path); assertEquals(mimeType, "image/png"); >
This method makes use of the installed FileTypeDetector implementations to probe the MIME type. It invokes the probeContentType of each implementation to resolve the type.
Now, if the file is recognized by any of the implementations, the content type is returned. However, if that doesn’t happen, a system-default file type detector is invoked.
However, the default implementations are OS specific and might fail depending on the OS that we are using.
In addition to that, it’s also important to note that the strategy will fail if the file isn’t present in the filesystem. Furthermore, if the file doesn’t have an extension, it will result in failure.
3. Using URLConnection
URLConnection provides several APIs for detecting MIME types of a file. Let’s briefly explore each of them.
3.1. Using getContentType()
We can use getContentType() method of URLConnection to retrieve a file’s MIME type:
@Test public void whenUsingGetContentType_thenSuccess()< File file = new File("product.png"); URLConnection connection = file.toURL().openConnection(); String mimeType = connection.getContentType(); assertEquals(mimeType, "image/png"); >
However, a major drawback of this approach is that it’s very slow.
3.2. Using guessContentTypeFromName()
Next, let’s see how we can make use of the guessContentTypeFromName() for the purpose:
@Test public void whenUsingGuessContentTypeFromName_thenSuccess()< File file = new File("product.png"); String mimeType = URLConnection.guessContentTypeFromName(file.getName()); assertEquals(mimeType, "image/png"); >
This method makes use of the internal FileNameMap to resolve the MIME type from the extension.
We also have the option of using guessContentTypeFromStream() instead, which uses the first few characters of the input stream, to determine the type.
3.3. Using getFileNameMap()
A faster way to obtain the MIME type using URLConnection is using the getFileNameMap() method:
@Test public void whenUsingGetFileNameMap_thenSuccess()< File file = new File("product.png"); FileNameMap fileNameMap = URLConnection.getFileNameMap(); String mimeType = fileNameMap.getContentTypeFor(file.getName()); assertEquals(mimeType, "image/png"); >
The method returns the table of MIME types used by all instances of URLConnection. This table is then used to resolve the input file type.
The built-in table of MIME types is very limited when it comes to URLConnection.
By default, the class uses content-types.properties file in JRE_HOME/lib. We can, however, extend it, by specifying a user-specific table using the content.types.user.table property:
System.setProperty("content.types.user.table","");
4. Using MimeTypesFileTypeMap
MimeTypesFileTypeMap resolves MIME types by using file’s extension. This class came with Java 6, and hence comes very handy when we’re working with JDK 1.6.
Now let’s see how to use it:
@Test public void whenUsingMimeTypesFileTypeMap_thenSuccess() < File file = new File("product.png"); MimetypesFileTypeMap fileTypeMap = new MimetypesFileTypeMap(); String mimeType = fileTypeMap.getContentType(file.getName()); assertEquals(mimeType, "image/png"); >
Here, we can either pass the name of the file or the File instance itself as the parameter to the function. However, the function with File instance as the parameter internally calls the overloaded method that accepts the filename as the parameter.
Internally, this method looks up a file called mime.types for the type resolution. It’s very important to note that the method searches for the file in a specific order:
- Programmatically added entries to the MimetypesFileTypeMap instance
- .mime.types in the user’s home directory
- /lib/mime.types
- resources named META-INF/mime.types
- resource named META-INF/mimetypes.default (usually found only in the activation.jar file)
However, if no file is found, it will return application/octet-stream as the response.
5. Using jMimeMagic
jMimeMagic is a restrictively licensed library that we can use to obtain the MIME type of a file.
Let’s start by configuring the Maven dependency:
net.sf.jmimemagic jmimemagic 0.1.5
We can find the latest version of this library on Maven Central.
Next, we’ll explore how to work with the library:
@Test public void whenUsingJmimeMagic_thenSuccess() < File file = new File("product.png"); Magic magic = new Magic(); MagicMatch match = magic.getMagicMatch(file, false); assertEquals(match.getMimeType(), "image/png"); >
This library can work with a stream of data and hence doesn’t require the file to be present in the file system.
6. Using Apache Tika
Apache Tika is a toolset that detects and extracts metadata and text from a variety of files. It has a rich and powerful API and comes with tika-core which we can make use of, for detecting MIME type of a file.
Let’s begin by configuring the Maven dependency:
org.apache.tika tika-core 1.18
Next, we’ll make use of the detect() method to resolve the type:
@Test public void whenUsingTika_thenSuccess() < File file = new File("product.png"); Tika tika = new Tika(); String mimeType = tika.detect(file); assertEquals(mimeType, "image/png"); >
The library relies on magic markers in the stream prefix, for type resolution.
7. Conclusion
In this article, we’ve looked at the various strategies of obtaining the MIME type of a file. Furthermore, we have also analyzed the tradeoffs of the approaches. We have also pointed out the scenarios where we should favor one strategy over the other.
The full source code that is used in this article is available over at GitHub, as always.
Slow MySQL query performance is all too common. Of course it is. A good way to go is, naturally, a dedicated profiler that actually understands the ins and outs of MySQL.
The Jet Profiler was built for MySQL only, so it can do things like real-time query performance, focus on most used tables or most frequent queries, quickly identify performance issues and basically help you optimize your queries.
Critically, it has very minimal impact on your server’s performance, with most of the profiling work done separately — so it needs no server changes, agents or separate services.
Basically, you install the desktop application, connect to your MySQL server, hit the record button, and you’ll have results within minutes: