Converting a Markdown (MD) file to MHTML is a simple two-step process. The first step is to render the MD file to a DOC file using Aspose.PDF for Java. Aspose.PDF for Java is a powerful PDF processing API that is part of the Aspose.Total for Java package. This package contains a wide range of APIs for working with different file formats, including PDF, Word, Excel, and PowerPoint.
Once the MD file has been rendered to a DOC file, the second step is to use Aspose.Words for Java to convert the DOC file to MHTML. Aspose.Words for Java is a powerful document processing API that enables you to easily convert between different file formats. It also provides a range of features for working with documents, such as document manipulation, document comparison, and document conversion.
By using Aspose.PDF for Java and Aspose.Words for Java, you can quickly and easily convert an MD file to MHTML. Both APIs are part of the Aspose.Total for Java package, which provides a comprehensive set of APIs for working with different file formats. With these APIs, you can easily convert MD files to MHTML in just two simple steps.
Java API to Convert MD to MHTML
Conversion Requirements
You can easily use Aspose.Total for Java directly from a Maven based project and include Aspose.PDF for Java and Aspose.Words for Java in your pom.xml.
Alternatively, you can get a ZIP file from downloads .
Open Password Protected MD Document via Java
While converting MD to MHTML, even if your document is password protected, you can still open it using PDF Manipulation API Aspose.PDF for Java . In order to open the encrypted file, you need to create a Document object and open the MD using the owner’s password.
Document document = new Document("input.md", "password");
// save MD as a DOC
document.save("DocOutput.doc", SaveFormat.DOC);
Save MHTML Document to a Database via Java
While saving your input document to MHTML file format, you can also save your document to database instead of a file system. You may need to implement storing and retrieving Document objects to and from a database. This would be necessary if you were implementing any type of content management system. In order to save your MHTML to database it is often necessary to serialize the document to obtain a byte array. This can be done using Aspose.Words for Java API. After getting your byte array, you can store it in the database using SQL statement.
public static void StoreToDatabase(Document doc, Connection mConnection) throws Exception {
// create an output stream which uses byte array to save data
ByteArrayOutputStream aout = new ByteArrayOutputStream();
// save the document to byte array
doc.save(aout, SaveFormat.MHTML);
// get the byte array from output steam
// the byte array now contains the document
byte[] buffer = aout.toByteArray();
// get the filename from the document.
String fileName = doc.getOriginalFileName();
String filePath = fileName.replace("\\", "\\\\");
// create the SQL command.
String commandString = "INSERT INTO Documents (FileName, FileContent) VALUES('" + filePath + "', '" + buffer + "')";
Statement statement = mConnection.createStatement();
statement.executeUpdate(commandString);
}