Merge branch 'eugenp:master' into danielmcnally285_string_to_long

This commit is contained in:
danielmcnally285 2024-01-01 17:39:25 +00:00 committed by GitHub
commit c9c82e9e33
87 changed files with 367 additions and 203 deletions

View File

@ -0,0 +1,49 @@
package com.baeldung.aboutlength;
import static org.junit.jupiter.api.Assertions.assertEquals;
import java.nio.charset.Charset;
import org.junit.jupiter.api.Test;
public class StringLengthAndByteArrayLengthUnitTest {
@Test
void whenStrWithAllAsciiChar_thenStrLengthAndBytesLengthAreEqual() {
String s = "beautiful";
assertEquals(9, s.length());
assertEquals(9, s.getBytes().length);
}
@Test
void whenStrWithUnicodeChar_thenStrLengthAndBytesLengthAreNotEqual() {
assertEquals("f6", Integer.toHexString('ö'));
assertEquals("7f8e", Integer.toHexString('美'));
assertEquals("4e3d", Integer.toHexString('丽'));
String de = "schöne";
assertEquals(6, de.length());
assertEquals(7, de.getBytes().length);
String cn = "美丽";
assertEquals(2, cn.length());
assertEquals(6, cn.getBytes().length);
}
@Test
void whenUsingUTF_32_thenBytesLengthIs4TimesStrLength() {
Charset UTF_32 = Charset.forName("UTF_32");
String en = "beautiful";
assertEquals(9, en.length());
assertEquals(9 * 4, en.getBytes(UTF_32).length);
String de = "schöne";
assertEquals(6, de.length());
assertEquals(6 * 4, de.getBytes(UTF_32).length);
String cn = "美丽";
assertEquals(2, cn.length());
assertEquals(2 * 4, cn.getBytes(UTF_32).length);
}
}

View File

@ -9,9 +9,9 @@
<parent> <parent>
<groupId>com.baeldung</groupId> <groupId>com.baeldung</groupId>
<artifactId>parent-boot-2</artifactId> <artifactId>parent-boot-3</artifactId>
<version>0.0.1-SNAPSHOT</version> <version>0.0.1-SNAPSHOT</version>
<relativePath>../../parent-boot-2</relativePath> <relativePath>../../parent-boot-3</relativePath>
</parent> </parent>
<dependencies> <dependencies>
@ -59,6 +59,8 @@
<properties> <properties>
<faunadb.version>4.2.0</faunadb.version> <faunadb.version>4.2.0</faunadb.version>
<maven.compiler.release>17</maven.compiler.release>
<start-class>com.baeldung.faunablog.FaunaBlogApplication</start-class>
</properties> </properties>
</project> </project>

View File

