tencent cloud

Cloud Infinite

Release Notes and Announcements
Release Notes
Announcements
Product Introduction
Product Overview
Product Strengths
Use Cases
Feature Overview
Regions and Domains
Specifications and Limits
Billing
Billing Overview
Billing Mode
Billable Items
Free Tier
Payment Overdue
Viewing Bill Details
FAQs
Getting Started
Registering and Logging In
Bind Bucket
Uploading and Processing File
Downloading and Deleting Images
Unbinding Buckets
Using CI via COS
Features
Image Processing
Media Processing
Content Moderation
AI Content Recognition
File Processing
Smart Voice
File processing
User Guide
Overview
Bucket Management
Smart Toolbox
Job and Workflow
Data Monitoring
Usage statistics
Use Cases
Copyright Protection Solutions
Image Processing Practices
Working with API Authorization Policies
Workflow Practices
API Documentation
API Overview
Structure
Common Request Headers
Common Response Headers
Activate Vast Service
Image Processing
AI-Based Content Recognition
Smart Audio
Media Processing
Content Moderation
Document Processing
File Processing
Job and Workflow
Cloud Virus Detection
Error Codes
Request Signature
SDK Documentation
SDK Overview
Android SDK
iOS SDK
COS Android SDK
C SDK
C++ SDK
.NET(C#) SDK
Go SDK
COS iOS SDK
Java SDK
JavaScript SDK
Node.js SDK
PHP SDK
Python SDK
Mini Program SDK
Personal Information Protection Policy for SDK
Security and Compliance
Permission ‍Management
FAQs
Basic Settings
Document Processing
Media Processing
Content Recognition
Smart Audio
Agreements
Service Level Agreement
Contact Us
Glossary

Document-to-HTML Synchronous Request

PDF
Focus Mode
Font Size
Last updated: 2025-12-26 18:31:06

Description

The document-to-HTML feature supports generating HTML previews for various document types, meeting online requirements for viewing documents across multiple user terminals including PCs and Apps. It is applicable to business scenarios such as online education, enterprise OA, online knowledge bases, and document preview in cloud drives.
Note:
Cloud Infinite encapsulates the JS preview SDK, allowing access to the HTML preview service with just a single URL.
If you need to use it within a mini program, see Mini Program Configuring Business Domain.
To integrate a CDN domain, you need to enable Advanced Cache Expiration Settings in CDN. For details, see the Node Cache Expiration Configuration in CDN documentation.

Authorization Description

When a sub-account is used, you must grant the cos:GetObject and cos:HeadObject permissions in the action of the Authorization Policy. For all APIs supported by COS, see COS action.

Service Activation

To use this feature, you need to bind Bucket in advance and activate the Cloud Infinite service.
To use this feature, you need to activate the document processing service in advance via the console or API.
Note:
After Cloud Infinite is bound, if you manually unbind Cloud Infinite from the Bucket, you will not be able to continue using this feature.

Use Limits

When using this interface, please first confirm the relevant restrictions. For details, see Usage Limits.

Fee Instructions

This is a paid service. Calling this API will incur Document Processing Fees and Traffic Fees, which will be charged by Cloud Infinite.

Request

Request sample

GET /<ObjectKey>?ci-process=doc-preview&dstType=html HTTP/1.1
Host: <BucketName-APPID>.cos.<Region>.myqcloud.com
Date: GMT Date
Authorization: Auth String
Note:
Authorization: A request header that carries authentication information. If your COS file has private read permission, the request can be verified with this header. For details, see Request Signature.

Request header

This API only uses common request headers. For details, see Common Request Headers.

Request Parameter

Name
Description
Type
Required
ObjectKey
Name of the object file, for example folder/document.pdf
String
Yes
ci-process
The processing capability of Cloud Infinite; HTML document preview is fixed as doc-preview.
String
Yes
dstType
Output type of the target file. HTML document preview is fixed as html (must be lowercase).
String
Yes
srcType
Enter the type of the target file. For supported file types and limitations, see below Notes section
String
No
sign
Signature for object download. If the object to be previewed has private read permission, a signature is required. For details, see Request Signature.
Note: URL encoding is required.
String
No
copyable
Whether it can be copied. The default is copyable: <1> indicates copyable; <0> indicates not copyable.
String
No
htmlwaterword
Watermark text requires URL-safe Base64 encoding, default is empty.
String
No
htmlfillstyle
Watermark RGBA (color and transparency) requires URL-safe Base64 encoding. Default: rgba(192,192,192,0.6).
String
No
htmlfront
Style of the watermark text requires URL-safe Base64 encoding, default: bold 20px Serif.
String
No
htmlrotate
Rotation angle of the watermark text, 0 - 360, default 315 degrees
String
No
htmlhorizontal
Horizontal spacing of the watermark text, unit: px, default: 50
String
No
htmlvertical
Vertical spacing of the watermark text, unit: px, default: 100
String
No

Note
:
Currently supported types of input files include the following formats:
Presentation files: pptx, ppt, pot, potx, pps, ppsx, dps, dpt, pptm, potm, ppsm.
Document files: doc, dot, wps, wpt, docx, dotx, docm, dotm.
Spreadsheet files: xls, xlt, et, ett, xlsx, xltx, xlsb, xlsm, xltm, ets.
Other format files: pdf, lrc, c, cpp, h, asm, s, java, asp, bat, bas, prg, cmd, rtf, txt, log, xml, htm, html.
Size of the input file is limited to 200MB.
Input file page count is limited to 5000 pages.
Word documents default to continuous layout on mobile devices and to page layout on PC.

Request body

The request body of this request is empty.

Response

Response Headers

This API only returns common response headers. For details, see Common Response Headers.

Response Body

The response body of this API request contains HTML preview content. For the display effect, see Actual Example.

Error Codes

This request has no unique error messages. For common error messages, see Error Codes.

Practical Case

Case 1: Simple Preview

To preview the PPT file with ObjectKey test.pptx in Bucket examples-1258125638 online, the final URL is as follows:
https://examples-1258125638.cos.ap-guangzhou.myqcloud.com/test.pptx?ci-process=doc-preview&dstType=html
Note:
You can also customize more features through the JS-SDK. For details, see Custom Configuration Overview.
Open the link directly in the browser. The generated preview page is shown in the figure below. For slide documents, you can also perform a full-screen slide show, supporting effects such as animations, triggers, and providing features such as virtual laser pointer, presenter mode.


Case 2: Watermark + Custom Configuration Preview

To preview the PPT file with ObjectKey test.pptx in Bucket examples-1258125638 online.
1. Set non-copyable (copyable = 0).
2. Set test watermark (via URL-safe Base64 encoding resulting in htmlwaterword = dGVzdAog).
3. Set custom configuration parameters (htmlParams is {"mode":"normal","commonOptions":{"isShowHeader":false,"isShowTopArea":true},"pptOptions":{"isSlidesStatusPlay": true}}, encoded via URL-safe Base64 to htmlParams=eyJtb2RlIjoibm9ybWFsIiwiY29tbW9uT3B0aW9ucyI6eyJpc1Nob3dIZWFkZXIiOmZhbHNlLCJpc1Nob3dUb3BBcmVhIjp0cnVlfSwicHB0T3B0aW9ucyI6eyJpc1NsaWRlc1N0YXR1c1BsYXkiOiB0cnVlfX0=).
The final URL is as follows:
https://examples-1258125638.cos.ap-guangzhou.myqcloud.com/test.pptx?ci-process=doc-preview&dstType=html&copyable=0&htmlwaterword=dGVzdAog&htmlParams=eyJtb2RlIjoibm9ybWFsIiwiY29tbW9uT3B0aW9ucyI6eyJpc1Nob3dIZWFkZXIiOmZhbHNlLCJpc1Nob3dUb3BBcmVhIjp0cnVlfSwicHB0T3B0aW9ucyI6eyJpc1NsaWRlc1N0YXR1c1BsYXkiOiB0cnVlfX0=
Open the link directly in the browser. The generated preview page is shown in the figure below. For slide documents, you can also perform a full-screen slide show, supporting effects such as animations, triggers, and providing features such as virtual laser pointer, presenter mode.

The preview link can also be embedded as an iframe in the business page, as shown below:
<!DOCTYPE html>
<html>

<head>
<meta charset="utf-8">
<meta name="viewport"
content="width=device-width, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0,user-scalable=no">
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
<meta http-equiv="Content-Security-Policy" content="upgrade-insecure-requests">
<meta name="keywords" content="COS,document preview">
<meta name="description" content="">
<title>Tencent Cloud - COS - Document Preview</title>
<style>
html,
body {
padding: 0;
margin: 0;
height: 100%;
touch-action: manipulation;
}
</style>
</head>
<body>
<iframe src="https://examples-1258125638.cos.ap-guangzhou.myqcloud.com/test.pptx?ci-process=doc-preview&dstType=html&copyable=0&htmlwaterword=dGVzdAog&htmlParams=eyJtb2RlIjoibm9ybWFsIiwiY29tbW9uT3B0aW9ucyI6eyJpc1Nob3dIZWFkZXIiOmZhbHNlLCJpc1Nob3dUb3BBcmVhIjp0cnVlfSwicHB0T3B0aW9ucyI6eyJpc1NsaWRlc1N0YXR1c1BsYXkiOiB0cnVlfX0=" width="100%" height="100%" allowFullScreen="true"></iframe>
</body>
</html>

Case 3: Switch Preview Language to English

To preview the PPT file with ObjectKey test.pptx in Bucket examples-1258125638 online.
Set the htmlParams parameter (htmlParams is {"commonOptions":{"language": "en"}}, encoded via URL-safe Base64 to htmlParams=eyJjb21tb25PcHRpb25zIjp7Imxhbmd1YWdlIjoiZW4ifX0).
The final URL is as follows:
https://examples-1258125638.cos.ap-guangzhou.myqcloud.com/test.pptx?ci-process=doc-preview&dstType=html&htmlParams=eyJjb21tb25PcHRpb25zIjp7Imxhbmd1YWdlIjoiZW4ifX0


Help and Support

Was this page helpful?

Help us improve! Rate your documentation experience in 5 mins.

Feedback