Skip to content

Commit

Permalink
Release GroupDocs.Viewer for Java v24.6 (#86)
Browse files Browse the repository at this point in the history
Co-authored-by: aleksey.permyakov <[email protected]>
  • Loading branch information
liosha2007 and oleksii-unnamed committed Jul 8, 2024
1 parent 516bb84 commit b6938f0
Show file tree
Hide file tree
Showing 29 changed files with 594 additions and 3 deletions.
6 changes: 3 additions & 3 deletions java/_index.md
Original file line number Diff line number Diff line change
Expand Up @@ -13,10 +13,10 @@ AddLibInfoScript: True
<img src="" alt="groupdocs-viewer-java-home" align="left" style="width:110px; margin: 0 30px 30px 0"/>

<dt class="flex flex-wrap align-center gdoc-props__meta">
<a href='https://releases.groupdocs.com/java/repo/com/groupdocs/groupdocs-viewer/23.4/' class="release-version-link">
<a href='https://releases.groupdocs.com/java/repo/com/groupdocs/groupdocs-viewer/24.6/' class="release-version-link">
<span class="gdoc-props__tag tip">Latest version
<i class="release-version-number">23.4</i>
<i class="release-version-month">(April 2023)</i>
<i class="release-version-number">24.6</i>
<i class="release-version-month">(June 2024)</i>
</span>
</a>
</dt>
Expand Down
122 changes: 122 additions & 0 deletions java/developer-guide/loading-documents/loading-external-resources.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,122 @@
---
id: loading-external-resources
url: viewer/java/loading-external-resources
title: Loading of external resources containing by a document
weight: 5
keywords: set timeout, Groupdocs.Viewer
description: "This article explains how to manage loading of external resources contained by a document with GroupDocs.Viewer within your Java applications."
productName: GroupDocs.Viewer for Java
hideChildren: False
---

If the document contains external resources, such as images, GroupDocs.Viewer loads them when rendering a document. This allows the document to display correctly, but is a potential security risk.

GroupDocs.Viewer allows you to manage loading of external resources contained by a document. These features are supported for the following formats:
- [Word Processing File Formats](https://docs.fileformat.com/word-processing/)
- [Web File Formats](https://docs.fileformat.com/web/)
- [SpreadSheet File Formats](https://docs.fileformat.com/spreadsheet/)

Use the [LoadOptions](https://reference.groupdocs.com/viewer/java/com.groupdocs.viewer.options/loadoptions/) object to manage loading of external resources.

## Skip loading of external resources

The following code snippet shows how to deny loading of external resources:

{{< tabs "example3">}}
{{< tab "Java" >}}
```java
LoadOptions loadOptions = new LoadOptions();
loadOptions.setSkipExternalResources(true); // Skip loading of external resources

try (Viewer viewer = new Viewer("business-flyer.docx", loadOptions)) {
HtmlViewOptions viewOptions = HtmlViewOptions.forEmbeddedResources();

viewer.view(viewOptions);
}
```
{{< /tab >}}
{{< tab "Kotlin">}}
```kotlin
val loadOptions = LoadOptions()
loadOptions.isSkipExternalResources = true // Skip loading of external resources

Viewer("business-flyer.docx", loadOptions).use { viewer ->
val viewOptions = HtmlViewOptions.forEmbeddedResources()

viewer.view(viewOptions)
}
```
{{< /tab >}}
{{< /tabs >}}

The following images show the output file with and without external resources (see top right corner):

| loadOptions.setSkipExternalResources(false) | loadOptions.setSkipExternalResources(true) |
|-----------------------------------------------------------|-------------------------------------------------------------|
| ![False](/viewer/java/images/with-external-resources.png) | ![True](/viewer/java/images/without-external-resources.png) |

## Manage a safelist for loading external resources

The following code snippet shows how to allow loading of external resources from specific URLs:

{{< tabs "example2">}}
{{< tab "Java" >}}
```java
LoadOptions loadOptions = new LoadOptions();
loadOptions.setSkipExternalResources(true); // Skip loading of all external resources
loadOptions.getWhitelistedResources().add("avatars.githubusercontent.com"); // Enable loading of external resources that has `avatars.githubusercontent.com` fragment in resource URL.

try (Viewer viewer = new Viewer("business-flyer.docx", loadOptions)) {
HtmlViewOptions viewOptions = HtmlViewOptions.forEmbeddedResources();
viewer.view(viewOptions);
}
```
{{< /tab >}}
{{< tab "Kotlin">}}
```kotlin
val loadOptions = LoadOptions()
loadOptions.isSkipExternalResources = true // Skip loading of all external resources
loadOptions.whitelistedResources.add("avatars.githubusercontent.com") // Enable loading of external resources that has `avatars.githubusercontent.com` fragment in resource URL.

val viewer = Viewer("business-flyer.docx", loadOptions)
val viewOptions = HtmlViewOptions.forEmbeddedResources()
viewer.use {
it.view(viewOptions)
}
```
{{< /tab >}}
{{< /tabs >}}

## Set timeout for loading of external resources

The default timeout is 10 seconds. GroupDocs.Viewer allows you to change this value.

The following code snippet shows how to set a timeout to load external resources:

{{< tabs "example1">}}
{{< tab "Java" >}}
```java
// Specify a timeout.
LoadOptions loadOptions = new LoadOptions();
loadOptions.setResourceLoadingTimeout(5000);
// Render a file.
try (Viewer viewer = new Viewer("sample.docx", loadOptions)) {
HtmlViewOptions viewOptions = HtmlViewOptions.forEmbeddedResources();
viewer.view(viewOptions);
}
```
{{< /tab >}}
{{< tab "Kotlin">}}
```kotlin
// Specify a timeout.
val loadOptions = LoadOptions()
loadOptions.setResourceLoadingTimeout(5000)
// Render a file.
Viewer("sample.docx", loadOptions).use { viewer ->
val viewOptions = HtmlViewOptions.forEmbeddedResources()
viewer.view(viewOptions)
}

```
{{< /tab >}}
{{< /tabs >}}
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
---
id: optimization-pdf-options
url: viewer/java/optimization-pdf-options
title: Optimize the output PDF file
linkTitle: Optimize the output PDF file
weight: 6
description: "This topic describes how to optimize PDF file in the GroupDocs.Viewer Java API for web browser or to reduce size."
keywords: convert to pdf, optimize size, optimize browser, optimize web, pdf reduce size
productName: GroupDocs.Viewer for Java
hideChildren: False
toc: True
---
GroupDocs.Viewer allows you to optimize the output PDF file for a web browser or to reduce the file size by optimizing resources.

Optimization for a web allows a browser to display the first pages of a PDF file when you open the document, instead of waiting for the entire file to download.

Resource optimization allows you to reduce the size of the output PDF file. While optimizing, GroupDocs.Viewer may reduce the image size or quality, remove notes or form fields, remove objects, fonts, or personal information from a document, and so on.

You can also optimize an existing PDF file. To do this, open it, specify the optimization parameters, and save the output file.


Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
---
id: optimization-pdf-for-web
url: viewer/java/optimization-pdf-for-web
title: Optimize a PDF file for a browser
linkTitle: Optimize a PDF file for a browser
weight: 1
description: "This topic describes how to optimize PDF file using the GroupDocs.Viewer Java API for web browser or to reduce size."
keywords: convert to pdf, optimize browser, optimize web
productName: GroupDocs.Viewer for Java
hideChildren: False
toc: True
---
This optimization allows a browser to display the first pages of a PDF file when you open the document, instead of waiting for the entire file to download.

The following code snippet shows how to optimize a PDF file for browser:
{{< tabs "Example1">}}
{{< tab "Java" >}}
```java
try (Viewer viewer = new Viewer("sample.docx")) {
PdfViewOptions viewOptions = new PdfViewOptions();
viewOptions.setPdfOptimizationOptions(new PdfOptimizationOptions());
viewOptions.getPdfOptimizationOptions().setLinearize(true);

viewer.view(viewOptions);
}
```
{{</ tab >}}
{{</ tabs >}}


Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
---
id: optimization-pdf-resources
url: viewer/java/optimization-pdf-resources
title: Optimize the PDF file resources
linkTitle: Optimize the PDF file resources
weight: 2
description: "This topic describes how to optimize PDF file using the GroupDocs.Viewer Java API to reduce size."
keywords: convert to pdf, optimize size, pdf reduce size
productName: GroupDocs.Viewer for Java
hideChildren: False
toc: True
---
Resource optimization allows you to reduce the size of the output PDF file. While optimizing, GroupDocs.Viewer may reduce the image size or quality, remove notes or form fields, remove objects, fonts, or personal information from a document, and so on.

The following code snippet shows how to optimize the PDF file by default:

{{< tabs "Example1">}}
{{< tab "Java" >}}
```java
try (Viewer viewer = new Viewer("sample.docx")) {
PdfViewOptions viewOptions = new PdfViewOptions();
viewOptions.setPdfOptimizationOptions(new PdfOptimizationOptions());

viewer.view(viewOptions);
}
```
{{</ tab >}}
{{</ tabs >}}


Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
---
id: optimization-pdf-spreadsheets
url: viewer/java/optimization-pdf-spreadsheets
title: Optimize spreadsheets in a PDF file
linkTitle: Optimize spreadsheets in a PDF file
weight: 3
description: "This topic describes how to optimize spreadsheets in a PDF file using the GroupDocs.Viewer Java API."
keywords: convert to pdf, optimize browser, optimize web
productName: GroupDocs.Viewer for Java
hideChildren: False
toc: True
---
This optimization allows to reduce the output file size by setting up border lines. Besides that, it removes the Arial and Times New Roman characters of 32-127 codes.

The default value is `false`.


The following code snippet shows how to optimize spreadsheets in a PDF file:

{{< tabs "Example1">}}
{{< tab "Java" >}}
```java
try (Viewer viewer = new Viewer("invoice.xlsx")) {
PdfViewOptions viewOptions = new PdfViewOptions();
PdfOptimizationOptions optimizationOptions = new PdfOptimizationOptions();
optimizationOptions.setOptimizeSpreadsheets(true);
viewOptions.setPdfOptimizationOptions(optimizationOptions);
viewer.view(viewOptions);
}
```
{{</ tab >}}
{{</ tabs >}}
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
---
id: optimize-content
url: viewer/java/optimize-content
title: Optimize content
weight: 5
description: "Optimize content of a PDF file using GroupDocs.Viewer for Java"
productName: GroupDocs.Viewer for Java
hideChildren: False
isMenuItemWithNoContent: True
---
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
---
id: optimization-pdf-remove-annotations
url: viewer/java/optimization-pdf-remove-annotations
title: Remove annotations
linkTitle: Remove annotations
weight: 1
description: "This topic describes how to remove annotations from PDF file using the GroupDocs.Viewer Java API."
keywords: convert to pdf, optimize size, pdf reduce size, remove annotations
productName: GroupDocs.Viewer for Java
hideChildren: False
toc: True
---
If the output PDF file contains annotations, you can remove them to reduce the file size.

To remove annotations, set the [setRemoveAnnotations](https://reference.groupdocs.com/viewer/java/com.groupdocs.viewer.options/pdfoptimizationoptions/#setRemoveAnnotations-boolean-) to `true`.

The following code snippet shows how to remove annotations from the file:

{{< tabs "Example1">}}
{{< tab "Java" >}}
```java
try (Viewer viewer = new Viewer("sample.docx")) {
PdfViewOptions viewOptions = new PdfViewOptions();
viewOptions.setPdfOptimizationOptions(new PdfOptimizationOptions());
viewOptions.getPdfOptimizationOptions().setRemoveAnnotations(true);

viewer.view(viewOptions);
}
```
{{</ tab >}}
{{</ tabs >}}

The following image demonstrates the result:

![Remove annotations](/viewer/java/images/pdf-rendering/optimization/optimization-pdf-remove-annotations.png)
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
---
id: optimization-pdf-remove-fields
url: viewer/java/optimization-pdf-remove-fields
title: Remove form fields
linkTitle: Remove form fields
weight: 2
description: "This topic describes how to remove form fields from PDF file using the GroupDocs.Viewer Java API."
keywords: convert to pdf, optimize size, pdf reduce size, remove fields
productName: GroupDocs.Viewer for Java
hideChildren: False
toc: True
---
If the output PDF file contains form fields, you can flatten them to reduce the file size.

To remove form fields, set the `setRemoveFormFields()` property to `true` in [PdfOptimizationOptions](https://reference.groupdocs.com/viewer/java/com.groupdocs.viewer.options/pdfoptimizationoptions/).

The following code snippet shows how to flatten form fields in the file:

{{< tabs "Example1">}}
{{< tab "Java" >}}
```java
try (Viewer viewer = new Viewer("sample.docx")) {
PdfViewOptions viewOptions = new PdfViewOptions();
viewOptions.setPdfOptimizationOptions(new PdfOptimizationOptions());
viewOptions.getPdfOptimizationOptions().setRemoveFormFields(true);

viewer.view(viewOptions);
}
```
{{</ tab >}}
{{</ tabs >}}

The following image demonstrates the result:

![Remove fields](/viewer/java/images/pdf-rendering/optimization/optimization-pdf-remove-fields.png)
Loading

0 comments on commit b6938f0

Please sign in to comment.