@ -5,15 +5,17 @@ import com.faunadb.client.FaunaClient;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration; import org.springframework.context.annotation.Configuration;
import org.springframework.security.config.annotation.method.configuration.EnableGlobalMethodSecurity; import org.springframework.security.config.Customizer;
import org.springframework.security.config.annotation.method.configuration.EnableMethodSecurity;
import org.springframework.security.config.annotation.web.builders.HttpSecurity; import org.springframework.security.config.annotation.web.builders.HttpSecurity;
import org.springframework.security.config.annotation.web.configuration.EnableWebSecurity; import org.springframework.security.config.annotation.web.configuration.EnableWebSecurity;
import org.springframework.security.config.annotation.web.configurers.CsrfConfigurer;
import org.springframework.security.core.userdetails.UserDetailsService; import org.springframework.security.core.userdetails.UserDetailsService;
import org.springframework.security.web.SecurityFilterChain; import org.springframework.security.web.SecurityFilterChain;
@Configuration @Configuration
@EnableWebSecurity @EnableWebSecurity
@EnableGlobalMethodSecurity(prePostEnabled = true) @EnableMethodSecurity
public class WebSecurityConfiguration { public class WebSecurityConfiguration {
@Autowired @Autowired
@ -21,13 +23,11 @@ public class WebSecurityConfiguration {
@Bean @Bean
public SecurityFilterChain filterChain(HttpSecurity http) throws Exception { public SecurityFilterChain filterChain(HttpSecurity http) throws Exception {
http.csrf() http.csrf(CsrfConfigurer::disable)
.disable(); .authorizeHttpRequests(requests -> requests
http.authorizeRequests() .requestMatchers("/**")
.antMatchers("/**") .permitAll())
.permitAll() .httpBasic(Customizer.withDefaults());
.and()
.httpBasic();
return http.build(); return http.build();
} }

View File

@ -6,7 +6,6 @@ import org.springframework.http.HttpStatus;
import org.springframework.security.access.prepost.PreAuthorize; import org.springframework.security.access.prepost.PreAuthorize;
import org.springframework.security.core.context.SecurityContextHolder; import org.springframework.security.core.context.SecurityContextHolder;
import org.springframework.web.bind.annotation.*; import org.springframework.web.bind.annotation.*;
import org.springframework.web.server.ResponseStatusException;
import java.util.List; import java.util.List;
import java.util.concurrent.ExecutionException; import java.util.concurrent.ExecutionException;

View File

@ -6,7 +6,6 @@ import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component; import org.springframework.stereotype.Component;
import java.time.Instant; import java.time.Instant;
import java.util.Collection;
import java.util.List; import java.util.List;
import java.util.concurrent.ExecutionException; import java.util.concurrent.ExecutionException;
import java.util.stream.Collectors; import java.util.stream.Collectors;

View File

@ -6,6 +6,8 @@ import org.springframework.security.core.userdetails.User;
import org.springframework.security.core.userdetails.UserDetails; import org.springframework.security.core.userdetails.UserDetails;
import org.springframework.security.core.userdetails.UserDetailsService; import org.springframework.security.core.userdetails.UserDetailsService;
import org.springframework.security.core.userdetails.UsernameNotFoundException; import org.springframework.security.core.userdetails.UsernameNotFoundException;
import org.springframework.security.crypto.factory.PasswordEncoderFactories;
import org.springframework.security.crypto.password.PasswordEncoder;
import java.util.concurrent.ExecutionException; import java.util.concurrent.ExecutionException;
@ -30,8 +32,9 @@ public class FaunaUserDetailsService implements UserDetailsService {
if (userData == null) { if (userData == null) {
throw new UsernameNotFoundException("User not found"); throw new UsernameNotFoundException("User not found");
} }
PasswordEncoder encoder = PasswordEncoderFactories.createDelegatingPasswordEncoder();
return User.withDefaultPasswordEncoder() return User.builder().passwordEncoder(encoder::encode)
.username(userData.at("data", "username").to(String.class).orNull()) .username(userData.at("data", "username").to(String.class).orNull())
.password(userData.at("data", "password").to(String.class).orNull()) .password(userData.at("data", "password").to(String.class).orNull())
.roles("USER") .roles("USER")

View File

@ -11,6 +11,7 @@ import org.hibernate.service.ServiceRegistry;
import com.baeldung.hibernate.exception.persistentobject.entity.Article; import com.baeldung.hibernate.exception.persistentobject.entity.Article;
import com.baeldung.hibernate.exception.persistentobject.entity.Author; import com.baeldung.hibernate.exception.persistentobject.entity.Author;
import com.baeldung.hibernate.exception.persistentobject.entity.Book; import com.baeldung.hibernate.exception.persistentobject.entity.Book;
import com.baeldung.hibernate.namedparameternotbound.Person;
public class HibernateUtil { public class HibernateUtil {
private static SessionFactory sessionFactory; private static SessionFactory sessionFactory;
@ -34,6 +35,7 @@ public class HibernateUtil {
configuration.addAnnotatedClass(Book.class); configuration.addAnnotatedClass(Book.class);
configuration.addAnnotatedClass(Author.class); configuration.addAnnotatedClass(Author.class);
configuration.addAnnotatedClass(Article.class); configuration.addAnnotatedClass(Article.class);
configuration.addAnnotatedClass(Person.class);
ServiceRegistry serviceRegistry = new StandardServiceRegistryBuilder() ServiceRegistry serviceRegistry = new StandardServiceRegistryBuilder()
.applySettings(configuration.getProperties()).build(); .applySettings(configuration.getProperties()).build();

View File

@ -0,0 +1,38 @@
package com.baeldung.hibernate.namedparameternotbound;
import jakarta.persistence.Entity;
import jakarta.persistence.Id;
@Entity
public class Person {
@Id
private int id;
private String firstName;
private String lastName;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getFirstName() {
return firstName;
}
public void setFirstName(String firstName) {
this.firstName = firstName;
}
public String getLastName() {
return lastName;
}
public void setLastName(String lastName) {
this.lastName = lastName;
}
}

View File

@ -0,0 +1,53 @@
package com.baeldung.hibernate.namedparameternotbound;
import static org.junit.jupiter.api.Assertions.assertNotNull;
import static org.junit.jupiter.api.Assertions.assertThrows;
import static org.junit.jupiter.api.Assertions.assertTrue;
import org.hibernate.QueryException;
import org.hibernate.Session;
import org.hibernate.query.Query;
import org.junit.jupiter.api.AfterAll;
import org.junit.jupiter.api.BeforeAll;
import org.junit.jupiter.api.Test;
import com.baeldung.hibernate.exception.persistentobject.HibernateUtil;
class NamedParameterNotBoundExceptionUnitTest {
private static Session session;
@BeforeAll
static void init() {
session = HibernateUtil.getSessionFactory()
.openSession();
session.beginTransaction();
}
@AfterAll
static void clear() {
session.close();
}
@Test
void whenSettingValueToNamedParameter_thenDoNotThrowQueryException() {
Query<Person> query = session.createQuery("FROM Person p WHERE p.firstName = :firstName", Person.class);
query.setParameter("firstName", "Azhrioun");
assertNotNull(query.list());
}
@Test
void whenNotSettingValueToNamedParameter_thenThrowQueryException() {
Exception exception = assertThrows(QueryException.class, () -> {
Query<Person> query = session.createQuery("FROM Person p WHERE p.firstName = :firstName", Person.class);
query.list();
});
String expectedMessage = "Named parameter not bound";
String actualMessage = exception.getMessage();
assertTrue(actualMessage.contains(expectedMessage));
}
}

12
pom.xml
View File

@ -686,7 +686,6 @@
<modules> <modules>
<module>akka-modules</module> <module>akka-modules</module>
<module>algorithms-modules</module> <module>algorithms-modules</module>
<module>antlr</module>
<module>apache-cxf-modules</module> <module>apache-cxf-modules</module>
<module>apache-httpclient-2</module> <module>apache-httpclient-2</module>
<module>apache-httpclient4</module> <module>apache-httpclient4</module>
@ -700,9 +699,7 @@
<module>apache-poi-3</module> <module>apache-poi-3</module>
<module>apache-poi</module> <module>apache-poi</module>
<module>apache-thrift</module> <module>apache-thrift</module>
<module>apache-tika</module>
<module>apache-velocity</module> <module>apache-velocity</module>
<module>asciidoctor</module>
<module>atomix</module> <module>atomix</module>
<module>aws-modules</module> <module>aws-modules</module>
<module>azure</module> <module>azure</module>
@ -813,8 +810,6 @@
<module>osgi</module> <module>osgi</module>
<module>parent-boot-3</module> <module>parent-boot-3</module>
<module>patterns-modules</module> <module>patterns-modules</module>
<module>pdf-2</module>
<module>pdf</module>
<module>performance-tests</module> <module>performance-tests</module>
<module>persistence-modules</module> <module>persistence-modules</module>
<!--<module>persistence-modules/java-harperdb</module>--> <!-- This module requires a library to download manually --> <!--<module>persistence-modules/java-harperdb</module>--> <!-- This module requires a library to download manually -->
@ -896,6 +891,7 @@
<module>tensorflow-java</module> <module>tensorflow-java</module>
<module>testing-modules</module> <module>testing-modules</module>
<module>testing-modules/mockito-simple</module> <module>testing-modules/mockito-simple</module>
<module>text-processing-libraries-modules</module>
<module>timefold-solver</module> <module>timefold-solver</module>
<module>vaadin</module> <module>vaadin</module>
<module>vavr-modules</module> <module>vavr-modules</module>
@ -940,7 +936,6 @@
<modules> <modules>
<module>akka-modules</module> <module>akka-modules</module>
<module>algorithms-modules</module> <module>algorithms-modules</module>
<module>antlr</module>
<module>apache-cxf-modules</module> <module>apache-cxf-modules</module>
<module>apache-httpclient-2</module> <module>apache-httpclient-2</module>
<module>apache-httpclient4</module> <module>apache-httpclient4</module>
@ -954,9 +949,7 @@
<module>apache-poi-3</module> <module>apache-poi-3</module>
<module>apache-poi</module> <module>apache-poi</module>
<module>apache-thrift</module> <module>apache-thrift</module>
<module>apache-tika</module>
<module>apache-velocity</module> <module>apache-velocity</module>
<module>asciidoctor</module>
<module>atomix</module> <module>atomix</module>
<module>aws-modules</module> <module>aws-modules</module>
<module>azure</module> <module>azure</module>
@ -1067,8 +1060,6 @@
<module>osgi</module> <module>osgi</module>
<module>parent-boot-3</module> <module>parent-boot-3</module>
<module>patterns-modules</module> <module>patterns-modules</module>
<module>pdf-2</module>
<module>pdf</module>
<module>performance-tests</module> <module>performance-tests</module>
<module>persistence-modules</module> <module>persistence-modules</module>
<module>persistence-modules/spring-data-neo4j</module> <module>persistence-modules/spring-data-neo4j</module>
@ -1148,6 +1139,7 @@
<module>tensorflow-java</module> <module>tensorflow-java</module>
<module>testing-modules</module> <module>testing-modules</module>
<module>testing-modules/mockito-simple</module> <module>testing-modules/mockito-simple</module>
<module>text-processing-libraries-modules</module>
<module>timefold-solver</module> <module>timefold-solver</module>
<module>vaadin</module> <module>vaadin</module>
<module>vavr-modules</module> <module>vavr-modules</module>

View File

@ -0,0 +1,3 @@
## Text Processing Libraries
This module contains modules about Text Processing Libraries.

View File

@ -8,7 +8,7 @@
<parent> <parent>
<groupId>com.baeldung</groupId> <groupId>com.baeldung</groupId>
<artifactId>parent-modules</artifactId> <artifactId>text-processing-libraries-modules</artifactId>
<version>1.0.0-SNAPSHOT</version> <version>1.0.0-SNAPSHOT</version>
</parent> </parent>

View File

@ -9,7 +9,7 @@
<parent> <parent>
<groupId>com.baeldung</groupId> <groupId>com.baeldung</groupId>
<artifactId>parent-modules</artifactId> <artifactId>text-processing-libraries-modules</artifactId>
<version>1.0.0-SNAPSHOT</version> <version>1.0.0-SNAPSHOT</version>
</parent> </parent>

View File

@ -8,7 +8,7 @@
<parent> <parent>
<groupId>com.baeldung</groupId> <groupId>com.baeldung</groupId>
<artifactId>parent-modules</artifactId> <artifactId>text-processing-libraries-modules</artifactId>
<version>1.0.0-SNAPSHOT</version> <version>1.0.0-SNAPSHOT</version>
</parent> </parent>

View File

@ -9,7 +9,7 @@
<parent> <parent>
<groupId>com.baeldung</groupId> <groupId>com.baeldung</groupId>
<artifactId>parent-modules</artifactId> <artifactId>text-processing-libraries-modules</artifactId>
<version>1.0.0-SNAPSHOT</version> <version>1.0.0-SNAPSHOT</version>
</parent> </parent>

View File

@ -1,43 +1,43 @@
package com.baeldung.pdfedition; package com.baeldung.pdfedition;
import java.io.IOException; import java.io.IOException;
import java.util.Arrays; import java.util.Arrays;
import java.util.List; import java.util.List;
import com.itextpdf.kernel.geom.Rectangle; import com.itextpdf.kernel.geom.Rectangle;
import com.itextpdf.kernel.pdf.PdfDocument; import com.itextpdf.kernel.pdf.PdfDocument;
import com.itextpdf.kernel.pdf.PdfReader; import com.itextpdf.kernel.pdf.PdfReader;
import com.itextpdf.kernel.pdf.PdfWriter; import com.itextpdf.kernel.pdf.PdfWriter;
import com.itextpdf.pdfcleanup.CleanUpProperties; import com.itextpdf.pdfcleanup.CleanUpProperties;
import com.itextpdf.pdfcleanup.PdfCleanUpLocation; import com.itextpdf.pdfcleanup.PdfCleanUpLocation;
import com.itextpdf.pdfcleanup.PdfCleanUpTool; import com.itextpdf.pdfcleanup.PdfCleanUpTool;
import com.itextpdf.pdfcleanup.PdfCleaner; import com.itextpdf.pdfcleanup.PdfCleaner;
import com.itextpdf.pdfcleanup.autosweep.CompositeCleanupStrategy; import com.itextpdf.pdfcleanup.autosweep.CompositeCleanupStrategy;
import com.itextpdf.pdfcleanup.autosweep.RegexBasedCleanupStrategy; import com.itextpdf.pdfcleanup.autosweep.RegexBasedCleanupStrategy;
public class PdfContentRemover { public class PdfContentRemover {
private static final String SOURCE = "src/main/resources/baeldung-modified.pdf"; private static final String SOURCE = "src/main/resources/baeldung-modified.pdf";
private static final String DESTINATION = "src/main/resources/baeldung-cleaned.pdf"; private static final String DESTINATION = "src/main/resources/baeldung-cleaned.pdf";
public static void main(String[] args) throws IOException { public static void main(String[] args) throws IOException {
PdfReader reader = new PdfReader(SOURCE); PdfReader reader = new PdfReader(SOURCE);
PdfWriter writer = new PdfWriter(DESTINATION); PdfWriter writer = new PdfWriter(DESTINATION);
PdfDocument pdfDocument = new PdfDocument(reader, writer); PdfDocument pdfDocument = new PdfDocument(reader, writer);
removeContentFromDocument(pdfDocument); removeContentFromDocument(pdfDocument);
pdfDocument.close(); pdfDocument.close();
} }
private static void removeContentFromDocument(PdfDocument pdfDocument) throws IOException { private static void removeContentFromDocument(PdfDocument pdfDocument) throws IOException {
// 5.1. remove text // 5.1. remove text
CompositeCleanupStrategy strategy = new CompositeCleanupStrategy(); CompositeCleanupStrategy strategy = new CompositeCleanupStrategy();
strategy.add(new RegexBasedCleanupStrategy("Baeldung")); strategy.add(new RegexBasedCleanupStrategy("Baeldung"));
PdfCleaner.autoSweepCleanUp(pdfDocument, strategy); PdfCleaner.autoSweepCleanUp(pdfDocument, strategy);
// 5.2. remove other areas // 5.2. remove other areas
List<PdfCleanUpLocation> cleanUpLocations = Arrays.asList(new PdfCleanUpLocation(1, new Rectangle(10, 50, 90, 70)), new PdfCleanUpLocation(2, new Rectangle(35, 400, 100, 35))); List<PdfCleanUpLocation> cleanUpLocations = Arrays.asList(new PdfCleanUpLocation(1, new Rectangle(10, 50, 90, 70)), new PdfCleanUpLocation(2, new Rectangle(35, 400, 100, 35)));
PdfCleanUpTool cleaner = new PdfCleanUpTool(pdfDocument, cleanUpLocations, new CleanUpProperties()); PdfCleanUpTool cleaner = new PdfCleanUpTool(pdfDocument, cleanUpLocations, new CleanUpProperties());
cleaner.cleanUp(); cleaner.cleanUp();
} }
} }

View File

@ -1,86 +1,86 @@
package com.baeldung.pdfedition; package com.baeldung.pdfedition;
import java.io.IOException; import java.io.IOException;
import java.net.MalformedURLException; import java.net.MalformedURLException;
import com.itextpdf.forms.PdfAcroForm; import com.itextpdf.forms.PdfAcroForm;
import com.itextpdf.forms.fields.PdfFormField; import com.itextpdf.forms.fields.PdfFormField;
import com.itextpdf.forms.fields.PdfTextFormField; import com.itextpdf.forms.fields.PdfTextFormField;
import com.itextpdf.io.image.ImageData; import com.itextpdf.io.image.ImageData;
import com.itextpdf.io.image.ImageDataFactory; import com.itextpdf.io.image.ImageDataFactory;
import com.itextpdf.kernel.geom.Rectangle; import com.itextpdf.kernel.geom.Rectangle;
import com.itextpdf.kernel.pdf.PdfDocument; import com.itextpdf.kernel.pdf.PdfDocument;
import com.itextpdf.kernel.pdf.PdfReader; import com.itextpdf.kernel.pdf.PdfReader;
import com.itextpdf.kernel.pdf.PdfString; import com.itextpdf.kernel.pdf.PdfString;
import com.itextpdf.kernel.pdf.PdfWriter; import com.itextpdf.kernel.pdf.PdfWriter;
import com.itextpdf.kernel.pdf.annot.PdfAnnotation; import com.itextpdf.kernel.pdf.annot.PdfAnnotation;
import com.itextpdf.kernel.pdf.annot.PdfTextAnnotation; import com.itextpdf.kernel.pdf.annot.PdfTextAnnotation;
import com.itextpdf.layout.Document; import com.itextpdf.layout.Document;
import com.itextpdf.layout.element.Image; import com.itextpdf.layout.element.Image;
import com.itextpdf.layout.element.Paragraph; import com.itextpdf.layout.element.Paragraph;
import com.itextpdf.layout.element.Table; import com.itextpdf.layout.element.Table;
import com.itextpdf.layout.element.Text; import com.itextpdf.layout.element.Text;
import com.itextpdf.layout.properties.UnitValue; import com.itextpdf.layout.properties.UnitValue;
public class PdfEditor { public class PdfEditor {
private static final String SOURCE = "src/main/resources/baeldung.pdf"; private static final String SOURCE = "src/main/resources/baeldung.pdf";
private static final String DESTINATION = "src/main/resources/baeldung-modified.pdf"; private static final String DESTINATION = "src/main/resources/baeldung-modified.pdf";
public static void main(String[] args) throws IOException { public static void main(String[] args) throws IOException {
PdfReader reader = new PdfReader(SOURCE); PdfReader reader = new PdfReader(SOURCE);
PdfWriter writer = new PdfWriter(DESTINATION); PdfWriter writer = new PdfWriter(DESTINATION);
PdfDocument pdfDocument = new PdfDocument(reader, writer); PdfDocument pdfDocument = new PdfDocument(reader, writer);
addContentToDocument(pdfDocument); addContentToDocument(pdfDocument);
} }
private static void addContentToDocument(PdfDocument pdfDocument) throws MalformedURLException { private static void addContentToDocument(PdfDocument pdfDocument) throws MalformedURLException {
// 4.1. add form // 4.1. add form
PdfFormField personal = PdfFormField.createEmptyField(pdfDocument); PdfFormField personal = PdfFormField.createEmptyField(pdfDocument);
personal.setFieldName("information"); personal.setFieldName("information");
PdfTextFormField name = PdfFormField.createText(pdfDocument, new Rectangle(35, 400, 100, 30), "name", ""); PdfTextFormField name = PdfFormField.createText(pdfDocument, new Rectangle(35, 400, 100, 30), "name", "");
personal.addKid(name); personal.addKid(name);
PdfAcroForm.getAcroForm(pdfDocument, true) PdfAcroForm.getAcroForm(pdfDocument, true)
.addField(personal, pdfDocument.getFirstPage()); .addField(personal, pdfDocument.getFirstPage());
// 4.2. add new page // 4.2. add new page
pdfDocument.addNewPage(1); pdfDocument.addNewPage(1);
// 4.3. add annotation // 4.3. add annotation
PdfAnnotation ann = new PdfTextAnnotation(new Rectangle(40, 435, 0, 0)).setTitle(new PdfString("name")) PdfAnnotation ann = new PdfTextAnnotation(new Rectangle(40, 435, 0, 0)).setTitle(new PdfString("name"))
.setContents("Your name"); .setContents("Your name");
pdfDocument.getPage(2) pdfDocument.getPage(2)
.addAnnotation(ann); .addAnnotation(ann);
// create document form pdf document // create document form pdf document
Document document = new Document(pdfDocument); Document document = new Document(pdfDocument);
// 4.4. add an image // 4.4. add an image
ImageData imageData = ImageDataFactory.create("src/main/resources/baeldung.png"); ImageData imageData = ImageDataFactory.create("src/main/resources/baeldung.png");
Image image = new Image(imageData).scaleAbsolute(550, 100) Image image = new Image(imageData).scaleAbsolute(550, 100)
.setFixedPosition(1, 10, 50); .setFixedPosition(1, 10, 50);
document.add(image); document.add(image);
// 4.5. add a paragraph // 4.5. add a paragraph
Text title = new Text("This is a demo").setFontSize(16); Text title = new Text("This is a demo").setFontSize(16);
Text author = new Text("Baeldung tutorials."); Text author = new Text("Baeldung tutorials.");
Paragraph p = new Paragraph().setFontSize(8) Paragraph p = new Paragraph().setFontSize(8)
.add(title) .add(title)
.add(" from ") .add(" from ")
.add(author); .add(author);
document.add(p); document.add(p);
// 4.6. add a table // 4.6. add a table
Table table = new Table(UnitValue.createPercentArray(2)); Table table = new Table(UnitValue.createPercentArray(2));
table.addHeaderCell("#"); table.addHeaderCell("#");
table.addHeaderCell("company"); table.addHeaderCell("company");
table.addCell("name"); table.addCell("name");
table.addCell("baeldung"); table.addCell("baeldung");
document.add(table); document.add(table);
// close the document // close the document
// this automatically closes the pdfDocument, which then closes automatically the pdfReader and pdfWriter // this automatically closes the pdfDocument, which then closes automatically the pdfReader and pdfWriter
document.close(); document.close();
} }
} }

View File

@ -1,45 +1,45 @@
package com.baeldung.pdfedition; package com.baeldung.pdfedition;
import java.io.IOException; import java.io.IOException;
import com.itextpdf.kernel.colors.ColorConstants; import com.itextpdf.kernel.colors.ColorConstants;
import com.itextpdf.kernel.pdf.PdfDocument; import com.itextpdf.kernel.pdf.PdfDocument;
import com.itextpdf.kernel.pdf.PdfPage; import com.itextpdf.kernel.pdf.PdfPage;
import com.itextpdf.kernel.pdf.PdfReader; import com.itextpdf.kernel.pdf.PdfReader;
import com.itextpdf.kernel.pdf.PdfWriter; import com.itextpdf.kernel.pdf.PdfWriter;
import com.itextpdf.kernel.pdf.canvas.PdfCanvas; import com.itextpdf.kernel.pdf.canvas.PdfCanvas;
import com.itextpdf.kernel.pdf.canvas.parser.listener.IPdfTextLocation; import com.itextpdf.kernel.pdf.canvas.parser.listener.IPdfTextLocation;
import com.itextpdf.layout.Canvas; import com.itextpdf.layout.Canvas;
import com.itextpdf.layout.element.Paragraph; import com.itextpdf.layout.element.Paragraph;
import com.itextpdf.pdfcleanup.PdfCleaner; import com.itextpdf.pdfcleanup.PdfCleaner;
import com.itextpdf.pdfcleanup.autosweep.CompositeCleanupStrategy; import com.itextpdf.pdfcleanup.autosweep.CompositeCleanupStrategy;
import com.itextpdf.pdfcleanup.autosweep.RegexBasedCleanupStrategy; import com.itextpdf.pdfcleanup.autosweep.RegexBasedCleanupStrategy;
public class PdfTextReplacement { public class PdfTextReplacement {
private static final String SOURCE = "src/main/resources/baeldung-modified.pdf"; private static final String SOURCE = "src/main/resources/baeldung-modified.pdf";
private static final String DESTINATION = "src/main/resources/baeldung-fixed.pdf"; private static final String DESTINATION = "src/main/resources/baeldung-fixed.pdf";
public static void main(String[] args) throws IOException { public static void main(String[] args) throws IOException {
PdfReader reader = new PdfReader(SOURCE); PdfReader reader = new PdfReader(SOURCE);
PdfWriter writer = new PdfWriter(DESTINATION); PdfWriter writer = new PdfWriter(DESTINATION);
PdfDocument pdfDocument = new PdfDocument(reader, writer); PdfDocument pdfDocument = new PdfDocument(reader, writer);
replaceTextContentFromDocument(pdfDocument); replaceTextContentFromDocument(pdfDocument);
pdfDocument.close(); pdfDocument.close();
} }
private static void replaceTextContentFromDocument(PdfDocument pdfDocument) throws IOException { private static void replaceTextContentFromDocument(PdfDocument pdfDocument) throws IOException {
CompositeCleanupStrategy strategy = new CompositeCleanupStrategy(); CompositeCleanupStrategy strategy = new CompositeCleanupStrategy();
strategy.add(new RegexBasedCleanupStrategy("Baeldung tutorials").setRedactionColor(ColorConstants.WHITE)); strategy.add(new RegexBasedCleanupStrategy("Baeldung tutorials").setRedactionColor(ColorConstants.WHITE));
PdfCleaner.autoSweepCleanUp(pdfDocument, strategy); PdfCleaner.autoSweepCleanUp(pdfDocument, strategy);
for (IPdfTextLocation location : strategy.getResultantLocations()) { for (IPdfTextLocation location : strategy.getResultantLocations()) {
PdfPage page = pdfDocument.getPage(location.getPageNumber() + 1); PdfPage page = pdfDocument.getPage(location.getPageNumber() + 1);
PdfCanvas pdfCanvas = new PdfCanvas(page.newContentStreamAfter(), page.getResources(), page.getDocument()); PdfCanvas pdfCanvas = new PdfCanvas(page.newContentStreamAfter(), page.getResources(), page.getDocument());
Canvas canvas = new Canvas(pdfCanvas, location.getRectangle()); Canvas canvas = new Canvas(pdfCanvas, location.getRectangle());
canvas.add(new Paragraph("HIDDEN").setFontSize(8) canvas.add(new Paragraph("HIDDEN").setFontSize(8)
.setMarginTop(0f)); .setMarginTop(0f));
} }
} }
} }

View File

Before

Width:  |  Height:  |  Size: 4.5 KiB

After

Width:  |  Height:  |  Size: 4.5 KiB

View File

@ -9,7 +9,7 @@
<parent> <parent>
<groupId>com.baeldung</groupId> <groupId>com.baeldung</groupId>
<artifactId>parent-modules</artifactId> <artifactId>text-processing-libraries-modules</artifactId>
<version>1.0.0-SNAPSHOT</version> <version>1.0.0-SNAPSHOT</version>
</parent> </parent>

View File

Before

Width:  |  Height:  |  Size: 14 KiB

After

Width:  |  Height:  |  Size: 14 KiB

View File

@ -0,0 +1,24 @@
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<artifactId>text-processing-libraries-modules</artifactId>
<name>text-processing-libraries-modules</name>
<packaging>pom</packaging>
<parent>
<artifactId>parent-modules</artifactId>
<groupId>com.baeldung</groupId>
<version>1.0.0-SNAPSHOT</version>
</parent>
<modules>
<module>antlr</module>
<module>apache-tika</module>
<module>asciidoctor</module>
<module>pdf</module>
<module>pdf-2</module>
</modules>
</project>