work on initial state of the spring 5 project
This commit is contained in:
parent
9f10890501
commit
07876a2855
431
spring-5/pom.xml
431
spring-5/pom.xml
|
@ -1,345 +1,108 @@
|
||||||
|
<?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"
|
<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">
|
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>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<groupId>com.baeldung</groupId>
|
|
||||||
<artifactId>spring-5</artifactId>
|
|
||||||
<version>0.1-SNAPSHOT</version>
|
|
||||||
<name>spring-5</name>
|
|
||||||
<packaging>war</packaging>
|
|
||||||
|
|
||||||
<parent>
|
<groupId>com.baeldung</groupId>
|
||||||
<groupId>org.springframework.boot</groupId>
|
<artifactId>spring-5</artifactId>
|
||||||
<artifactId>spring-boot-starter-parent</artifactId>
|
<version>0.0.1-SNAPSHOT</version>
|
||||||
<!-- <version>1.5.1.RELEASE</version> -->
|
<packaging>jar</packaging>
|
||||||
<version>2.0.0.BUILD-SNAPSHOT</version>
|
|
||||||
</parent>
|
|
||||||
|
|
||||||
<dependencies>
|
<name>spring-5</name>
|
||||||
|
<description></description>
|
||||||
|
|
||||||
<!-- Spring Boot Dependencies -->
|
<parent>
|
||||||
|
<groupId>org.springframework.boot</groupId>
|
||||||
|
<artifactId>spring-boot-starter-parent</artifactId>
|
||||||
|
<version>2.0.0.BUILD-SNAPSHOT</version>
|
||||||
|
<relativePath/> <!-- lookup parent from repository -->
|
||||||
|
</parent>
|
||||||
|
|
||||||
<dependency>
|
<properties>
|
||||||
<groupId>org.springframework.boot</groupId>
|
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
|
||||||
<artifactId>spring-boot-starter-thymeleaf</artifactId>
|
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
|
||||||
</dependency>
|
<java.version>1.8</java.version>
|
||||||
<dependency>
|
</properties>
|
||||||
<groupId>org.springframework.boot</groupId>
|
|
||||||
<artifactId>spring-boot-starter-actuator</artifactId>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.springframework.boot</groupId>
|
|
||||||
<artifactId>spring-boot-devtools</artifactId>
|
|
||||||
</dependency>
|
|
||||||
|
|
||||||
<!-- Spring -->
|
<dependencies>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.springframework.boot</groupId>
|
||||||
|
<artifactId>spring-boot-starter-data-jpa</artifactId>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.springframework.boot</groupId>
|
||||||
|
<artifactId>spring-boot-starter-security</artifactId>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.springframework.boot</groupId>
|
||||||
|
<artifactId>spring-boot-starter-validation</artifactId>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.springframework.boot</groupId>
|
||||||
|
<artifactId>spring-boot-starter-web</artifactId>
|
||||||
|
</dependency>
|
||||||
|
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.springframework</groupId>
|
<groupId>org.springframework.boot</groupId>
|
||||||
<artifactId>spring-web</artifactId>
|
<artifactId>spring-boot-devtools</artifactId>
|
||||||
<exclusions>
|
<scope>runtime</scope>
|
||||||
<exclusion>
|
</dependency>
|
||||||
<artifactId>commons-logging</artifactId>
|
<dependency>
|
||||||
<groupId>commons-logging</groupId>
|
<groupId>com.h2database</groupId>
|
||||||
</exclusion>
|
<artifactId>h2</artifactId>
|
||||||
</exclusions>
|
<scope>runtime</scope>
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.springframework</groupId>
|
<groupId>org.springframework.boot</groupId>
|
||||||
<artifactId>spring-webmvc</artifactId>
|
<artifactId>spring-boot-starter-test</artifactId>
|
||||||
</dependency>
|
<scope>test</scope>
|
||||||
<dependency>
|
</dependency>
|
||||||
<groupId>org.springframework</groupId>
|
</dependencies>
|
||||||
<artifactId>spring-oxm</artifactId>
|
|
||||||
</dependency>
|
|
||||||
|
|
||||||
<dependency>
|
<build>
|
||||||
<groupId>commons-fileupload</groupId>
|
<plugins>
|
||||||
<artifactId>commons-fileupload</artifactId>
|
<plugin>
|
||||||
<version>${commons-fileupload.version}</version>
|
<groupId>org.springframework.boot</groupId>
|
||||||
</dependency>
|
<artifactId>spring-boot-maven-plugin</artifactId>
|
||||||
<!-- web -->
|
</plugin>
|
||||||
|
</plugins>
|
||||||
|
</build>
|
||||||
|
|
||||||
<dependency>
|
<repositories>
|
||||||
<groupId>javax.servlet</groupId>
|
<repository>
|
||||||
<artifactId>javax.servlet-api</artifactId>
|
<id>spring-snapshots</id>
|
||||||
<scope>provided</scope>
|
<name>Spring Snapshots</name>
|
||||||
</dependency>
|
<url>https://repo.spring.io/snapshot</url>
|
||||||
|
<snapshots>
|
||||||
<dependency>
|
<enabled>true</enabled>
|
||||||
<groupId>javax.servlet</groupId>
|
</snapshots>
|
||||||
<artifactId>jstl</artifactId>
|
</repository>
|
||||||
<scope>runtime</scope>
|
<repository>
|
||||||
</dependency>
|
<id>spring-milestones</id>
|
||||||
|
<name>Spring Milestones</name>
|
||||||
<!-- marshalling -->
|
<url>https://repo.spring.io/milestone</url>
|
||||||
|
<snapshots>
|
||||||
<dependency>
|
<enabled>false</enabled>
|
||||||
<groupId>com.fasterxml.jackson.core</groupId>
|
</snapshots>
|
||||||
<artifactId>jackson-databind</artifactId>
|
</repository>
|
||||||
</dependency>
|
</repositories>
|
||||||
|
<pluginRepositories>
|
||||||
<dependency>
|
<pluginRepository>
|
||||||
<groupId>com.fasterxml.jackson.dataformat</groupId>
|
<id>spring-snapshots</id>
|
||||||
<artifactId>jackson-dataformat-xml</artifactId>
|
<name>Spring Snapshots</name>
|
||||||
</dependency>
|
<url>https://repo.spring.io/snapshot</url>
|
||||||
|
<snapshots>
|
||||||
<dependency>
|
<enabled>true</enabled>
|
||||||
<groupId>com.thoughtworks.xstream</groupId>
|
</snapshots>
|
||||||
<artifactId>xstream</artifactId>
|
</pluginRepository>
|
||||||
<version>${xstream.version}</version>
|
<pluginRepository>
|
||||||
</dependency>
|
<id>spring-milestones</id>
|
||||||
|
<name>Spring Milestones</name>
|
||||||
<!-- util -->
|
<url>https://repo.spring.io/milestone</url>
|
||||||
|
<snapshots>
|
||||||
<dependency>
|
<enabled>false</enabled>
|
||||||
<groupId>com.google.guava</groupId>
|
</snapshots>
|
||||||
<artifactId>guava</artifactId>
|
</pluginRepository>
|
||||||
<version>${guava.version}</version>
|
</pluginRepositories>
|
||||||
</dependency>
|
|
||||||
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.apache.commons</groupId>
|
|
||||||
<artifactId>commons-lang3</artifactId>
|
|
||||||
<version>${commons-lang3.version}</version>
|
|
||||||
</dependency>
|
|
||||||
|
|
||||||
<!-- logging -->
|
|
||||||
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.slf4j</groupId>
|
|
||||||
<artifactId>slf4j-api</artifactId>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>ch.qos.logback</groupId>
|
|
||||||
<artifactId>logback-classic</artifactId>
|
|
||||||
<!-- <scope>runtime</scope> -->
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.slf4j</groupId>
|
|
||||||
<artifactId>jcl-over-slf4j</artifactId>
|
|
||||||
<!-- <scope>runtime</scope> --> <!-- some spring dependencies need to compile against jcl -->
|
|
||||||
</dependency>
|
|
||||||
<dependency> <!-- needed to bridge to slf4j for projects that use the log4j APIs directly -->
|
|
||||||
<groupId>org.slf4j</groupId>
|
|
||||||
<artifactId>log4j-over-slf4j</artifactId>
|
|
||||||
</dependency>
|
|
||||||
|
|
||||||
<!-- okhttp -->
|
|
||||||
|
|
||||||
<dependency>
|
|
||||||
<groupId>com.squareup.okhttp3</groupId>
|
|
||||||
<artifactId>okhttp</artifactId>
|
|
||||||
<version>${com.squareup.okhttp3.version}</version>
|
|
||||||
</dependency>
|
|
||||||
|
|
||||||
<!-- test scoped -->
|
|
||||||
|
|
||||||
<dependency>
|
|
||||||
<groupId>junit</groupId>
|
|
||||||
<artifactId>junit</artifactId>
|
|
||||||
<scope>test</scope>
|
|
||||||
</dependency>
|
|
||||||
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.hamcrest</groupId>
|
|
||||||
<artifactId>hamcrest-core</artifactId>
|
|
||||||
<scope>test</scope>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.hamcrest</groupId>
|
|
||||||
<artifactId>hamcrest-library</artifactId>
|
|
||||||
<scope>test</scope>
|
|
||||||
</dependency>
|
|
||||||
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.mockito</groupId>
|
|
||||||
<artifactId>mockito-core</artifactId>
|
|
||||||
<scope>test</scope>
|
|
||||||
</dependency>
|
|
||||||
|
|
||||||
<dependency>
|
|
||||||
<groupId>org.springframework</groupId>
|
|
||||||
<artifactId>spring-test</artifactId>
|
|
||||||
</dependency>
|
|
||||||
|
|
||||||
<dependency>
|
|
||||||
<groupId>com.jayway.restassured</groupId>
|
|
||||||
<artifactId>rest-assured</artifactId>
|
|
||||||
<version>${rest-assured.version}</version>
|
|
||||||
</dependency>
|
|
||||||
|
|
||||||
<!-- -->
|
|
||||||
<dependency>
|
|
||||||
<groupId>com.google.protobuf</groupId>
|
|
||||||
<artifactId>protobuf-java</artifactId>
|
|
||||||
<version>${protobuf-java.version}</version>
|
|
||||||
</dependency>
|
|
||||||
<dependency>
|
|
||||||
<groupId>com.googlecode.protobuf-java-format</groupId>
|
|
||||||
<artifactId>protobuf-java-format</artifactId>
|
|
||||||
<version>${protobuf-java-format.version}</version>
|
|
||||||
</dependency>
|
|
||||||
|
|
||||||
<dependency>
|
|
||||||
<groupId>com.esotericsoftware</groupId>
|
|
||||||
<artifactId>kryo</artifactId>
|
|
||||||
<version>${kryo.version}</version>
|
|
||||||
</dependency>
|
|
||||||
</dependencies>
|
|
||||||
|
|
||||||
<build>
|
|
||||||
<finalName>spring-5</finalName>
|
|
||||||
<resources>
|
|
||||||
<resource>
|
|
||||||
<directory>src/main/resources</directory>
|
|
||||||
<filtering>true</filtering>
|
|
||||||
</resource>
|
|
||||||
</resources>
|
|
||||||
|
|
||||||
<plugins>
|
|
||||||
|
|
||||||
<plugin>
|
|
||||||
<groupId>org.apache.maven.plugins</groupId>
|
|
||||||
<artifactId>maven-compiler-plugin</artifactId>
|
|
||||||
<configuration>
|
|
||||||
<source>1.8</source>
|
|
||||||
<target>1.8</target>
|
|
||||||
</configuration>
|
|
||||||
</plugin>
|
|
||||||
|
|
||||||
<plugin>
|
|
||||||
<groupId>org.apache.maven.plugins</groupId>
|
|
||||||
<artifactId>maven-war-plugin</artifactId>
|
|
||||||
</plugin>
|
|
||||||
|
|
||||||
<plugin>
|
|
||||||
<groupId>org.apache.maven.plugins</groupId>
|
|
||||||
<artifactId>maven-surefire-plugin</artifactId>
|
|
||||||
<configuration>
|
|
||||||
<excludes>
|
|
||||||
<exclude>**/*IntegrationTest.java</exclude>
|
|
||||||
<exclude>**/*LiveTest.java</exclude>
|
|
||||||
</excludes>
|
|
||||||
<systemPropertyVariables>
|
|
||||||
<!-- <provPersistenceTarget>h2</provPersistenceTarget> -->
|
|
||||||
</systemPropertyVariables>
|
|
||||||
</configuration>
|
|
||||||
</plugin>
|
|
||||||
|
|
||||||
<plugin>
|
|
||||||
<groupId>org.codehaus.cargo</groupId>
|
|
||||||
<artifactId>cargo-maven2-plugin</artifactId>
|
|
||||||
<version>${cargo-maven2-plugin.version}</version>
|
|
||||||
<configuration>
|
|
||||||
<wait>true</wait>
|
|
||||||
<container>
|
|
||||||
<containerId>tomcat8x</containerId>
|
|
||||||
<type>embedded</type>
|
|
||||||
<systemProperties>
|
|
||||||
<!-- <provPersistenceTarget>cargo</provPersistenceTarget> -->
|
|
||||||
</systemProperties>
|
|
||||||
</container>
|
|
||||||
<configuration>
|
|
||||||
<properties>
|
|
||||||
<cargo.servlet.port>8082</cargo.servlet.port>
|
|
||||||
</properties>
|
|
||||||
</configuration>
|
|
||||||
</configuration>
|
|
||||||
</plugin>
|
|
||||||
|
|
||||||
</plugins>
|
|
||||||
|
|
||||||
</build>
|
|
||||||
|
|
||||||
<profiles>
|
|
||||||
|
|
||||||
<profile>
|
|
||||||
<id>integration</id>
|
|
||||||
<build>
|
|
||||||
<plugins>
|
|
||||||
<plugin>
|
|
||||||
<groupId>org.apache.maven.plugins</groupId>
|
|
||||||
<artifactId>maven-surefire-plugin</artifactId>
|
|
||||||
<executions>
|
|
||||||
<execution>
|
|
||||||
<phase>integration-test</phase>
|
|
||||||
<goals>
|
|
||||||
<goal>test</goal>
|
|
||||||
</goals>
|
|
||||||
<configuration>
|
|
||||||
<excludes>
|
|
||||||
<exclude>none</exclude>
|
|
||||||
</excludes>
|
|
||||||
<includes>
|
|
||||||
<include>**/*IntegrationTest.java</include>
|
|
||||||
</includes>
|
|
||||||
</configuration>
|
|
||||||
</execution>
|
|
||||||
</executions>
|
|
||||||
</plugin>
|
|
||||||
|
|
||||||
</plugins>
|
|
||||||
</build>
|
|
||||||
</profile>
|
|
||||||
|
|
||||||
</profiles>
|
|
||||||
|
|
||||||
<properties>
|
|
||||||
<commons-fileupload.version>1.3.2</commons-fileupload.version>
|
|
||||||
<kryo.version>4.0.0</kryo.version>
|
|
||||||
<protobuf-java-format.version>1.4</protobuf-java-format.version>
|
|
||||||
<protobuf-java.version>3.1.0</protobuf-java.version>
|
|
||||||
<commons-lang3.version>3.5</commons-lang3.version>
|
|
||||||
<xstream.version>1.4.9</xstream.version>
|
|
||||||
|
|
||||||
<!-- util -->
|
|
||||||
<guava.version>20.0</guava.version>
|
|
||||||
<rest-assured.version>2.9.0</rest-assured.version>
|
|
||||||
|
|
||||||
<!-- Maven plugins -->
|
|
||||||
<cargo-maven2-plugin.version>1.6.0</cargo-maven2-plugin.version>
|
|
||||||
<findbugs-maven-plugin.version>3.0.4</findbugs-maven-plugin.version>
|
|
||||||
|
|
||||||
<!-- okhttp -->
|
|
||||||
<com.squareup.okhttp3.version>3.4.1</com.squareup.okhttp3.version>
|
|
||||||
|
|
||||||
</properties>
|
|
||||||
|
|
||||||
<repositories>
|
|
||||||
<repository>
|
|
||||||
<id>spring-snapshots</id>
|
|
||||||
<name>Spring Snapshots</name>
|
|
||||||
<url>https://repo.spring.io/snapshot</url>
|
|
||||||
<snapshots>
|
|
||||||
<enabled>true</enabled>
|
|
||||||
</snapshots>
|
|
||||||
</repository>
|
|
||||||
<repository>
|
|
||||||
<id>spring-milestones</id>
|
|
||||||
<name>Spring Milestones</name>
|
|
||||||
<url>https://repo.spring.io/milestone</url>
|
|
||||||
<snapshots>
|
|
||||||
<enabled>false</enabled>
|
|
||||||
</snapshots>
|
|
||||||
</repository>
|
|
||||||
</repositories>
|
|
||||||
<pluginRepositories>
|
|
||||||
<pluginRepository>
|
|
||||||
<id>spring-snapshots</id>
|
|
||||||
<name>Spring Snapshots</name>
|
|
||||||
<url>https://repo.spring.io/snapshot</url>
|
|
||||||
<snapshots>
|
|
||||||
<enabled>true</enabled>
|
|
||||||
</snapshots>
|
|
||||||
</pluginRepository>
|
|
||||||
<pluginRepository>
|
|
||||||
<id>spring-milestones</id>
|
|
||||||
<name>Spring Milestones</name>
|
|
||||||
<url>https://repo.spring.io/milestone</url>
|
|
||||||
<snapshots>
|
|
||||||
<enabled>false</enabled>
|
|
||||||
</snapshots>
|
|
||||||
</pluginRepository>
|
|
||||||
</pluginRepositories>
|
|
||||||
|
|
||||||
</project>
|
</project>
|
||||||
|
|
|
@ -0,0 +1,12 @@
|
||||||
|
package com.baeldung;
|
||||||
|
|
||||||
|
import org.springframework.boot.SpringApplication;
|
||||||
|
import org.springframework.boot.autoconfigure.SpringBootApplication;
|
||||||
|
|
||||||
|
@SpringBootApplication
|
||||||
|
public class Spring5Application {
|
||||||
|
|
||||||
|
public static void main(String[] args) {
|
||||||
|
SpringApplication.run(Spring5Application.class, args);
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,16 +0,0 @@
|
||||||
package org.baeldung.config;
|
|
||||||
|
|
||||||
import org.springframework.boot.SpringApplication;
|
|
||||||
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
|
|
||||||
import org.springframework.context.annotation.ComponentScan;
|
|
||||||
import org.springframework.web.servlet.config.annotation.WebMvcConfigurerAdapter;
|
|
||||||
|
|
||||||
@EnableAutoConfiguration
|
|
||||||
@ComponentScan("org.baeldung")
|
|
||||||
public class Application extends WebMvcConfigurerAdapter {
|
|
||||||
|
|
||||||
public static void main(final String[] args) {
|
|
||||||
SpringApplication.run(Application.class, args);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
|
@ -1,57 +0,0 @@
|
||||||
package org.baeldung.config;
|
|
||||||
|
|
||||||
import org.baeldung.config.converter.KryoHttpMessageConverter;
|
|
||||||
import org.springframework.context.annotation.ComponentScan;
|
|
||||||
import org.springframework.context.annotation.Configuration;
|
|
||||||
import org.springframework.http.converter.HttpMessageConverter;
|
|
||||||
import org.springframework.http.converter.json.Jackson2ObjectMapperBuilder;
|
|
||||||
import org.springframework.http.converter.json.MappingJackson2HttpMessageConverter;
|
|
||||||
import org.springframework.http.converter.protobuf.ProtobufHttpMessageConverter;
|
|
||||||
import org.springframework.http.converter.xml.MarshallingHttpMessageConverter;
|
|
||||||
import org.springframework.oxm.xstream.XStreamMarshaller;
|
|
||||||
import org.springframework.web.servlet.config.annotation.EnableWebMvc;
|
|
||||||
import org.springframework.web.servlet.config.annotation.WebMvcConfigurerAdapter;
|
|
||||||
|
|
||||||
import java.text.SimpleDateFormat;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Please note that main web configuration is in src/main/webapp/WEB-INF/api-servlet.xml
|
|
||||||
*/
|
|
||||||
@Configuration
|
|
||||||
@EnableWebMvc
|
|
||||||
@ComponentScan({ "org.baeldung.web" })
|
|
||||||
public class WebConfig extends WebMvcConfigurerAdapter {
|
|
||||||
|
|
||||||
public WebConfig() {
|
|
||||||
super();
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void configureMessageConverters(final List<HttpMessageConverter<?>> messageConverters) {
|
|
||||||
final Jackson2ObjectMapperBuilder builder = new Jackson2ObjectMapperBuilder();
|
|
||||||
builder.indentOutput(true).dateFormat(new SimpleDateFormat("dd-MM-yyyy hh:mm"));
|
|
||||||
messageConverters.add(new MappingJackson2HttpMessageConverter(builder.build()));
|
|
||||||
// messageConverters.add(new MappingJackson2XmlHttpMessageConverter(builder.createXmlMapper(true).build()));
|
|
||||||
|
|
||||||
// messageConverters.add(createXmlHttpMessageConverter());
|
|
||||||
// messageConverters.add(new MappingJackson2HttpMessageConverter());
|
|
||||||
|
|
||||||
messageConverters.add(new ProtobufHttpMessageConverter());
|
|
||||||
messageConverters.add(new KryoHttpMessageConverter());
|
|
||||||
super.configureMessageConverters(messageConverters);
|
|
||||||
}
|
|
||||||
|
|
||||||
private HttpMessageConverter<Object> createXmlHttpMessageConverter() {
|
|
||||||
final MarshallingHttpMessageConverter xmlConverter = new MarshallingHttpMessageConverter();
|
|
||||||
|
|
||||||
final XStreamMarshaller xstreamMarshaller = new XStreamMarshaller();
|
|
||||||
xmlConverter.setMarshaller(xstreamMarshaller);
|
|
||||||
xmlConverter.setUnmarshaller(xstreamMarshaller);
|
|
||||||
|
|
||||||
return xmlConverter;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
|
@ -1,57 +0,0 @@
|
||||||
package org.baeldung.config.converter;
|
|
||||||
|
|
||||||
import java.io.IOException;
|
|
||||||
|
|
||||||
import org.baeldung.web.dto.Foo;
|
|
||||||
import org.springframework.http.HttpInputMessage;
|
|
||||||
import org.springframework.http.HttpOutputMessage;
|
|
||||||
import org.springframework.http.MediaType;
|
|
||||||
import org.springframework.http.converter.AbstractHttpMessageConverter;
|
|
||||||
|
|
||||||
import com.esotericsoftware.kryo.Kryo;
|
|
||||||
import com.esotericsoftware.kryo.io.Input;
|
|
||||||
import com.esotericsoftware.kryo.io.Output;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* An {@code HttpMessageConverter} that can read and write Kryo messages.
|
|
||||||
*/
|
|
||||||
public class KryoHttpMessageConverter extends AbstractHttpMessageConverter<Object> {
|
|
||||||
|
|
||||||
public static final MediaType KRYO = new MediaType("application", "x-kryo");
|
|
||||||
|
|
||||||
private static final ThreadLocal<Kryo> kryoThreadLocal = new ThreadLocal<Kryo>() {
|
|
||||||
@Override
|
|
||||||
protected Kryo initialValue() {
|
|
||||||
final Kryo kryo = new Kryo();
|
|
||||||
kryo.register(Foo.class, 1);
|
|
||||||
return kryo;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
public KryoHttpMessageConverter() {
|
|
||||||
super(KRYO);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected boolean supports(final Class<?> clazz) {
|
|
||||||
return Object.class.isAssignableFrom(clazz);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected Object readInternal(final Class<? extends Object> clazz, final HttpInputMessage inputMessage) throws IOException {
|
|
||||||
final Input input = new Input(inputMessage.getBody());
|
|
||||||
return kryoThreadLocal.get().readClassAndObject(input);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected void writeInternal(final Object object, final HttpOutputMessage outputMessage) throws IOException {
|
|
||||||
final Output output = new Output(outputMessage.getBody());
|
|
||||||
kryoThreadLocal.get().writeClassAndObject(output, object);
|
|
||||||
output.flush();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected MediaType getDefaultContentType(final Object object) {
|
|
||||||
return KRYO;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,47 +0,0 @@
|
||||||
package org.baeldung.web.controller;
|
|
||||||
|
|
||||||
import org.springframework.stereotype.Controller;
|
|
||||||
import org.springframework.web.bind.annotation.PathVariable;
|
|
||||||
import org.springframework.web.bind.annotation.RequestMapping;
|
|
||||||
import org.springframework.web.bind.annotation.RequestParam;
|
|
||||||
import org.springframework.web.bind.annotation.ResponseBody;
|
|
||||||
|
|
||||||
@Controller
|
|
||||||
@RequestMapping(value = "/ex")
|
|
||||||
public class BarMappingExamplesController {
|
|
||||||
|
|
||||||
public BarMappingExamplesController() {
|
|
||||||
super();
|
|
||||||
}
|
|
||||||
|
|
||||||
// API
|
|
||||||
|
|
||||||
// with @RequestParam
|
|
||||||
|
|
||||||
@RequestMapping(value = "/bars")
|
|
||||||
@ResponseBody
|
|
||||||
public String getBarBySimplePathWithRequestParam(@RequestParam("id") final long id) {
|
|
||||||
return "Get a specific Bar with id=" + id;
|
|
||||||
}
|
|
||||||
|
|
||||||
@RequestMapping(value = "/bars", params = "id")
|
|
||||||
@ResponseBody
|
|
||||||
public String getBarBySimplePathWithExplicitRequestParam(@RequestParam("id") final long id) {
|
|
||||||
return "Get a specific Bar with id=" + id;
|
|
||||||
}
|
|
||||||
|
|
||||||
@RequestMapping(value = "/bars", params = { "id", "second" })
|
|
||||||
@ResponseBody
|
|
||||||
public String getBarBySimplePathWithExplicitRequestParams(@RequestParam("id") final long id) {
|
|
||||||
return "Get a specific Bar with id=" + id;
|
|
||||||
}
|
|
||||||
|
|
||||||
// with @PathVariable
|
|
||||||
|
|
||||||
@RequestMapping(value = "/bars/{numericId:[\\d]+}")
|
|
||||||
@ResponseBody
|
|
||||||
public String getBarsBySimplePathWithPathVariable(@PathVariable final long numericId) {
|
|
||||||
return "Get a specific Bar with id=" + numericId;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
|
@ -1,16 +0,0 @@
|
||||||
package org.baeldung.web.controller;
|
|
||||||
|
|
||||||
import org.baeldung.web.dto.Company;
|
|
||||||
import org.springframework.http.MediaType;
|
|
||||||
import org.springframework.web.bind.annotation.RequestMapping;
|
|
||||||
import org.springframework.web.bind.annotation.RestController;
|
|
||||||
|
|
||||||
@RestController
|
|
||||||
public class CompanyController {
|
|
||||||
|
|
||||||
@RequestMapping(value = "/companyRest", produces = MediaType.APPLICATION_JSON_VALUE)
|
|
||||||
public Company getCompanyRest() {
|
|
||||||
final Company company = new Company(1, "Xpto");
|
|
||||||
return company;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,45 +0,0 @@
|
||||||
package org.baeldung.web.controller;
|
|
||||||
|
|
||||||
import static org.apache.commons.lang3.RandomStringUtils.randomAlphabetic;
|
|
||||||
|
|
||||||
import org.baeldung.web.dto.Foo;
|
|
||||||
import org.baeldung.web.dto.FooProtos;
|
|
||||||
import org.springframework.http.HttpStatus;
|
|
||||||
import org.springframework.stereotype.Controller;
|
|
||||||
import org.springframework.web.bind.annotation.PathVariable;
|
|
||||||
import org.springframework.web.bind.annotation.RequestBody;
|
|
||||||
import org.springframework.web.bind.annotation.RequestMapping;
|
|
||||||
import org.springframework.web.bind.annotation.RequestMethod;
|
|
||||||
import org.springframework.web.bind.annotation.ResponseBody;
|
|
||||||
import org.springframework.web.bind.annotation.ResponseStatus;
|
|
||||||
|
|
||||||
@Controller
|
|
||||||
public class FooController {
|
|
||||||
|
|
||||||
public FooController() {
|
|
||||||
super();
|
|
||||||
}
|
|
||||||
|
|
||||||
// API - read
|
|
||||||
|
|
||||||
@RequestMapping(method = RequestMethod.GET, value = "/foos/{id}")
|
|
||||||
@ResponseBody
|
|
||||||
public Foo findById(@PathVariable final long id) {
|
|
||||||
return new Foo(id, randomAlphabetic(4));
|
|
||||||
}
|
|
||||||
|
|
||||||
// API - write
|
|
||||||
|
|
||||||
@RequestMapping(method = RequestMethod.PUT, value = "/foos/{id}")
|
|
||||||
@ResponseStatus(HttpStatus.OK)
|
|
||||||
@ResponseBody
|
|
||||||
public Foo updateFoo(@PathVariable("id") final String id, @RequestBody final Foo foo) {
|
|
||||||
return foo;
|
|
||||||
}
|
|
||||||
|
|
||||||
@RequestMapping(method = RequestMethod.GET, value = "/foos/{id}", produces = { "application/x-protobuf" })
|
|
||||||
@ResponseBody
|
|
||||||
public FooProtos.Foo findProtoById(@PathVariable final long id) {
|
|
||||||
return FooProtos.Foo.newBuilder().setId(1).setName("Foo Name").build();
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,101 +0,0 @@
|
||||||
package org.baeldung.web.controller;
|
|
||||||
|
|
||||||
import org.springframework.stereotype.Controller;
|
|
||||||
import org.springframework.web.bind.annotation.PathVariable;
|
|
||||||
import org.springframework.web.bind.annotation.RequestMapping;
|
|
||||||
import org.springframework.web.bind.annotation.RequestMethod;
|
|
||||||
import org.springframework.web.bind.annotation.ResponseBody;
|
|
||||||
|
|
||||||
@Controller
|
|
||||||
@RequestMapping(value = "/ex")
|
|
||||||
public class FooMappingExamplesController {
|
|
||||||
|
|
||||||
public FooMappingExamplesController() {
|
|
||||||
super();
|
|
||||||
}
|
|
||||||
|
|
||||||
// API
|
|
||||||
|
|
||||||
// mapping examples
|
|
||||||
|
|
||||||
@RequestMapping(value = "/foos")
|
|
||||||
@ResponseBody
|
|
||||||
public String getFoosBySimplePath() {
|
|
||||||
return "Simple Get some Foos";
|
|
||||||
}
|
|
||||||
|
|
||||||
// with @PathVariable
|
|
||||||
|
|
||||||
@RequestMapping(value = "/foos/{id}")
|
|
||||||
@ResponseBody
|
|
||||||
public String getFoosBySimplePathWithPathVariable(@PathVariable final long id) {
|
|
||||||
return "Get a specific Foo with id=" + id;
|
|
||||||
}
|
|
||||||
|
|
||||||
@RequestMapping(value = "/foos/{fooid}/bar/{barid}")
|
|
||||||
@ResponseBody
|
|
||||||
public String getFoosBySimplePathWithPathVariables(@PathVariable final long fooid, @PathVariable final long barid) {
|
|
||||||
return "Get a specific Bar with id=" + barid + " from a Foo with id=" + fooid;
|
|
||||||
}
|
|
||||||
|
|
||||||
// other HTTP verbs
|
|
||||||
|
|
||||||
@RequestMapping(value = "/foos", method = RequestMethod.POST)
|
|
||||||
@ResponseBody
|
|
||||||
public String postFoos() {
|
|
||||||
return "Post some Foos";
|
|
||||||
}
|
|
||||||
|
|
||||||
// with headers
|
|
||||||
|
|
||||||
@RequestMapping(value = "/foos", headers = "key=val")
|
|
||||||
@ResponseBody
|
|
||||||
public String getFoosWithHeader() {
|
|
||||||
return "Get some Foos with Header";
|
|
||||||
}
|
|
||||||
|
|
||||||
@RequestMapping(value = "/foos", headers = { "key1=val1", "key2=val2" })
|
|
||||||
@ResponseBody
|
|
||||||
public String getFoosWithHeaders() {
|
|
||||||
return "Get some Foos with Header";
|
|
||||||
}
|
|
||||||
|
|
||||||
// @RequestMapping(value = "/foos", method = RequestMethod.GET, headers = "Accept=application/json")
|
|
||||||
// @ResponseBody
|
|
||||||
// public String getFoosAsJsonFromBrowser() {
|
|
||||||
// return "Get some Foos with Header Old";
|
|
||||||
// }
|
|
||||||
|
|
||||||
@RequestMapping(value = "/foos", produces = { "application/json", "application/xml" })
|
|
||||||
@ResponseBody
|
|
||||||
public String getFoosAsJsonFromREST() {
|
|
||||||
return "Get some Foos with Header New";
|
|
||||||
}
|
|
||||||
|
|
||||||
// advanced - multiple mappings
|
|
||||||
|
|
||||||
@RequestMapping(value = { "/advanced/bars", "/advanced/foos" })
|
|
||||||
@ResponseBody
|
|
||||||
public String getFoosOrBarsByPath() {
|
|
||||||
return "Advanced - Get some Foos or Bars";
|
|
||||||
}
|
|
||||||
|
|
||||||
@RequestMapping(value = "*")
|
|
||||||
@ResponseBody
|
|
||||||
public String getFallback() {
|
|
||||||
return "Fallback for GET Requests";
|
|
||||||
}
|
|
||||||
|
|
||||||
@RequestMapping(value = "*", method = { RequestMethod.GET, RequestMethod.POST })
|
|
||||||
@ResponseBody
|
|
||||||
public String allFallback() {
|
|
||||||
return "Fallback for All Requests";
|
|
||||||
}
|
|
||||||
|
|
||||||
@RequestMapping(value = "/foos/multiple", method = { RequestMethod.PUT, RequestMethod.POST })
|
|
||||||
@ResponseBody
|
|
||||||
public String putAndPostFoos() {
|
|
||||||
return "Advanced - PUT and POST within single method";
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
|
@ -1,39 +0,0 @@
|
||||||
package org.baeldung.web.controller;
|
|
||||||
|
|
||||||
import java.util.Date;
|
|
||||||
|
|
||||||
import org.baeldung.web.dto.Item;
|
|
||||||
import org.baeldung.web.dto.ItemManager;
|
|
||||||
import org.baeldung.web.dto.Views;
|
|
||||||
import org.springframework.web.bind.annotation.PathVariable;
|
|
||||||
import org.springframework.web.bind.annotation.RequestMapping;
|
|
||||||
import org.springframework.web.bind.annotation.RestController;
|
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonView;
|
|
||||||
|
|
||||||
@RestController
|
|
||||||
public class ItemController {
|
|
||||||
|
|
||||||
@JsonView(Views.Public.class)
|
|
||||||
@RequestMapping("/items/{id}")
|
|
||||||
public Item getItemPublic(@PathVariable final int id) {
|
|
||||||
return ItemManager.getById(id);
|
|
||||||
}
|
|
||||||
|
|
||||||
@JsonView(Views.Internal.class)
|
|
||||||
@RequestMapping("/items/internal/{id}")
|
|
||||||
public Item getItemInternal(@PathVariable final int id) {
|
|
||||||
return ItemManager.getById(id);
|
|
||||||
}
|
|
||||||
|
|
||||||
@RequestMapping("/date")
|
|
||||||
public Date getCurrentDate() throws Exception {
|
|
||||||
return new Date();
|
|
||||||
}
|
|
||||||
|
|
||||||
@RequestMapping("/delay/{seconds}")
|
|
||||||
public void getCurrentTime(@PathVariable final int seconds) throws Exception {
|
|
||||||
|
|
||||||
Thread.sleep(seconds * 1000);
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,76 +0,0 @@
|
||||||
package org.baeldung.web.controller;
|
|
||||||
|
|
||||||
import java.util.Collection;
|
|
||||||
import java.util.HashMap;
|
|
||||||
import java.util.Map;
|
|
||||||
|
|
||||||
import javax.servlet.http.HttpServletResponse;
|
|
||||||
|
|
||||||
import org.baeldung.web.dto.Foo;
|
|
||||||
import org.baeldung.web.exception.ResourceNotFoundException;
|
|
||||||
import org.springframework.http.HttpStatus;
|
|
||||||
import org.springframework.stereotype.Controller;
|
|
||||||
import org.springframework.web.bind.annotation.PathVariable;
|
|
||||||
import org.springframework.web.bind.annotation.RequestBody;
|
|
||||||
import org.springframework.web.bind.annotation.RequestMapping;
|
|
||||||
import org.springframework.web.bind.annotation.RequestMethod;
|
|
||||||
import org.springframework.web.bind.annotation.ResponseBody;
|
|
||||||
import org.springframework.web.bind.annotation.ResponseStatus;
|
|
||||||
import org.springframework.web.servlet.support.ServletUriComponentsBuilder;
|
|
||||||
|
|
||||||
@Controller
|
|
||||||
@RequestMapping(value = "/myfoos")
|
|
||||||
public class MyFooController {
|
|
||||||
|
|
||||||
private final Map<Long, Foo> myfoos;
|
|
||||||
|
|
||||||
public MyFooController() {
|
|
||||||
super();
|
|
||||||
myfoos = new HashMap<Long, Foo>();
|
|
||||||
myfoos.put(1L, new Foo(1L, "sample foo"));
|
|
||||||
}
|
|
||||||
|
|
||||||
// API - read
|
|
||||||
|
|
||||||
@RequestMapping(method = RequestMethod.GET)
|
|
||||||
@ResponseBody
|
|
||||||
public Collection<Foo> findAll() {
|
|
||||||
return myfoos.values();
|
|
||||||
}
|
|
||||||
|
|
||||||
@RequestMapping(method = RequestMethod.GET, value = "/{id}", produces = { "application/json" })
|
|
||||||
@ResponseBody
|
|
||||||
public Foo findById(@PathVariable final long id) {
|
|
||||||
final Foo foo = myfoos.get(id);
|
|
||||||
if (foo == null) {
|
|
||||||
throw new ResourceNotFoundException();
|
|
||||||
}
|
|
||||||
return foo;
|
|
||||||
}
|
|
||||||
|
|
||||||
// API - write
|
|
||||||
|
|
||||||
@RequestMapping(method = RequestMethod.PUT, value = "/{id}")
|
|
||||||
@ResponseStatus(HttpStatus.OK)
|
|
||||||
@ResponseBody
|
|
||||||
public Foo updateFoo(@PathVariable("id") final long id, @RequestBody final Foo foo) {
|
|
||||||
myfoos.put(id, foo);
|
|
||||||
return foo;
|
|
||||||
}
|
|
||||||
|
|
||||||
@RequestMapping(method = RequestMethod.POST)
|
|
||||||
@ResponseStatus(HttpStatus.CREATED)
|
|
||||||
@ResponseBody
|
|
||||||
public Foo createFoo(@RequestBody final Foo foo, HttpServletResponse response) {
|
|
||||||
myfoos.put(foo.getId(), foo);
|
|
||||||
response.setHeader("Location", ServletUriComponentsBuilder.fromCurrentRequest().path("/" + foo.getId()).toUriString());
|
|
||||||
return foo;
|
|
||||||
}
|
|
||||||
|
|
||||||
@RequestMapping(method = RequestMethod.DELETE, value = "/{id}")
|
|
||||||
@ResponseStatus(HttpStatus.OK)
|
|
||||||
public void deleteById(@PathVariable final long id) {
|
|
||||||
myfoos.remove(id);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
|
@ -1,73 +0,0 @@
|
||||||
package org.baeldung.web.controller;
|
|
||||||
|
|
||||||
import java.io.BufferedOutputStream;
|
|
||||||
import java.io.File;
|
|
||||||
import java.io.FileOutputStream;
|
|
||||||
import java.text.DateFormat;
|
|
||||||
import java.text.SimpleDateFormat;
|
|
||||||
import java.util.Date;
|
|
||||||
|
|
||||||
import org.baeldung.web.dto.Foo;
|
|
||||||
import org.springframework.web.bind.annotation.RequestBody;
|
|
||||||
import org.springframework.web.bind.annotation.RequestMapping;
|
|
||||||
import org.springframework.web.bind.annotation.RequestMethod;
|
|
||||||
import org.springframework.web.bind.annotation.RequestParam;
|
|
||||||
import org.springframework.web.bind.annotation.RestController;
|
|
||||||
import org.springframework.web.multipart.MultipartFile;
|
|
||||||
|
|
||||||
// used to test HttpClientPostingTest
|
|
||||||
@RestController
|
|
||||||
public class SimplePostController {
|
|
||||||
|
|
||||||
@RequestMapping(value = "/users", method = RequestMethod.POST)
|
|
||||||
public String postUser(@RequestParam final String username, @RequestParam final String password) {
|
|
||||||
return "Success" + username;
|
|
||||||
}
|
|
||||||
|
|
||||||
@RequestMapping(value = "/users/detail", method = RequestMethod.POST)
|
|
||||||
public String postUserDetail(@RequestBody final Foo entity) {
|
|
||||||
return "Success" + entity.getId();
|
|
||||||
}
|
|
||||||
|
|
||||||
@RequestMapping(value = "/users/multipart", method = RequestMethod.POST)
|
|
||||||
public String uploadFile(@RequestParam final String username, @RequestParam final String password, @RequestParam("file") final MultipartFile file) {
|
|
||||||
if (!file.isEmpty()) {
|
|
||||||
try {
|
|
||||||
final DateFormat dateFormat = new SimpleDateFormat("yyyy_MM_dd_HH.mm.ss");
|
|
||||||
final String fileName = dateFormat.format(new Date());
|
|
||||||
final File fileServer = new File(fileName);
|
|
||||||
fileServer.createNewFile();
|
|
||||||
final byte[] bytes = file.getBytes();
|
|
||||||
final BufferedOutputStream stream = new BufferedOutputStream(new FileOutputStream(fileServer));
|
|
||||||
stream.write(bytes);
|
|
||||||
stream.close();
|
|
||||||
return "You successfully uploaded " + username;
|
|
||||||
} catch (final Exception e) {
|
|
||||||
return "You failed to upload " + e.getMessage();
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
return "You failed to upload because the file was empty.";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@RequestMapping(value = "/users/upload", method = RequestMethod.POST)
|
|
||||||
public String postMultipart(@RequestParam("file") final MultipartFile file) {
|
|
||||||
if (!file.isEmpty()) {
|
|
||||||
try {
|
|
||||||
final DateFormat dateFormat = new SimpleDateFormat("yyyy_MM_dd_HH.mm.ss");
|
|
||||||
final String fileName = dateFormat.format(new Date());
|
|
||||||
final File fileServer = new File(fileName);
|
|
||||||
fileServer.createNewFile();
|
|
||||||
final byte[] bytes = file.getBytes();
|
|
||||||
final BufferedOutputStream stream = new BufferedOutputStream(new FileOutputStream(fileServer));
|
|
||||||
stream.write(bytes);
|
|
||||||
stream.close();
|
|
||||||
return "You successfully uploaded ";
|
|
||||||
} catch (final Exception e) {
|
|
||||||
return "You failed to upload " + e.getMessage();
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
return "You failed to upload because the file was empty.";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,13 +0,0 @@
|
||||||
package org.baeldung.web.controller.advice;
|
|
||||||
|
|
||||||
import org.springframework.web.bind.annotation.ControllerAdvice;
|
|
||||||
import org.springframework.web.servlet.mvc.method.annotation.AbstractJsonpResponseBodyAdvice;
|
|
||||||
|
|
||||||
@ControllerAdvice
|
|
||||||
public class JsonpControllerAdvice extends AbstractJsonpResponseBodyAdvice {
|
|
||||||
|
|
||||||
public JsonpControllerAdvice() {
|
|
||||||
super("callback");
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
|
@ -1,20 +0,0 @@
|
||||||
package org.baeldung.web.controller.mediatypes;
|
|
||||||
|
|
||||||
import org.baeldung.web.dto.BaeldungItem;
|
|
||||||
import org.baeldung.web.dto.BaeldungItemV2;
|
|
||||||
import org.springframework.web.bind.annotation.*;
|
|
||||||
|
|
||||||
@RestController
|
|
||||||
@RequestMapping(value = "/", produces = "application/vnd.baeldung.api.v1+json")
|
|
||||||
public class CustomMediaTypeController {
|
|
||||||
|
|
||||||
@RequestMapping(method = RequestMethod.GET, value = "/public/api/items/{id}", produces = "application/vnd.baeldung.api.v1+json")
|
|
||||||
public @ResponseBody BaeldungItem getItem(@PathVariable("id") String id) {
|
|
||||||
return new BaeldungItem("itemId1");
|
|
||||||
}
|
|
||||||
|
|
||||||
@RequestMapping(method = RequestMethod.GET, value = "/public/api/items/{id}", produces = "application/vnd.baeldung.api.v2+json")
|
|
||||||
public @ResponseBody BaeldungItemV2 getItemSecondAPIVersion(@PathVariable("id") String id) {
|
|
||||||
return new BaeldungItemV2("itemName");
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,52 +0,0 @@
|
||||||
package org.baeldung.web.controller.redirect;
|
|
||||||
|
|
||||||
import org.springframework.stereotype.Controller;
|
|
||||||
import org.springframework.ui.ModelMap;
|
|
||||||
import org.springframework.web.bind.annotation.ModelAttribute;
|
|
||||||
import org.springframework.web.bind.annotation.RequestMapping;
|
|
||||||
import org.springframework.web.bind.annotation.RequestMethod;
|
|
||||||
import org.springframework.web.servlet.ModelAndView;
|
|
||||||
import org.springframework.web.servlet.mvc.support.RedirectAttributes;
|
|
||||||
import org.springframework.web.servlet.view.RedirectView;
|
|
||||||
|
|
||||||
@Controller
|
|
||||||
@RequestMapping("/")
|
|
||||||
public class RedirectController {
|
|
||||||
|
|
||||||
@RequestMapping(value = "/redirectWithXMLConfig", method = RequestMethod.GET)
|
|
||||||
public ModelAndView redirectWithUsingXMLConfig(final ModelMap model) {
|
|
||||||
model.addAttribute("attribute", "redirectWithXMLConfig");
|
|
||||||
return new ModelAndView("RedirectedUrl", model);
|
|
||||||
}
|
|
||||||
|
|
||||||
@RequestMapping(value = "/redirectWithRedirectPrefix", method = RequestMethod.GET)
|
|
||||||
public ModelAndView redirectWithUsingRedirectPrefix(final ModelMap model) {
|
|
||||||
model.addAttribute("attribute", "redirectWithRedirectPrefix");
|
|
||||||
return new ModelAndView("redirect:/redirectedUrl", model);
|
|
||||||
}
|
|
||||||
|
|
||||||
@RequestMapping(value = "/redirectWithRedirectAttributes", method = RequestMethod.GET)
|
|
||||||
public RedirectView redirectWithRedirectAttributes(final RedirectAttributes redirectAttributes) {
|
|
||||||
redirectAttributes.addFlashAttribute("flashAttribute", "redirectWithRedirectAttributes");
|
|
||||||
redirectAttributes.addAttribute("attribute", "redirectWithRedirectAttributes");
|
|
||||||
return new RedirectView("redirectedUrl");
|
|
||||||
}
|
|
||||||
|
|
||||||
@RequestMapping(value = "/redirectWithRedirectView", method = RequestMethod.GET)
|
|
||||||
public RedirectView redirectWithUsingRedirectView(final ModelMap model) {
|
|
||||||
model.addAttribute("attribute", "redirectWithRedirectView");
|
|
||||||
return new RedirectView("redirectedUrl");
|
|
||||||
}
|
|
||||||
|
|
||||||
@RequestMapping(value = "/forwardWithForwardPrefix", method = RequestMethod.GET)
|
|
||||||
public ModelAndView forwardWithUsingForwardPrefix(final ModelMap model) {
|
|
||||||
model.addAttribute("attribute", "redirectWithForwardPrefix");
|
|
||||||
return new ModelAndView("forward:/redirectedUrl", model);
|
|
||||||
}
|
|
||||||
|
|
||||||
@RequestMapping(value = "/redirectedUrl", method = RequestMethod.GET)
|
|
||||||
public ModelAndView redirection(final ModelMap model, @ModelAttribute("flashAttribute") final Object flashAttribute) {
|
|
||||||
model.addAttribute("redirectionAttribute", flashAttribute);
|
|
||||||
return new ModelAndView("redirection", model);
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,24 +0,0 @@
|
||||||
package org.baeldung.web.controller.status;
|
|
||||||
|
|
||||||
import org.springframework.http.HttpStatus;
|
|
||||||
import org.springframework.http.ResponseEntity;
|
|
||||||
import org.springframework.stereotype.Controller;
|
|
||||||
import org.springframework.web.bind.annotation.RequestMapping;
|
|
||||||
import org.springframework.web.bind.annotation.RequestMethod;
|
|
||||||
import org.springframework.web.bind.annotation.ResponseBody;
|
|
||||||
|
|
||||||
@Controller
|
|
||||||
public class ExampleController {
|
|
||||||
|
|
||||||
@RequestMapping(value = "/controller", method = RequestMethod.GET)
|
|
||||||
@ResponseBody
|
|
||||||
public ResponseEntity sendViaResponseEntity() {
|
|
||||||
return new ResponseEntity(HttpStatus.NOT_ACCEPTABLE);
|
|
||||||
}
|
|
||||||
|
|
||||||
@RequestMapping(value = "/exception", method = RequestMethod.GET)
|
|
||||||
@ResponseBody
|
|
||||||
public ResponseEntity sendViaException() {
|
|
||||||
throw new ForbiddenException();
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,10 +0,0 @@
|
||||||
package org.baeldung.web.controller.status;
|
|
||||||
|
|
||||||
import org.springframework.http.HttpStatus;
|
|
||||||
import org.springframework.web.bind.annotation.ResponseStatus;
|
|
||||||
|
|
||||||
@ResponseStatus(value = HttpStatus.FORBIDDEN, reason = "To show an example of a custom message")
|
|
||||||
public class ForbiddenException extends RuntimeException {
|
|
||||||
private static final long serialVersionUID = 6826605655586311552L;
|
|
||||||
|
|
||||||
}
|
|
|
@ -1,13 +0,0 @@
|
||||||
package org.baeldung.web.dto;
|
|
||||||
|
|
||||||
public class BaeldungItem {
|
|
||||||
private final String itemId;
|
|
||||||
|
|
||||||
public BaeldungItem(String itemId) {
|
|
||||||
this.itemId = itemId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getItemId() {
|
|
||||||
return itemId;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,14 +0,0 @@
|
||||||
package org.baeldung.web.dto;
|
|
||||||
|
|
||||||
|
|
||||||
public class BaeldungItemV2 {
|
|
||||||
private final String itemName;
|
|
||||||
|
|
||||||
public BaeldungItemV2(String itemName) {
|
|
||||||
this.itemName = itemName;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getItemName() {
|
|
||||||
return itemName;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,38 +0,0 @@
|
||||||
package org.baeldung.web.dto;
|
|
||||||
|
|
||||||
public class Company {
|
|
||||||
|
|
||||||
private long id;
|
|
||||||
private String name;
|
|
||||||
|
|
||||||
public Company() {
|
|
||||||
super();
|
|
||||||
}
|
|
||||||
|
|
||||||
public Company(final long id, final String name) {
|
|
||||||
this.id = id;
|
|
||||||
this.name = name;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getName() {
|
|
||||||
return name;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setName(final String name) {
|
|
||||||
this.name = name;
|
|
||||||
}
|
|
||||||
|
|
||||||
public long getId() {
|
|
||||||
return id;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setId(final long id) {
|
|
||||||
this.id = id;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String toString() {
|
|
||||||
return "Company [id=" + id + ", name=" + name + "]";
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
|
@ -1,45 +0,0 @@
|
||||||
package org.baeldung.web.dto;
|
|
||||||
|
|
||||||
import com.thoughtworks.xstream.annotations.XStreamAlias;
|
|
||||||
|
|
||||||
@XStreamAlias("Foo")
|
|
||||||
public class Foo {
|
|
||||||
private long id;
|
|
||||||
private String name;
|
|
||||||
|
|
||||||
public Foo() {
|
|
||||||
super();
|
|
||||||
}
|
|
||||||
|
|
||||||
public Foo(final String name) {
|
|
||||||
super();
|
|
||||||
|
|
||||||
this.name = name;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Foo(final long id, final String name) {
|
|
||||||
super();
|
|
||||||
|
|
||||||
this.id = id;
|
|
||||||
this.name = name;
|
|
||||||
}
|
|
||||||
|
|
||||||
// API
|
|
||||||
|
|
||||||
public long getId() {
|
|
||||||
return id;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setId(final long id) {
|
|
||||||
this.id = id;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getName() {
|
|
||||||
return name;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setName(final String name) {
|
|
||||||
this.name = name;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
|
@ -1,597 +0,0 @@
|
||||||
// Generated by the protocol buffer compiler. DO NOT EDIT!
|
|
||||||
// source: FooProtos.proto
|
|
||||||
|
|
||||||
package org.baeldung.web.dto;
|
|
||||||
|
|
||||||
public final class FooProtos {
|
|
||||||
private FooProtos() {
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void registerAllExtensions(com.google.protobuf.ExtensionRegistry registry) {
|
|
||||||
}
|
|
||||||
|
|
||||||
public interface FooOrBuilder extends
|
|
||||||
// @@protoc_insertion_point(interface_extends:baeldung.Foo)
|
|
||||||
com.google.protobuf.MessageOrBuilder {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* <code>required int64 id = 1;</code>
|
|
||||||
*/
|
|
||||||
boolean hasId();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* <code>required int64 id = 1;</code>
|
|
||||||
*/
|
|
||||||
long getId();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* <code>required string name = 2;</code>
|
|
||||||
*/
|
|
||||||
boolean hasName();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* <code>required string name = 2;</code>
|
|
||||||
*/
|
|
||||||
java.lang.String getName();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* <code>required string name = 2;</code>
|
|
||||||
*/
|
|
||||||
com.google.protobuf.ByteString getNameBytes();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Protobuf type {@code baeldung.Foo}
|
|
||||||
*/
|
|
||||||
public static final class Foo extends com.google.protobuf.GeneratedMessage implements
|
|
||||||
// @@protoc_insertion_point(message_implements:baeldung.Foo)
|
|
||||||
FooOrBuilder {
|
|
||||||
// Use Foo.newBuilder() to construct.
|
|
||||||
private Foo(com.google.protobuf.GeneratedMessage.Builder<?> builder) {
|
|
||||||
super(builder);
|
|
||||||
this.unknownFields = builder.getUnknownFields();
|
|
||||||
}
|
|
||||||
|
|
||||||
private Foo(boolean noInit) {
|
|
||||||
this.unknownFields = com.google.protobuf.UnknownFieldSet.getDefaultInstance();
|
|
||||||
}
|
|
||||||
|
|
||||||
private static final Foo defaultInstance;
|
|
||||||
|
|
||||||
public static Foo getDefaultInstance() {
|
|
||||||
return defaultInstance;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Foo getDefaultInstanceForType() {
|
|
||||||
return defaultInstance;
|
|
||||||
}
|
|
||||||
|
|
||||||
private final com.google.protobuf.UnknownFieldSet unknownFields;
|
|
||||||
|
|
||||||
@java.lang.Override
|
|
||||||
public final com.google.protobuf.UnknownFieldSet getUnknownFields() {
|
|
||||||
return this.unknownFields;
|
|
||||||
}
|
|
||||||
|
|
||||||
private Foo(com.google.protobuf.CodedInputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException {
|
|
||||||
initFields();
|
|
||||||
int mutable_bitField0_ = 0;
|
|
||||||
com.google.protobuf.UnknownFieldSet.Builder unknownFields = com.google.protobuf.UnknownFieldSet.newBuilder();
|
|
||||||
try {
|
|
||||||
boolean done = false;
|
|
||||||
while (!done) {
|
|
||||||
int tag = input.readTag();
|
|
||||||
switch (tag) {
|
|
||||||
case 0:
|
|
||||||
done = true;
|
|
||||||
break;
|
|
||||||
default: {
|
|
||||||
if (!parseUnknownField(input, unknownFields, extensionRegistry, tag)) {
|
|
||||||
done = true;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case 8: {
|
|
||||||
bitField0_ |= 0x00000001;
|
|
||||||
id_ = input.readInt64();
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case 18: {
|
|
||||||
com.google.protobuf.ByteString bs = input.readBytes();
|
|
||||||
bitField0_ |= 0x00000002;
|
|
||||||
name_ = bs;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} catch (com.google.protobuf.InvalidProtocolBufferException e) {
|
|
||||||
throw e.setUnfinishedMessage(this);
|
|
||||||
} catch (java.io.IOException e) {
|
|
||||||
throw new com.google.protobuf.InvalidProtocolBufferException(e.getMessage()).setUnfinishedMessage(this);
|
|
||||||
} finally {
|
|
||||||
this.unknownFields = unknownFields.build();
|
|
||||||
makeExtensionsImmutable();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static final com.google.protobuf.Descriptors.Descriptor getDescriptor() {
|
|
||||||
return org.baeldung.web.dto.FooProtos.internal_static_baeldung_Foo_descriptor;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected com.google.protobuf.GeneratedMessage.FieldAccessorTable internalGetFieldAccessorTable() {
|
|
||||||
return org.baeldung.web.dto.FooProtos.internal_static_baeldung_Foo_fieldAccessorTable.ensureFieldAccessorsInitialized(org.baeldung.web.dto.FooProtos.Foo.class, org.baeldung.web.dto.FooProtos.Foo.Builder.class);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static com.google.protobuf.Parser<Foo> PARSER = new com.google.protobuf.AbstractParser<Foo>() {
|
|
||||||
public Foo parsePartialFrom(com.google.protobuf.CodedInputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException {
|
|
||||||
return new Foo(input, extensionRegistry);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
@java.lang.Override
|
|
||||||
public com.google.protobuf.Parser<Foo> getParserForType() {
|
|
||||||
return PARSER;
|
|
||||||
}
|
|
||||||
|
|
||||||
private int bitField0_;
|
|
||||||
public static final int ID_FIELD_NUMBER = 1;
|
|
||||||
private long id_;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* <code>required int64 id = 1;</code>
|
|
||||||
*/
|
|
||||||
public boolean hasId() {
|
|
||||||
return ((bitField0_ & 0x00000001) == 0x00000001);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* <code>required int64 id = 1;</code>
|
|
||||||
*/
|
|
||||||
public long getId() {
|
|
||||||
return id_;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static final int NAME_FIELD_NUMBER = 2;
|
|
||||||
private java.lang.Object name_;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* <code>required string name = 2;</code>
|
|
||||||
*/
|
|
||||||
public boolean hasName() {
|
|
||||||
return ((bitField0_ & 0x00000002) == 0x00000002);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* <code>required string name = 2;</code>
|
|
||||||
*/
|
|
||||||
public java.lang.String getName() {
|
|
||||||
java.lang.Object ref = name_;
|
|
||||||
if (ref instanceof java.lang.String) {
|
|
||||||
return (java.lang.String) ref;
|
|
||||||
} else {
|
|
||||||
com.google.protobuf.ByteString bs = (com.google.protobuf.ByteString) ref;
|
|
||||||
java.lang.String s = bs.toStringUtf8();
|
|
||||||
if (bs.isValidUtf8()) {
|
|
||||||
name_ = s;
|
|
||||||
}
|
|
||||||
return s;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* <code>required string name = 2;</code>
|
|
||||||
*/
|
|
||||||
public com.google.protobuf.ByteString getNameBytes() {
|
|
||||||
java.lang.Object ref = name_;
|
|
||||||
if (ref instanceof java.lang.String) {
|
|
||||||
com.google.protobuf.ByteString b = com.google.protobuf.ByteString.copyFromUtf8((java.lang.String) ref);
|
|
||||||
name_ = b;
|
|
||||||
return b;
|
|
||||||
} else {
|
|
||||||
return (com.google.protobuf.ByteString) ref;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void initFields() {
|
|
||||||
id_ = 0L;
|
|
||||||
name_ = "";
|
|
||||||
}
|
|
||||||
|
|
||||||
private byte memoizedIsInitialized = -1;
|
|
||||||
|
|
||||||
public final boolean isInitialized() {
|
|
||||||
byte isInitialized = memoizedIsInitialized;
|
|
||||||
if (isInitialized == 1)
|
|
||||||
return true;
|
|
||||||
if (isInitialized == 0)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
if (!hasId()) {
|
|
||||||
memoizedIsInitialized = 0;
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
if (!hasName()) {
|
|
||||||
memoizedIsInitialized = 0;
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
memoizedIsInitialized = 1;
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void writeTo(com.google.protobuf.CodedOutputStream output) throws java.io.IOException {
|
|
||||||
getSerializedSize();
|
|
||||||
if (((bitField0_ & 0x00000001) == 0x00000001)) {
|
|
||||||
output.writeInt64(1, id_);
|
|
||||||
}
|
|
||||||
if (((bitField0_ & 0x00000002) == 0x00000002)) {
|
|
||||||
output.writeBytes(2, getNameBytes());
|
|
||||||
}
|
|
||||||
getUnknownFields().writeTo(output);
|
|
||||||
}
|
|
||||||
|
|
||||||
private int memoizedSerializedSize = -1;
|
|
||||||
|
|
||||||
public int getSerializedSize() {
|
|
||||||
int size = memoizedSerializedSize;
|
|
||||||
if (size != -1)
|
|
||||||
return size;
|
|
||||||
|
|
||||||
size = 0;
|
|
||||||
if (((bitField0_ & 0x00000001) == 0x00000001)) {
|
|
||||||
size += com.google.protobuf.CodedOutputStream.computeInt64Size(1, id_);
|
|
||||||
}
|
|
||||||
if (((bitField0_ & 0x00000002) == 0x00000002)) {
|
|
||||||
size += com.google.protobuf.CodedOutputStream.computeBytesSize(2, getNameBytes());
|
|
||||||
}
|
|
||||||
size += getUnknownFields().getSerializedSize();
|
|
||||||
memoizedSerializedSize = size;
|
|
||||||
return size;
|
|
||||||
}
|
|
||||||
|
|
||||||
private static final long serialVersionUID = 0L;
|
|
||||||
|
|
||||||
@java.lang.Override
|
|
||||||
protected java.lang.Object writeReplace() throws java.io.ObjectStreamException {
|
|
||||||
return super.writeReplace();
|
|
||||||
}
|
|
||||||
|
|
||||||
public static org.baeldung.web.dto.FooProtos.Foo parseFrom(com.google.protobuf.ByteString data) throws com.google.protobuf.InvalidProtocolBufferException {
|
|
||||||
return PARSER.parseFrom(data);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static org.baeldung.web.dto.FooProtos.Foo parseFrom(com.google.protobuf.ByteString data, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException {
|
|
||||||
return PARSER.parseFrom(data, extensionRegistry);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static org.baeldung.web.dto.FooProtos.Foo parseFrom(byte[] data) throws com.google.protobuf.InvalidProtocolBufferException {
|
|
||||||
return PARSER.parseFrom(data);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static org.baeldung.web.dto.FooProtos.Foo parseFrom(byte[] data, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException {
|
|
||||||
return PARSER.parseFrom(data, extensionRegistry);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static org.baeldung.web.dto.FooProtos.Foo parseFrom(java.io.InputStream input) throws java.io.IOException {
|
|
||||||
return PARSER.parseFrom(input);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static org.baeldung.web.dto.FooProtos.Foo parseFrom(java.io.InputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws java.io.IOException {
|
|
||||||
return PARSER.parseFrom(input, extensionRegistry);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static org.baeldung.web.dto.FooProtos.Foo parseDelimitedFrom(java.io.InputStream input) throws java.io.IOException {
|
|
||||||
return PARSER.parseDelimitedFrom(input);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static org.baeldung.web.dto.FooProtos.Foo parseDelimitedFrom(java.io.InputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws java.io.IOException {
|
|
||||||
return PARSER.parseDelimitedFrom(input, extensionRegistry);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static org.baeldung.web.dto.FooProtos.Foo parseFrom(com.google.protobuf.CodedInputStream input) throws java.io.IOException {
|
|
||||||
return PARSER.parseFrom(input);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static org.baeldung.web.dto.FooProtos.Foo parseFrom(com.google.protobuf.CodedInputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws java.io.IOException {
|
|
||||||
return PARSER.parseFrom(input, extensionRegistry);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static Builder newBuilder() {
|
|
||||||
return Builder.create();
|
|
||||||
}
|
|
||||||
|
|
||||||
public Builder newBuilderForType() {
|
|
||||||
return newBuilder();
|
|
||||||
}
|
|
||||||
|
|
||||||
public static Builder newBuilder(org.baeldung.web.dto.FooProtos.Foo prototype) {
|
|
||||||
return newBuilder().mergeFrom(prototype);
|
|
||||||
}
|
|
||||||
|
|
||||||
public Builder toBuilder() {
|
|
||||||
return newBuilder(this);
|
|
||||||
}
|
|
||||||
|
|
||||||
@java.lang.Override
|
|
||||||
protected Builder newBuilderForType(com.google.protobuf.GeneratedMessage.BuilderParent parent) {
|
|
||||||
Builder builder = new Builder(parent);
|
|
||||||
return builder;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Protobuf type {@code baeldung.Foo}
|
|
||||||
*/
|
|
||||||
public static final class Builder extends com.google.protobuf.GeneratedMessage.Builder<Builder> implements
|
|
||||||
// @@protoc_insertion_point(builder_implements:baeldung.Foo)
|
|
||||||
org.baeldung.web.dto.FooProtos.FooOrBuilder {
|
|
||||||
public static final com.google.protobuf.Descriptors.Descriptor getDescriptor() {
|
|
||||||
return org.baeldung.web.dto.FooProtos.internal_static_baeldung_Foo_descriptor;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected com.google.protobuf.GeneratedMessage.FieldAccessorTable internalGetFieldAccessorTable() {
|
|
||||||
return org.baeldung.web.dto.FooProtos.internal_static_baeldung_Foo_fieldAccessorTable.ensureFieldAccessorsInitialized(org.baeldung.web.dto.FooProtos.Foo.class, org.baeldung.web.dto.FooProtos.Foo.Builder.class);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Construct using org.baeldung.web.dto.FooProtos.Foo.newBuilder()
|
|
||||||
private Builder() {
|
|
||||||
maybeForceBuilderInitialization();
|
|
||||||
}
|
|
||||||
|
|
||||||
private Builder(com.google.protobuf.GeneratedMessage.BuilderParent parent) {
|
|
||||||
super(parent);
|
|
||||||
maybeForceBuilderInitialization();
|
|
||||||
}
|
|
||||||
|
|
||||||
private void maybeForceBuilderInitialization() {
|
|
||||||
if (com.google.protobuf.GeneratedMessage.alwaysUseFieldBuilders) {
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private static Builder create() {
|
|
||||||
return new Builder();
|
|
||||||
}
|
|
||||||
|
|
||||||
public Builder clear() {
|
|
||||||
super.clear();
|
|
||||||
id_ = 0L;
|
|
||||||
bitField0_ = (bitField0_ & ~0x00000001);
|
|
||||||
name_ = "";
|
|
||||||
bitField0_ = (bitField0_ & ~0x00000002);
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Builder clone() {
|
|
||||||
return create().mergeFrom(buildPartial());
|
|
||||||
}
|
|
||||||
|
|
||||||
public com.google.protobuf.Descriptors.Descriptor getDescriptorForType() {
|
|
||||||
return org.baeldung.web.dto.FooProtos.internal_static_baeldung_Foo_descriptor;
|
|
||||||
}
|
|
||||||
|
|
||||||
public org.baeldung.web.dto.FooProtos.Foo getDefaultInstanceForType() {
|
|
||||||
return org.baeldung.web.dto.FooProtos.Foo.getDefaultInstance();
|
|
||||||
}
|
|
||||||
|
|
||||||
public org.baeldung.web.dto.FooProtos.Foo build() {
|
|
||||||
org.baeldung.web.dto.FooProtos.Foo result = buildPartial();
|
|
||||||
if (!result.isInitialized()) {
|
|
||||||
throw newUninitializedMessageException(result);
|
|
||||||
}
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
public org.baeldung.web.dto.FooProtos.Foo buildPartial() {
|
|
||||||
org.baeldung.web.dto.FooProtos.Foo result = new org.baeldung.web.dto.FooProtos.Foo(this);
|
|
||||||
int from_bitField0_ = bitField0_;
|
|
||||||
int to_bitField0_ = 0;
|
|
||||||
if (((from_bitField0_ & 0x00000001) == 0x00000001)) {
|
|
||||||
to_bitField0_ |= 0x00000001;
|
|
||||||
}
|
|
||||||
result.id_ = id_;
|
|
||||||
if (((from_bitField0_ & 0x00000002) == 0x00000002)) {
|
|
||||||
to_bitField0_ |= 0x00000002;
|
|
||||||
}
|
|
||||||
result.name_ = name_;
|
|
||||||
result.bitField0_ = to_bitField0_;
|
|
||||||
onBuilt();
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Builder mergeFrom(com.google.protobuf.Message other) {
|
|
||||||
if (other instanceof org.baeldung.web.dto.FooProtos.Foo) {
|
|
||||||
return mergeFrom((org.baeldung.web.dto.FooProtos.Foo) other);
|
|
||||||
} else {
|
|
||||||
super.mergeFrom(other);
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public Builder mergeFrom(org.baeldung.web.dto.FooProtos.Foo other) {
|
|
||||||
if (other == org.baeldung.web.dto.FooProtos.Foo.getDefaultInstance())
|
|
||||||
return this;
|
|
||||||
if (other.hasId()) {
|
|
||||||
setId(other.getId());
|
|
||||||
}
|
|
||||||
if (other.hasName()) {
|
|
||||||
bitField0_ |= 0x00000002;
|
|
||||||
name_ = other.name_;
|
|
||||||
onChanged();
|
|
||||||
}
|
|
||||||
this.mergeUnknownFields(other.getUnknownFields());
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public final boolean isInitialized() {
|
|
||||||
if (!hasId()) {
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
if (!hasName()) {
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Builder mergeFrom(com.google.protobuf.CodedInputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws java.io.IOException {
|
|
||||||
org.baeldung.web.dto.FooProtos.Foo parsedMessage = null;
|
|
||||||
try {
|
|
||||||
parsedMessage = PARSER.parsePartialFrom(input, extensionRegistry);
|
|
||||||
} catch (com.google.protobuf.InvalidProtocolBufferException e) {
|
|
||||||
parsedMessage = (org.baeldung.web.dto.FooProtos.Foo) e.getUnfinishedMessage();
|
|
||||||
throw e;
|
|
||||||
} finally {
|
|
||||||
if (parsedMessage != null) {
|
|
||||||
mergeFrom(parsedMessage);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
private int bitField0_;
|
|
||||||
|
|
||||||
private long id_;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* <code>required int64 id = 1;</code>
|
|
||||||
*/
|
|
||||||
public boolean hasId() {
|
|
||||||
return ((bitField0_ & 0x00000001) == 0x00000001);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* <code>required int64 id = 1;</code>
|
|
||||||
*/
|
|
||||||
public long getId() {
|
|
||||||
return id_;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* <code>required int64 id = 1;</code>
|
|
||||||
*/
|
|
||||||
public Builder setId(long value) {
|
|
||||||
bitField0_ |= 0x00000001;
|
|
||||||
id_ = value;
|
|
||||||
onChanged();
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* <code>required int64 id = 1;</code>
|
|
||||||
*/
|
|
||||||
public Builder clearId() {
|
|
||||||
bitField0_ = (bitField0_ & ~0x00000001);
|
|
||||||
id_ = 0L;
|
|
||||||
onChanged();
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
private java.lang.Object name_ = "";
|
|
||||||
|
|
||||||
/**
|
|
||||||
* <code>required string name = 2;</code>
|
|
||||||
*/
|
|
||||||
public boolean hasName() {
|
|
||||||
return ((bitField0_ & 0x00000002) == 0x00000002);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* <code>required string name = 2;</code>
|
|
||||||
*/
|
|
||||||
public java.lang.String getName() {
|
|
||||||
java.lang.Object ref = name_;
|
|
||||||
if (!(ref instanceof java.lang.String)) {
|
|
||||||
com.google.protobuf.ByteString bs = (com.google.protobuf.ByteString) ref;
|
|
||||||
java.lang.String s = bs.toStringUtf8();
|
|
||||||
if (bs.isValidUtf8()) {
|
|
||||||
name_ = s;
|
|
||||||
}
|
|
||||||
return s;
|
|
||||||
} else {
|
|
||||||
return (java.lang.String) ref;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* <code>required string name = 2;</code>
|
|
||||||
*/
|
|
||||||
public com.google.protobuf.ByteString getNameBytes() {
|
|
||||||
java.lang.Object ref = name_;
|
|
||||||
if (ref instanceof String) {
|
|
||||||
com.google.protobuf.ByteString b = com.google.protobuf.ByteString.copyFromUtf8((java.lang.String) ref);
|
|
||||||
name_ = b;
|
|
||||||
return b;
|
|
||||||
} else {
|
|
||||||
return (com.google.protobuf.ByteString) ref;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* <code>required string name = 2;</code>
|
|
||||||
*/
|
|
||||||
public Builder setName(java.lang.String value) {
|
|
||||||
if (value == null) {
|
|
||||||
throw new NullPointerException();
|
|
||||||
}
|
|
||||||
bitField0_ |= 0x00000002;
|
|
||||||
name_ = value;
|
|
||||||
onChanged();
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* <code>required string name = 2;</code>
|
|
||||||
*/
|
|
||||||
public Builder clearName() {
|
|
||||||
bitField0_ = (bitField0_ & ~0x00000002);
|
|
||||||
name_ = getDefaultInstance().getName();
|
|
||||||
onChanged();
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* <code>required string name = 2;</code>
|
|
||||||
*/
|
|
||||||
public Builder setNameBytes(com.google.protobuf.ByteString value) {
|
|
||||||
if (value == null) {
|
|
||||||
throw new NullPointerException();
|
|
||||||
}
|
|
||||||
bitField0_ |= 0x00000002;
|
|
||||||
name_ = value;
|
|
||||||
onChanged();
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
// @@protoc_insertion_point(builder_scope:baeldung.Foo)
|
|
||||||
}
|
|
||||||
|
|
||||||
static {
|
|
||||||
defaultInstance = new Foo(true);
|
|
||||||
defaultInstance.initFields();
|
|
||||||
}
|
|
||||||
|
|
||||||
// @@protoc_insertion_point(class_scope:baeldung.Foo)
|
|
||||||
}
|
|
||||||
|
|
||||||
private static final com.google.protobuf.Descriptors.Descriptor internal_static_baeldung_Foo_descriptor;
|
|
||||||
private static com.google.protobuf.GeneratedMessage.FieldAccessorTable internal_static_baeldung_Foo_fieldAccessorTable;
|
|
||||||
|
|
||||||
public static com.google.protobuf.Descriptors.FileDescriptor getDescriptor() {
|
|
||||||
return descriptor;
|
|
||||||
}
|
|
||||||
|
|
||||||
private static com.google.protobuf.Descriptors.FileDescriptor descriptor;
|
|
||||||
static {
|
|
||||||
java.lang.String[] descriptorData = { "\n\017FooProtos.proto\022\010baeldung\"\037\n\003Foo\022\n\n\002id" + "\030\001 \002(\003\022\014\n\004name\030\002 \002(\tB!\n\024org.baeldung.web" + ".dtoB\tFooProtos" };
|
|
||||||
com.google.protobuf.Descriptors.FileDescriptor.InternalDescriptorAssigner assigner = new com.google.protobuf.Descriptors.FileDescriptor.InternalDescriptorAssigner() {
|
|
||||||
public com.google.protobuf.ExtensionRegistry assignDescriptors(com.google.protobuf.Descriptors.FileDescriptor root) {
|
|
||||||
descriptor = root;
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
com.google.protobuf.Descriptors.FileDescriptor.internalBuildGeneratedFileFrom(descriptorData, new com.google.protobuf.Descriptors.FileDescriptor[] {}, assigner);
|
|
||||||
internal_static_baeldung_Foo_descriptor = getDescriptor().getMessageTypes().get(0);
|
|
||||||
internal_static_baeldung_Foo_fieldAccessorTable = new com.google.protobuf.GeneratedMessage.FieldAccessorTable(internal_static_baeldung_Foo_descriptor, new java.lang.String[] { "Id", "Name", });
|
|
||||||
}
|
|
||||||
|
|
||||||
// @@protoc_insertion_point(outer_class_scope)
|
|
||||||
}
|
|
|
@ -1,36 +0,0 @@
|
||||||
package org.baeldung.web.dto;
|
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonView;
|
|
||||||
|
|
||||||
public class Item {
|
|
||||||
@JsonView(Views.Public.class)
|
|
||||||
public int id;
|
|
||||||
|
|
||||||
@JsonView(Views.Public.class)
|
|
||||||
public String itemName;
|
|
||||||
|
|
||||||
@JsonView(Views.Internal.class)
|
|
||||||
public String ownerName;
|
|
||||||
|
|
||||||
public Item() {
|
|
||||||
super();
|
|
||||||
}
|
|
||||||
|
|
||||||
public Item(final int id, final String itemName, final String ownerName) {
|
|
||||||
this.id = id;
|
|
||||||
this.itemName = itemName;
|
|
||||||
this.ownerName = ownerName;
|
|
||||||
}
|
|
||||||
|
|
||||||
public int getId() {
|
|
||||||
return id;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getItemName() {
|
|
||||||
return itemName;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getOwnerName() {
|
|
||||||
return ownerName;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,9 +0,0 @@
|
||||||
package org.baeldung.web.dto;
|
|
||||||
|
|
||||||
public class ItemManager {
|
|
||||||
|
|
||||||
public static Item getById(final int id) {
|
|
||||||
final Item item = new Item(2, "book", "John");
|
|
||||||
return item;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,9 +0,0 @@
|
||||||
package org.baeldung.web.dto;
|
|
||||||
|
|
||||||
public class Views {
|
|
||||||
public static class Public {
|
|
||||||
}
|
|
||||||
|
|
||||||
public static class Internal extends Public {
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,8 +0,0 @@
|
||||||
package org.baeldung.web.exception;
|
|
||||||
|
|
||||||
import org.springframework.http.HttpStatus;
|
|
||||||
import org.springframework.web.bind.annotation.ResponseStatus;
|
|
||||||
|
|
||||||
@ResponseStatus(value = HttpStatus.NOT_FOUND)
|
|
||||||
public class ResourceNotFoundException extends RuntimeException {
|
|
||||||
}
|
|
|
@ -1,2 +0,0 @@
|
||||||
server.port= 8082
|
|
||||||
server.context-path=/spring-rest
|
|
|
@ -1,20 +0,0 @@
|
||||||
<configuration>
|
|
||||||
|
|
||||||
<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
|
|
||||||
<encoder>
|
|
||||||
<pattern>web - %date [%thread] %-5level %logger{36} - %message%n
|
|
||||||
</pattern>
|
|
||||||
</encoder>
|
|
||||||
</appender>
|
|
||||||
|
|
||||||
<logger name="org.springframework" level="WARN" />
|
|
||||||
<logger name="org.springframework.transaction" level="WARN" />
|
|
||||||
|
|
||||||
<!-- in order to debug some marshalling issues, this needs to be TRACE -->
|
|
||||||
<logger name="org.springframework.web.servlet.mvc" level="WARN" />
|
|
||||||
|
|
||||||
<root level="INFO">
|
|
||||||
<appender-ref ref="STDOUT" />
|
|
||||||
</root>
|
|
||||||
|
|
||||||
</configuration>
|
|
|
@ -1,56 +0,0 @@
|
||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<beans xmlns="http://www.springframework.org/schema/beans" xmlns:mvc="http://www.springframework.org/schema/mvc" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
|
||||||
xmlns:context="http://www.springframework.org/schema/context"
|
|
||||||
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
|
|
||||||
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd
|
|
||||||
http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd"
|
|
||||||
>
|
|
||||||
|
|
||||||
<context:component-scan base-package="org.baeldung.web" />
|
|
||||||
|
|
||||||
<mvc:annotation-driven content-negotiation-manager="contentNegotiationManager" >
|
|
||||||
<mvc:message-converters register-defaults="true">
|
|
||||||
<!--
|
|
||||||
<bean class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter"/>
|
|
||||||
|
|
||||||
<bean class="org.springframework.http.converter.xml.MarshallingHttpMessageConverter">
|
|
||||||
<property name="marshaller" ref="xstreamMarshaller" />
|
|
||||||
<property name="unmarshaller" ref="xstreamMarshaller" />
|
|
||||||
</bean>
|
|
||||||
-->
|
|
||||||
<bean class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter"/>
|
|
||||||
<bean class="org.baeldung.config.converter.KryoHttpMessageConverter"/>
|
|
||||||
<bean class="org.springframework.http.converter.protobuf.ProtobufHttpMessageConverter"/>
|
|
||||||
</mvc:message-converters>
|
|
||||||
</mvc:annotation-driven>
|
|
||||||
|
|
||||||
<bean id="xstreamMarshaller" class="org.springframework.oxm.xstream.XStreamMarshaller" />
|
|
||||||
|
|
||||||
<!-- -->
|
|
||||||
|
|
||||||
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver" />
|
|
||||||
<bean class="org.springframework.web.servlet.view.XmlViewResolver">
|
|
||||||
<property name="location">
|
|
||||||
<value>/WEB-INF/spring-views.xml</value>
|
|
||||||
</property>
|
|
||||||
<property name="order" value="0" />
|
|
||||||
</bean>
|
|
||||||
|
|
||||||
<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
|
|
||||||
<!-- max upload size in bytes -->
|
|
||||||
<property name="maxUploadSize" value="20971520" /> <!-- 20MB -->
|
|
||||||
|
|
||||||
<!-- max size of file in memory (in bytes) -->
|
|
||||||
<property name="maxInMemorySize" value="1048576" /> <!-- 1MB -->
|
|
||||||
|
|
||||||
</bean>
|
|
||||||
|
|
||||||
<bean id="contentNegotiationManager"
|
|
||||||
class="org.springframework.web.accept.ContentNegotiationManagerFactoryBean">
|
|
||||||
<property name="defaultContentType" value="application/json" />
|
|
||||||
</bean>
|
|
||||||
|
|
||||||
|
|
||||||
</beans>
|
|
||||||
|
|
||||||
|
|
|
@ -1,44 +0,0 @@
|
||||||
<!DOCTYPE html>
|
|
||||||
<html>
|
|
||||||
<head>
|
|
||||||
<meta charset="ISO-8859-1">
|
|
||||||
<title>Company Data</title>
|
|
||||||
<script src="https://code.jquery.com/jquery-3.1.0.js"
|
|
||||||
integrity="sha256-slogkvB1K3VOkzAI8QITxV3VzpOnkeNVsKvtkYLMjfk="
|
|
||||||
crossorigin="anonymous"></script>
|
|
||||||
<script>
|
|
||||||
$(document).ready(function(){
|
|
||||||
$('#REST-button').click(function() {
|
|
||||||
$.ajax({
|
|
||||||
url: 'http://localhost:8080/spring-rest/companyRest?callback=getCompanyData',
|
|
||||||
data: {
|
|
||||||
format: 'json'
|
|
||||||
},
|
|
||||||
type: 'GET',
|
|
||||||
jsonpCallback:'getCompanyData',
|
|
||||||
dataType: 'jsonp',
|
|
||||||
error: function() {
|
|
||||||
$('#infoREST').html('<p>An error has occurred</p>');
|
|
||||||
},
|
|
||||||
success: function(data) {
|
|
||||||
console.log("sucess");
|
|
||||||
}
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
function getCompanyData(data) {
|
|
||||||
document.write("<b>ID:</b> "+data.id+"<br/>");
|
|
||||||
document.write("<b>NAME:</b> "+data.name+"<br/>");
|
|
||||||
document.write("<br/>");
|
|
||||||
}
|
|
||||||
</script>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
|
|
||||||
<!-- Using REST URL-->
|
|
||||||
<button id="REST-button">Test REST JSON-P!</button>
|
|
||||||
<div id="infoREST"></div>
|
|
||||||
|
|
||||||
</body>
|
|
||||||
</html>
|
|
|
@ -1,10 +0,0 @@
|
||||||
<beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
|
||||||
xsi:schemaLocation="http://www.springframework.org/schema/beans
|
|
||||||
http://www.springframework.org/schema/beans/spring-beans-2.5.xsd"
|
|
||||||
>
|
|
||||||
|
|
||||||
<bean id="RedirectedUrl" class="org.springframework.web.servlet.view.RedirectView">
|
|
||||||
<property name="url" value="redirectedUrl" />
|
|
||||||
</bean>
|
|
||||||
|
|
||||||
</beans>
|
|
|
@ -1,41 +0,0 @@
|
||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
|
|
||||||
xsi:schemaLocation="
|
|
||||||
http://java.sun.com/xml/ns/javaee
|
|
||||||
http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0"
|
|
||||||
>
|
|
||||||
|
|
||||||
<display-name>Spring MVC Application</display-name>
|
|
||||||
|
|
||||||
<!-- Spring root -->
|
|
||||||
<context-param>
|
|
||||||
<param-name>contextClass</param-name>
|
|
||||||
<param-value>
|
|
||||||
org.springframework.web.context.support.AnnotationConfigWebApplicationContext
|
|
||||||
</param-value>
|
|
||||||
</context-param>
|
|
||||||
<context-param>
|
|
||||||
<param-name>contextConfigLocation</param-name>
|
|
||||||
<param-value>org.baeldung.config</param-value>
|
|
||||||
</context-param>
|
|
||||||
|
|
||||||
<listener>
|
|
||||||
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
|
|
||||||
</listener>
|
|
||||||
|
|
||||||
<!-- Spring child -->
|
|
||||||
<servlet>
|
|
||||||
<servlet-name>api</servlet-name>
|
|
||||||
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
|
|
||||||
<load-on-startup>1</load-on-startup>
|
|
||||||
</servlet>
|
|
||||||
<servlet-mapping>
|
|
||||||
<servlet-name>api</servlet-name>
|
|
||||||
<url-pattern>/</url-pattern>
|
|
||||||
</servlet-mapping>
|
|
||||||
|
|
||||||
<welcome-file-list>
|
|
||||||
<welcome-file/>
|
|
||||||
</welcome-file-list>
|
|
||||||
|
|
||||||
</web-app>
|
|
|
@ -0,0 +1,16 @@
|
||||||
|
package com.baeldung;
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.springframework.boot.test.context.SpringBootTest;
|
||||||
|
import org.springframework.test.context.junit4.SpringRunner;
|
||||||
|
|
||||||
|
@RunWith(SpringRunner.class)
|
||||||
|
@SpringBootTest
|
||||||
|
public class Spring5ApplicationTests {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void contextLoads() {
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -1,5 +0,0 @@
|
||||||
package org.baeldung.client;
|
|
||||||
|
|
||||||
public interface Consts {
|
|
||||||
int APPLICATION_PORT = 8082;
|
|
||||||
}
|
|
|
@ -1,216 +0,0 @@
|
||||||
package org.baeldung.client;
|
|
||||||
|
|
||||||
import static org.apache.commons.codec.binary.Base64.encodeBase64;
|
|
||||||
import static org.baeldung.client.Consts.APPLICATION_PORT;
|
|
||||||
import static org.hamcrest.CoreMatchers.equalTo;
|
|
||||||
import static org.hamcrest.CoreMatchers.is;
|
|
||||||
import static org.hamcrest.CoreMatchers.notNullValue;
|
|
||||||
import static org.hamcrest.MatcherAssert.assertThat;
|
|
||||||
import static org.junit.Assert.assertTrue;
|
|
||||||
import static org.junit.Assert.fail;
|
|
||||||
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.net.URI;
|
|
||||||
import java.util.Arrays;
|
|
||||||
import java.util.Set;
|
|
||||||
|
|
||||||
import org.baeldung.web.dto.Foo;
|
|
||||||
import org.junit.Before;
|
|
||||||
import org.junit.Test;
|
|
||||||
import org.springframework.http.HttpEntity;
|
|
||||||
import org.springframework.http.HttpHeaders;
|
|
||||||
import org.springframework.http.HttpMethod;
|
|
||||||
import org.springframework.http.HttpStatus;
|
|
||||||
import org.springframework.http.MediaType;
|
|
||||||
import org.springframework.http.ResponseEntity;
|
|
||||||
import org.springframework.http.client.ClientHttpRequestFactory;
|
|
||||||
import org.springframework.http.client.HttpComponentsClientHttpRequestFactory;
|
|
||||||
import org.springframework.web.client.HttpClientErrorException;
|
|
||||||
import org.springframework.web.client.RequestCallback;
|
|
||||||
import org.springframework.web.client.RestTemplate;
|
|
||||||
|
|
||||||
import com.fasterxml.jackson.databind.JsonNode;
|
|
||||||
import com.fasterxml.jackson.databind.ObjectMapper;
|
|
||||||
import com.google.common.base.Charsets;
|
|
||||||
|
|
||||||
public class RestTemplateBasicLiveTest {
|
|
||||||
|
|
||||||
private RestTemplate restTemplate;
|
|
||||||
private static final String fooResourceUrl = "http://localhost:" + APPLICATION_PORT + "/spring-rest/myfoos";
|
|
||||||
|
|
||||||
@Before
|
|
||||||
public void beforeTest() {
|
|
||||||
restTemplate = new RestTemplate();
|
|
||||||
}
|
|
||||||
|
|
||||||
// GET
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void givenResourceUrl_whenSendGetForRequestEntity_thenStatusOk() throws IOException {
|
|
||||||
final ResponseEntity<String> response = restTemplate.getForEntity(fooResourceUrl + "/1", String.class);
|
|
||||||
|
|
||||||
assertThat(response.getStatusCode(), equalTo(HttpStatus.OK));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void givenResourceUrl_whenSendGetForRequestEntity_thenBodyCorrect() throws IOException {
|
|
||||||
final ResponseEntity<String> response = restTemplate.getForEntity(fooResourceUrl + "/1", String.class);
|
|
||||||
|
|
||||||
final ObjectMapper mapper = new ObjectMapper();
|
|
||||||
final JsonNode root = mapper.readTree(response.getBody());
|
|
||||||
final JsonNode name = root.path("name");
|
|
||||||
assertThat(name.asText(), notNullValue());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void givenResourceUrl_whenRetrievingResource_thenCorrect() throws IOException {
|
|
||||||
final Foo foo = restTemplate.getForObject(fooResourceUrl + "/1", Foo.class);
|
|
||||||
|
|
||||||
assertThat(foo.getName(), notNullValue());
|
|
||||||
assertThat(foo.getId(), is(1L));
|
|
||||||
}
|
|
||||||
|
|
||||||
// HEAD, OPTIONS
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void givenFooService_whenCallHeadForHeaders_thenReceiveAllHeadersForThatResource() {
|
|
||||||
final HttpHeaders httpHeaders = restTemplate.headForHeaders(fooResourceUrl);
|
|
||||||
|
|
||||||
assertTrue(httpHeaders.getContentType().includes(MediaType.APPLICATION_JSON));
|
|
||||||
}
|
|
||||||
|
|
||||||
// POST
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void givenFooService_whenPostForObject_thenCreatedObjectIsReturned() {
|
|
||||||
final HttpEntity<Foo> request = new HttpEntity<>(new Foo("bar"));
|
|
||||||
final Foo foo = restTemplate.postForObject(fooResourceUrl, request, Foo.class);
|
|
||||||
assertThat(foo, notNullValue());
|
|
||||||
assertThat(foo.getName(), is("bar"));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void givenFooService_whenPostForLocation_thenCreatedLocationIsReturned() {
|
|
||||||
final HttpEntity<Foo> request = new HttpEntity<>(new Foo("bar"));
|
|
||||||
final URI location = restTemplate.postForLocation(fooResourceUrl, request);
|
|
||||||
assertThat(location, notNullValue());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void givenFooService_whenPostResource_thenResourceIsCreated() {
|
|
||||||
final RestTemplate template = new RestTemplate();
|
|
||||||
|
|
||||||
final HttpEntity<Foo> request = new HttpEntity<>(new Foo("bar"));
|
|
||||||
|
|
||||||
final ResponseEntity<Foo> response = template.exchange(fooResourceUrl, HttpMethod.POST, request, Foo.class);
|
|
||||||
assertThat(response.getStatusCode(), is(HttpStatus.CREATED));
|
|
||||||
final Foo foo = response.getBody();
|
|
||||||
assertThat(foo, notNullValue());
|
|
||||||
assertThat(foo.getName(), is("bar"));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void givenFooService_whenCallOptionsForAllow_thenReceiveValueOfAllowHeader() {
|
|
||||||
final Set<HttpMethod> optionsForAllow = restTemplate.optionsForAllow(fooResourceUrl);
|
|
||||||
final HttpMethod[] supportedMethods = { HttpMethod.GET, HttpMethod.POST, HttpMethod.HEAD };
|
|
||||||
|
|
||||||
assertTrue(optionsForAllow.containsAll(Arrays.asList(supportedMethods)));
|
|
||||||
}
|
|
||||||
|
|
||||||
// PUT
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void givenFooService_whenPutExistingEntity_thenItIsUpdated() {
|
|
||||||
final RestTemplate template = new RestTemplate();
|
|
||||||
final HttpHeaders headers = prepareBasicAuthHeaders();
|
|
||||||
final HttpEntity<Foo> request = new HttpEntity<>(new Foo("bar"), headers);
|
|
||||||
|
|
||||||
// Create Resource
|
|
||||||
final ResponseEntity<Foo> createResponse = template.exchange(fooResourceUrl, HttpMethod.POST, request, Foo.class);
|
|
||||||
|
|
||||||
// Update Resource
|
|
||||||
final Foo updatedInstance = new Foo("newName");
|
|
||||||
updatedInstance.setId(createResponse.getBody().getId());
|
|
||||||
final String resourceUrl = fooResourceUrl + '/' + createResponse.getBody().getId();
|
|
||||||
final HttpEntity<Foo> requestUpdate = new HttpEntity<>(updatedInstance, headers);
|
|
||||||
template.exchange(resourceUrl, HttpMethod.PUT, requestUpdate, Void.class);
|
|
||||||
|
|
||||||
// Check that Resource was updated
|
|
||||||
final ResponseEntity<Foo> updateResponse = template.exchange(resourceUrl, HttpMethod.GET, new HttpEntity<>(headers), Foo.class);
|
|
||||||
final Foo foo = updateResponse.getBody();
|
|
||||||
assertThat(foo.getName(), is(updatedInstance.getName()));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void givenFooService_whenPutExistingEntityWithCallback_thenItIsUpdated() {
|
|
||||||
final RestTemplate template = new RestTemplate();
|
|
||||||
final HttpHeaders headers = prepareBasicAuthHeaders();
|
|
||||||
final HttpEntity<Foo> request = new HttpEntity<>(new Foo("bar"), headers);
|
|
||||||
|
|
||||||
// Create entity
|
|
||||||
ResponseEntity<Foo> response = template.exchange(fooResourceUrl, HttpMethod.POST, request, Foo.class);
|
|
||||||
assertThat(response.getStatusCode(), is(HttpStatus.CREATED));
|
|
||||||
|
|
||||||
// Update entity
|
|
||||||
final Foo updatedInstance = new Foo("newName");
|
|
||||||
updatedInstance.setId(response.getBody().getId());
|
|
||||||
final String resourceUrl = fooResourceUrl + '/' + response.getBody().getId();
|
|
||||||
template.execute(resourceUrl, HttpMethod.PUT, requestCallback(updatedInstance), clientHttpResponse -> null);
|
|
||||||
|
|
||||||
// Check that entity was updated
|
|
||||||
response = template.exchange(resourceUrl, HttpMethod.GET, new HttpEntity<>(headers), Foo.class);
|
|
||||||
final Foo foo = response.getBody();
|
|
||||||
assertThat(foo.getName(), is(updatedInstance.getName()));
|
|
||||||
}
|
|
||||||
|
|
||||||
// DELETE
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void givenFooService_whenCallDelete_thenEntityIsRemoved() {
|
|
||||||
final Foo foo = new Foo("remove me");
|
|
||||||
final ResponseEntity<Foo> response = restTemplate.postForEntity(fooResourceUrl, foo, Foo.class);
|
|
||||||
assertThat(response.getStatusCode(), is(HttpStatus.CREATED));
|
|
||||||
|
|
||||||
final String entityUrl = fooResourceUrl + "/" + response.getBody().getId();
|
|
||||||
restTemplate.delete(entityUrl);
|
|
||||||
try {
|
|
||||||
restTemplate.getForEntity(entityUrl, Foo.class);
|
|
||||||
fail();
|
|
||||||
} catch (final HttpClientErrorException ex) {
|
|
||||||
assertThat(ex.getStatusCode(), is(HttpStatus.NOT_FOUND));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
|
|
||||||
private HttpHeaders prepareBasicAuthHeaders() {
|
|
||||||
final HttpHeaders headers = new HttpHeaders();
|
|
||||||
final String encodedLogPass = getBase64EncodedLogPass();
|
|
||||||
headers.add(HttpHeaders.AUTHORIZATION, "Basic " + encodedLogPass);
|
|
||||||
return headers;
|
|
||||||
}
|
|
||||||
|
|
||||||
private String getBase64EncodedLogPass() {
|
|
||||||
final String logPass = "user1:user1Pass";
|
|
||||||
final byte[] authHeaderBytes = encodeBase64(logPass.getBytes(Charsets.US_ASCII));
|
|
||||||
return new String(authHeaderBytes, Charsets.US_ASCII);
|
|
||||||
}
|
|
||||||
|
|
||||||
private RequestCallback requestCallback(final Foo updatedInstance) {
|
|
||||||
return clientHttpRequest -> {
|
|
||||||
final ObjectMapper mapper = new ObjectMapper();
|
|
||||||
mapper.writeValue(clientHttpRequest.getBody(), updatedInstance);
|
|
||||||
clientHttpRequest.getHeaders().add(HttpHeaders.CONTENT_TYPE, MediaType.APPLICATION_JSON_VALUE);
|
|
||||||
clientHttpRequest.getHeaders().add(HttpHeaders.AUTHORIZATION, "Basic " + getBase64EncodedLogPass());
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
// Simply setting restTemplate timeout using ClientHttpRequestFactory
|
|
||||||
|
|
||||||
ClientHttpRequestFactory getSimpleClientHttpRequestFactory() {
|
|
||||||
final int timeout = 5;
|
|
||||||
final HttpComponentsClientHttpRequestFactory clientHttpRequestFactory = new HttpComponentsClientHttpRequestFactory();
|
|
||||||
clientHttpRequestFactory.setConnectTimeout(timeout * 1000);
|
|
||||||
return clientHttpRequestFactory;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,24 +0,0 @@
|
||||||
package org.baeldung.okhttp;
|
|
||||||
|
|
||||||
import java.io.IOException;
|
|
||||||
|
|
||||||
import okhttp3.Interceptor;
|
|
||||||
import okhttp3.Request;
|
|
||||||
import okhttp3.Response;
|
|
||||||
|
|
||||||
public class DefaultContentTypeInterceptor implements Interceptor {
|
|
||||||
|
|
||||||
private final String contentType;
|
|
||||||
|
|
||||||
public DefaultContentTypeInterceptor(String contentType) {
|
|
||||||
this.contentType = contentType;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Response intercept(Interceptor.Chain chain) throws IOException {
|
|
||||||
|
|
||||||
Request originalRequest = chain.request();
|
|
||||||
Request requestWithUserAgent = originalRequest.newBuilder().header("Content-Type", contentType).build();
|
|
||||||
|
|
||||||
return chain.proceed(requestWithUserAgent);
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,65 +0,0 @@
|
||||||
package org.baeldung.okhttp;
|
|
||||||
|
|
||||||
import static org.baeldung.client.Consts.APPLICATION_PORT;
|
|
||||||
import static org.hamcrest.Matchers.equalTo;
|
|
||||||
import static org.junit.Assert.assertFalse;
|
|
||||||
import static org.junit.Assert.assertThat;
|
|
||||||
|
|
||||||
import java.io.File;
|
|
||||||
import java.io.IOException;
|
|
||||||
|
|
||||||
import okhttp3.Call;
|
|
||||||
import okhttp3.MediaType;
|
|
||||||
import okhttp3.MultipartBody;
|
|
||||||
import okhttp3.OkHttpClient;
|
|
||||||
import okhttp3.Request;
|
|
||||||
import okhttp3.RequestBody;
|
|
||||||
import okhttp3.Response;
|
|
||||||
|
|
||||||
import org.junit.Before;
|
|
||||||
import org.junit.Test;
|
|
||||||
|
|
||||||
public class OkHttpFileUploadingLiveTest {
|
|
||||||
|
|
||||||
private static final String BASE_URL = "http://localhost:" + APPLICATION_PORT + "/spring-rest";
|
|
||||||
|
|
||||||
OkHttpClient client;
|
|
||||||
|
|
||||||
@Before
|
|
||||||
public void init() {
|
|
||||||
client = new OkHttpClient();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void whenUploadFile_thenCorrect() throws IOException {
|
|
||||||
|
|
||||||
final RequestBody requestBody = new MultipartBody.Builder().setType(MultipartBody.FORM).addFormDataPart("file", "file.txt", RequestBody.create(MediaType.parse("application/octet-stream"), new File("src/test/resources/test.txt"))).build();
|
|
||||||
|
|
||||||
final Request request = new Request.Builder().url(BASE_URL + "/users/upload").post(requestBody).build();
|
|
||||||
|
|
||||||
final Call call = client.newCall(request);
|
|
||||||
final Response response = call.execute();
|
|
||||||
|
|
||||||
assertThat(response.code(), equalTo(200));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void whenGetUploadFileProgress_thenCorrect() throws IOException {
|
|
||||||
|
|
||||||
final RequestBody requestBody = new MultipartBody.Builder().setType(MultipartBody.FORM).addFormDataPart("file", "file.txt", RequestBody.create(MediaType.parse("application/octet-stream"), new File("src/test/resources/test.txt"))).build();
|
|
||||||
|
|
||||||
final ProgressRequestWrapper countingBody = new ProgressRequestWrapper(requestBody, (long bytesWritten, long contentLength) -> {
|
|
||||||
|
|
||||||
final float percentage = (100f * bytesWritten) / contentLength;
|
|
||||||
assertFalse(Float.compare(percentage, 100) > 0);
|
|
||||||
});
|
|
||||||
|
|
||||||
final Request request = new Request.Builder().url(BASE_URL + "/users/upload").post(countingBody).build();
|
|
||||||
|
|
||||||
final Call call = client.newCall(request);
|
|
||||||
final Response response = call.execute();
|
|
||||||
|
|
||||||
assertThat(response.code(), equalTo(200));
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,77 +0,0 @@
|
||||||
package org.baeldung.okhttp;
|
|
||||||
|
|
||||||
import static org.baeldung.client.Consts.APPLICATION_PORT;
|
|
||||||
import static org.hamcrest.CoreMatchers.equalTo;
|
|
||||||
import static org.junit.Assert.assertThat;
|
|
||||||
import static org.junit.Assert.fail;
|
|
||||||
|
|
||||||
import java.io.IOException;
|
|
||||||
|
|
||||||
import okhttp3.Call;
|
|
||||||
import okhttp3.Callback;
|
|
||||||
import okhttp3.HttpUrl;
|
|
||||||
import okhttp3.OkHttpClient;
|
|
||||||
import okhttp3.Request;
|
|
||||||
import okhttp3.Response;
|
|
||||||
|
|
||||||
import org.junit.Before;
|
|
||||||
import org.junit.Test;
|
|
||||||
|
|
||||||
public class OkHttpGetLiveTest {
|
|
||||||
|
|
||||||
private static final String BASE_URL = "http://localhost:" + APPLICATION_PORT + "/spring-rest";
|
|
||||||
|
|
||||||
OkHttpClient client;
|
|
||||||
|
|
||||||
@Before
|
|
||||||
public void init() {
|
|
||||||
|
|
||||||
client = new OkHttpClient();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void whenGetRequest_thenCorrect() throws IOException {
|
|
||||||
final Request request = new Request.Builder().url(BASE_URL + "/date").build();
|
|
||||||
|
|
||||||
final Call call = client.newCall(request);
|
|
||||||
final Response response = call.execute();
|
|
||||||
|
|
||||||
assertThat(response.code(), equalTo(200));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void whenGetRequestWithQueryParameter_thenCorrect() throws IOException {
|
|
||||||
final HttpUrl.Builder urlBuilder = HttpUrl.parse(BASE_URL + "/ex/bars").newBuilder();
|
|
||||||
urlBuilder.addQueryParameter("id", "1");
|
|
||||||
|
|
||||||
final String url = urlBuilder.build().toString();
|
|
||||||
|
|
||||||
final Request request = new Request.Builder().url(url).build();
|
|
||||||
|
|
||||||
final Call call = client.newCall(request);
|
|
||||||
final Response response = call.execute();
|
|
||||||
|
|
||||||
assertThat(response.code(), equalTo(200));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void whenAsynchronousGetRequest_thenCorrect() throws InterruptedException {
|
|
||||||
final Request request = new Request.Builder().url(BASE_URL + "/date").build();
|
|
||||||
|
|
||||||
final Call call = client.newCall(request);
|
|
||||||
|
|
||||||
call.enqueue(new Callback() {
|
|
||||||
@Override
|
|
||||||
public void onResponse(Call call, Response response) throws IOException {
|
|
||||||
System.out.println("OK");
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onFailure(Call call, IOException e) {
|
|
||||||
fail();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
Thread.sleep(3000);
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,45 +0,0 @@
|
||||||
package org.baeldung.okhttp;
|
|
||||||
|
|
||||||
import java.io.IOException;
|
|
||||||
|
|
||||||
import org.junit.Before;
|
|
||||||
import org.junit.Test;
|
|
||||||
|
|
||||||
import okhttp3.Call;
|
|
||||||
import okhttp3.OkHttpClient;
|
|
||||||
import okhttp3.Request;
|
|
||||||
import okhttp3.Response;
|
|
||||||
|
|
||||||
public class OkHttpHeaderLiveTest {
|
|
||||||
|
|
||||||
private static final String SAMPLE_URL = "http://www.github.com";
|
|
||||||
|
|
||||||
OkHttpClient client;
|
|
||||||
|
|
||||||
@Before
|
|
||||||
public void init() {
|
|
||||||
|
|
||||||
client = new OkHttpClient();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void whenSetHeader_thenCorrect() throws IOException {
|
|
||||||
Request request = new Request.Builder().url(SAMPLE_URL).addHeader("Content-Type", "application/json").build();
|
|
||||||
|
|
||||||
Call call = client.newCall(request);
|
|
||||||
Response response = call.execute();
|
|
||||||
response.close();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void whenSetDefaultHeader_thenCorrect() throws IOException {
|
|
||||||
|
|
||||||
OkHttpClient clientWithInterceptor = new OkHttpClient.Builder().addInterceptor(new DefaultContentTypeInterceptor("application/json")).build();
|
|
||||||
|
|
||||||
Request request = new Request.Builder().url(SAMPLE_URL).build();
|
|
||||||
|
|
||||||
Call call = clientWithInterceptor.newCall(request);
|
|
||||||
Response response = call.execute();
|
|
||||||
response.close();
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,99 +0,0 @@
|
||||||
package org.baeldung.okhttp;
|
|
||||||
|
|
||||||
import static org.baeldung.client.Consts.APPLICATION_PORT;
|
|
||||||
|
|
||||||
import java.io.File;
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.net.SocketTimeoutException;
|
|
||||||
import java.util.concurrent.Executors;
|
|
||||||
import java.util.concurrent.ScheduledExecutorService;
|
|
||||||
import java.util.concurrent.TimeUnit;
|
|
||||||
|
|
||||||
import okhttp3.Cache;
|
|
||||||
import okhttp3.Call;
|
|
||||||
import okhttp3.OkHttpClient;
|
|
||||||
import okhttp3.Request;
|
|
||||||
import okhttp3.Response;
|
|
||||||
|
|
||||||
import org.junit.Before;
|
|
||||||
import org.junit.Test;
|
|
||||||
import org.slf4j.Logger;
|
|
||||||
import org.slf4j.LoggerFactory;
|
|
||||||
|
|
||||||
public class OkHttpMiscLiveTest {
|
|
||||||
|
|
||||||
private static final String BASE_URL = "http://localhost:" + APPLICATION_PORT + "/spring-rest";
|
|
||||||
private static Logger logger = LoggerFactory.getLogger(OkHttpMiscLiveTest.class);
|
|
||||||
|
|
||||||
OkHttpClient client;
|
|
||||||
|
|
||||||
@Before
|
|
||||||
public void init() {
|
|
||||||
|
|
||||||
client = new OkHttpClient();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test(expected = SocketTimeoutException.class)
|
|
||||||
public void whenSetRequestTimeout_thenFail() throws IOException {
|
|
||||||
final OkHttpClient clientWithTimeout = new OkHttpClient.Builder().readTimeout(1, TimeUnit.SECONDS).build();
|
|
||||||
|
|
||||||
final Request request = new Request.Builder().url(BASE_URL + "/delay/2") // This URL is served with a 2 second delay.
|
|
||||||
.build();
|
|
||||||
|
|
||||||
final Call call = clientWithTimeout.newCall(request);
|
|
||||||
final Response response = call.execute();
|
|
||||||
response.close();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test(expected = IOException.class)
|
|
||||||
public void whenCancelRequest_thenCorrect() throws IOException {
|
|
||||||
final ScheduledExecutorService executor = Executors.newScheduledThreadPool(1);
|
|
||||||
|
|
||||||
final Request request = new Request.Builder().url(BASE_URL + "/delay/2") // This URL is served with a 2 second delay.
|
|
||||||
.build();
|
|
||||||
|
|
||||||
final int seconds = 1;
|
|
||||||
final long startNanos = System.nanoTime();
|
|
||||||
|
|
||||||
final Call call = client.newCall(request);
|
|
||||||
|
|
||||||
// Schedule a job to cancel the call in 1 second.
|
|
||||||
executor.schedule(() -> {
|
|
||||||
|
|
||||||
logger.debug("Canceling call: " + ((System.nanoTime() - startNanos) / 1e9f));
|
|
||||||
call.cancel();
|
|
||||||
logger.debug("Canceled call: " + ((System.nanoTime() - startNanos) / 1e9f));
|
|
||||||
|
|
||||||
}, seconds, TimeUnit.SECONDS);
|
|
||||||
|
|
||||||
logger.debug("Executing call: " + ((System.nanoTime() - startNanos) / 1e9f));
|
|
||||||
final Response response = call.execute();
|
|
||||||
logger.debug("Call completed: " + ((System.nanoTime() - startNanos) / 1e9f), response);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void whenSetResponseCache_thenCorrect() throws IOException {
|
|
||||||
|
|
||||||
final int cacheSize = 10 * 1024 * 1024; // 10 MiB
|
|
||||||
final File cacheDirectory = new File("src/test/resources/cache");
|
|
||||||
final Cache cache = new Cache(cacheDirectory, cacheSize);
|
|
||||||
|
|
||||||
final OkHttpClient clientCached = new OkHttpClient.Builder().cache(cache).build();
|
|
||||||
|
|
||||||
final Request request = new Request.Builder().url("http://publicobject.com/helloworld.txt").build();
|
|
||||||
|
|
||||||
final Response response1 = clientCached.newCall(request).execute();
|
|
||||||
logResponse(response1);
|
|
||||||
|
|
||||||
final Response response2 = clientCached.newCall(request).execute();
|
|
||||||
logResponse(response2);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void logResponse(Response response) throws IOException {
|
|
||||||
|
|
||||||
logger.debug("Response response: " + response);
|
|
||||||
logger.debug("Response cache response: " + response.cacheResponse());
|
|
||||||
logger.debug("Response network response: " + response.networkResponse());
|
|
||||||
logger.debug("Response responseBody: " + response.body().string());
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,85 +0,0 @@
|
||||||
package org.baeldung.okhttp;
|
|
||||||
|
|
||||||
import static org.baeldung.client.Consts.APPLICATION_PORT;
|
|
||||||
import static org.hamcrest.Matchers.equalTo;
|
|
||||||
import static org.junit.Assert.assertThat;
|
|
||||||
|
|
||||||
import java.io.File;
|
|
||||||
import java.io.IOException;
|
|
||||||
|
|
||||||
import okhttp3.Call;
|
|
||||||
import okhttp3.Credentials;
|
|
||||||
import okhttp3.FormBody;
|
|
||||||
import okhttp3.MediaType;
|
|
||||||
import okhttp3.MultipartBody;
|
|
||||||
import okhttp3.OkHttpClient;
|
|
||||||
import okhttp3.Request;
|
|
||||||
import okhttp3.RequestBody;
|
|
||||||
import okhttp3.Response;
|
|
||||||
|
|
||||||
import org.junit.Before;
|
|
||||||
import org.junit.Test;
|
|
||||||
|
|
||||||
public class OkHttpPostingLiveTest {
|
|
||||||
|
|
||||||
private static final String BASE_URL = "http://localhost:" + APPLICATION_PORT + "/spring-rest";
|
|
||||||
private static final String URL_SECURED_BY_BASIC_AUTHENTICATION = "http://browserspy.dk/password-ok.php";
|
|
||||||
|
|
||||||
OkHttpClient client;
|
|
||||||
|
|
||||||
@Before
|
|
||||||
public void init() {
|
|
||||||
|
|
||||||
client = new OkHttpClient();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void whenSendPostRequest_thenCorrect() throws IOException {
|
|
||||||
final RequestBody formBody = new FormBody.Builder().add("username", "test").add("password", "test").build();
|
|
||||||
|
|
||||||
final Request request = new Request.Builder().url(BASE_URL + "/users").post(formBody).build();
|
|
||||||
|
|
||||||
final Call call = client.newCall(request);
|
|
||||||
final Response response = call.execute();
|
|
||||||
|
|
||||||
assertThat(response.code(), equalTo(200));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void whenSendPostRequestWithAuthorization_thenCorrect() throws IOException {
|
|
||||||
final String postBody = "test post";
|
|
||||||
|
|
||||||
final Request request = new Request.Builder().url(URL_SECURED_BY_BASIC_AUTHENTICATION).addHeader("Authorization", Credentials.basic("test", "test")).post(RequestBody.create(MediaType.parse("text/x-markdown; charset=utf-8"), "test post")).build();
|
|
||||||
|
|
||||||
final Call call = client.newCall(request);
|
|
||||||
final Response response = call.execute();
|
|
||||||
|
|
||||||
assertThat(response.code(), equalTo(200));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void whenPostJson_thenCorrect() throws IOException {
|
|
||||||
final String json = "{\"id\":1,\"name\":\"John\"}";
|
|
||||||
|
|
||||||
final RequestBody body = RequestBody.create(MediaType.parse("application/json; charset=utf-8"), "{\"id\":1,\"name\":\"John\"}");
|
|
||||||
final Request request = new Request.Builder().url(BASE_URL + "/users/detail").post(body).build();
|
|
||||||
|
|
||||||
final Call call = client.newCall(request);
|
|
||||||
final Response response = call.execute();
|
|
||||||
|
|
||||||
assertThat(response.code(), equalTo(200));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void whenSendMultipartRequest_thenCorrect() throws IOException {
|
|
||||||
final RequestBody requestBody = new MultipartBody.Builder().setType(MultipartBody.FORM).addFormDataPart("username", "test").addFormDataPart("password", "test")
|
|
||||||
.addFormDataPart("file", "file.txt", RequestBody.create(MediaType.parse("application/octet-stream"), new File("src/test/resources/test.txt"))).build();
|
|
||||||
|
|
||||||
final Request request = new Request.Builder().url(BASE_URL + "/users/multipart").post(requestBody).build();
|
|
||||||
|
|
||||||
final Call call = client.newCall(request);
|
|
||||||
final Response response = call.execute();
|
|
||||||
|
|
||||||
assertThat(response.code(), equalTo(200));
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,29 +0,0 @@
|
||||||
package org.baeldung.okhttp;
|
|
||||||
|
|
||||||
import static org.hamcrest.Matchers.equalTo;
|
|
||||||
import static org.junit.Assert.assertThat;
|
|
||||||
|
|
||||||
import java.io.IOException;
|
|
||||||
|
|
||||||
import org.junit.Test;
|
|
||||||
|
|
||||||
import okhttp3.Call;
|
|
||||||
import okhttp3.OkHttpClient;
|
|
||||||
import okhttp3.Request;
|
|
||||||
import okhttp3.Response;
|
|
||||||
|
|
||||||
public class OkHttpRedirectLiveTest {
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void whenSetFollowRedirects_thenNotRedirected() throws IOException {
|
|
||||||
|
|
||||||
OkHttpClient client = new OkHttpClient().newBuilder().followRedirects(false).build();
|
|
||||||
|
|
||||||
Request request = new Request.Builder().url("http://t.co/I5YYd9tddw").build();
|
|
||||||
|
|
||||||
Call call = client.newCall(request);
|
|
||||||
Response response = call.execute();
|
|
||||||
|
|
||||||
assertThat(response.code(), equalTo(301));
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,73 +0,0 @@
|
||||||
package org.baeldung.okhttp;
|
|
||||||
|
|
||||||
import okhttp3.RequestBody;
|
|
||||||
import okhttp3.MediaType;
|
|
||||||
|
|
||||||
import java.io.IOException;
|
|
||||||
|
|
||||||
import okio.Buffer;
|
|
||||||
import okio.BufferedSink;
|
|
||||||
import okio.ForwardingSink;
|
|
||||||
import okio.Okio;
|
|
||||||
import okio.Sink;
|
|
||||||
|
|
||||||
public class ProgressRequestWrapper extends RequestBody {
|
|
||||||
|
|
||||||
protected RequestBody delegate;
|
|
||||||
protected ProgressListener listener;
|
|
||||||
|
|
||||||
protected CountingSink countingSink;
|
|
||||||
|
|
||||||
public ProgressRequestWrapper(RequestBody delegate, ProgressListener listener) {
|
|
||||||
this.delegate = delegate;
|
|
||||||
this.listener = listener;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public MediaType contentType() {
|
|
||||||
return delegate.contentType();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public long contentLength() throws IOException {
|
|
||||||
return delegate.contentLength();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void writeTo(BufferedSink sink) throws IOException {
|
|
||||||
|
|
||||||
BufferedSink bufferedSink;
|
|
||||||
|
|
||||||
countingSink = new CountingSink(sink);
|
|
||||||
bufferedSink = Okio.buffer(countingSink);
|
|
||||||
|
|
||||||
delegate.writeTo(bufferedSink);
|
|
||||||
|
|
||||||
bufferedSink.flush();
|
|
||||||
}
|
|
||||||
|
|
||||||
protected final class CountingSink extends ForwardingSink {
|
|
||||||
|
|
||||||
private long bytesWritten = 0;
|
|
||||||
|
|
||||||
public CountingSink(Sink delegate) {
|
|
||||||
super(delegate);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void write(Buffer source, long byteCount) throws IOException {
|
|
||||||
|
|
||||||
super.write(source, byteCount);
|
|
||||||
|
|
||||||
bytesWritten += byteCount;
|
|
||||||
listener.onRequestProgress(bytesWritten, contentLength());
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
public interface ProgressListener {
|
|
||||||
|
|
||||||
void onRequestProgress(long bytesWritten, long contentLength);
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,49 +0,0 @@
|
||||||
package org.baeldung.uribuilder;
|
|
||||||
|
|
||||||
import static org.junit.Assert.assertEquals;
|
|
||||||
|
|
||||||
import java.util.Collections;
|
|
||||||
|
|
||||||
import org.junit.Test;
|
|
||||||
import org.springframework.web.util.UriComponents;
|
|
||||||
import org.springframework.web.util.UriComponentsBuilder;
|
|
||||||
|
|
||||||
public class SpringUriBuilderTest {
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void constructUri() {
|
|
||||||
UriComponents uriComponents = UriComponentsBuilder.newInstance().scheme("http").host("www.baeldung.com").path("/junit-5").build();
|
|
||||||
|
|
||||||
assertEquals("http://www.baeldung.com/junit-5", uriComponents.toUriString());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void constructUriEncoded() {
|
|
||||||
UriComponents uriComponents = UriComponentsBuilder.newInstance().scheme("http").host("www.baeldung.com").path("/junit 5").build().encode();
|
|
||||||
|
|
||||||
assertEquals("http://www.baeldung.com/junit%205", uriComponents.toUriString());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void constructUriFromTemplate() {
|
|
||||||
UriComponents uriComponents = UriComponentsBuilder.newInstance().scheme("http").host("www.baeldung.com").path("/{article-name}").buildAndExpand("junit-5");
|
|
||||||
|
|
||||||
assertEquals("http://www.baeldung.com/junit-5", uriComponents.toUriString());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void constructUriWithQueryParameter() {
|
|
||||||
UriComponents uriComponents = UriComponentsBuilder.newInstance().scheme("http").host("www.google.com").path("/").query("q={keyword}").buildAndExpand("baeldung");
|
|
||||||
|
|
||||||
assertEquals("http://www.google.com/?q=baeldung", uriComponents.toUriString());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void expandWithRegexVar() {
|
|
||||||
String template = "/myurl/{name:[a-z]{1,5}}/show";
|
|
||||||
UriComponents uriComponents = UriComponentsBuilder.fromUriString(template).build();
|
|
||||||
uriComponents = uriComponents.expand(Collections.singletonMap("name", "test"));
|
|
||||||
|
|
||||||
assertEquals("/myurl/test/show", uriComponents.getPath());
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,37 +0,0 @@
|
||||||
package org.baeldung.web.controller.mediatypes;
|
|
||||||
|
|
||||||
import com.jayway.restassured.http.ContentType;
|
|
||||||
import org.junit.Test;
|
|
||||||
import org.junit.runner.RunWith;
|
|
||||||
import org.springframework.test.context.ContextConfiguration;
|
|
||||||
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
|
|
||||||
import org.springframework.test.context.support.AnnotationConfigContextLoader;
|
|
||||||
|
|
||||||
import static com.jayway.restassured.RestAssured.given;
|
|
||||||
|
|
||||||
@RunWith(SpringJUnit4ClassRunner.class)
|
|
||||||
@ContextConfiguration(classes = {TestConfig.class}, loader = AnnotationConfigContextLoader.class)
|
|
||||||
public class CustomMediaTypeControllerLiveTest {
|
|
||||||
private static final String URL_PREFIX = "http://localhost:8082/spring-rest";
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void givenServiceEndpoint_whenGetRequestFirstAPIVersion_thenShouldReturn200() {
|
|
||||||
given()
|
|
||||||
.accept("application/vnd.baeldung.api.v1+json")
|
|
||||||
.when()
|
|
||||||
.get(URL_PREFIX + "/public/api/items/1")
|
|
||||||
.then()
|
|
||||||
.contentType(ContentType.JSON).and().statusCode(200);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void givenServiceEndpoint_whenGetRequestSecondAPIVersion_thenShouldReturn200() {
|
|
||||||
given()
|
|
||||||
.accept("application/vnd.baeldung.api.v2+json")
|
|
||||||
.when()
|
|
||||||
.get(URL_PREFIX + "/public/api/items/2")
|
|
||||||
.then()
|
|
||||||
.contentType(ContentType.JSON).and().statusCode(200);
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,42 +0,0 @@
|
||||||
package org.baeldung.web.controller.mediatypes;
|
|
||||||
|
|
||||||
import org.baeldung.config.WebConfig;
|
|
||||||
import org.junit.Before;
|
|
||||||
import org.junit.Test;
|
|
||||||
import org.junit.runner.RunWith;
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.test.context.ContextConfiguration;
|
|
||||||
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
|
|
||||||
import org.springframework.test.context.web.WebAppConfiguration;
|
|
||||||
import org.springframework.test.web.servlet.MockMvc;
|
|
||||||
import org.springframework.test.web.servlet.setup.MockMvcBuilders;
|
|
||||||
import org.springframework.web.context.WebApplicationContext;
|
|
||||||
|
|
||||||
import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.get;
|
|
||||||
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status;
|
|
||||||
|
|
||||||
@RunWith(SpringJUnit4ClassRunner.class)
|
|
||||||
@ContextConfiguration(classes = WebConfig.class)
|
|
||||||
@WebAppConfiguration
|
|
||||||
public class CustomMediaTypeControllerTest {
|
|
||||||
|
|
||||||
private MockMvc mockMvc;
|
|
||||||
|
|
||||||
@Autowired
|
|
||||||
private WebApplicationContext webApplicationContext;
|
|
||||||
|
|
||||||
@Before
|
|
||||||
public void setUp() {
|
|
||||||
mockMvc = MockMvcBuilders.webAppContextSetup(webApplicationContext).build();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void givenServiceUrl_whenGetWithProperAcceptHeaderFirstAPIVersion_thenReturn200() throws Exception {
|
|
||||||
mockMvc.perform(get("/public/api/items/1").accept("application/vnd.baeldung.api.v1+json")).andExpect(status().isOk());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void givenServiceUrl_whenGetWithProperAcceptHeaderSecondVersion_thenReturn200() throws Exception {
|
|
||||||
mockMvc.perform(get("/public/api/items/2").accept("application/vnd.baeldung.api.v2+json")).andExpect(status().isOk());
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,11 +0,0 @@
|
||||||
package org.baeldung.web.controller.mediatypes;
|
|
||||||
|
|
||||||
import org.springframework.context.annotation.ComponentScan;
|
|
||||||
import org.springframework.context.annotation.Configuration;
|
|
||||||
|
|
||||||
|
|
||||||
@Configuration
|
|
||||||
@ComponentScan({ "org.baeldung.web" })
|
|
||||||
public class TestConfig {
|
|
||||||
|
|
||||||
}
|
|
|
@ -1,66 +0,0 @@
|
||||||
package org.baeldung.web.controller.redirect;
|
|
||||||
|
|
||||||
import static org.hamcrest.CoreMatchers.equalTo;
|
|
||||||
import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.get;
|
|
||||||
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.flash;
|
|
||||||
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.forwardedUrl;
|
|
||||||
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.model;
|
|
||||||
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.redirectedUrl;
|
|
||||||
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status;
|
|
||||||
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.view;
|
|
||||||
import static org.springframework.test.web.servlet.setup.MockMvcBuilders.webAppContextSetup;
|
|
||||||
|
|
||||||
import org.junit.Before;
|
|
||||||
import org.junit.Test;
|
|
||||||
import org.junit.runner.RunWith;
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.test.context.ContextConfiguration;
|
|
||||||
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
|
|
||||||
import org.springframework.test.context.web.WebAppConfiguration;
|
|
||||||
import org.springframework.test.web.servlet.MockMvc;
|
|
||||||
import org.springframework.web.context.WebApplicationContext;
|
|
||||||
|
|
||||||
@RunWith(SpringJUnit4ClassRunner.class)
|
|
||||||
@ContextConfiguration("file:src/main/webapp/WEB-INF/api-servlet.xml")
|
|
||||||
@WebAppConfiguration
|
|
||||||
public class RedirectControllerIntegrationTest {
|
|
||||||
|
|
||||||
private MockMvc mockMvc;
|
|
||||||
|
|
||||||
@Autowired
|
|
||||||
protected WebApplicationContext wac;
|
|
||||||
|
|
||||||
@Before
|
|
||||||
public void setup() {
|
|
||||||
mockMvc = webAppContextSetup(wac).build();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void whenRedirectOnUrlWithUsingXMLConfig_thenStatusRedirectionAndRedirectedOnUrl() throws Exception {
|
|
||||||
mockMvc.perform(get("/redirectWithXMLConfig")).andExpect(status().is3xxRedirection()).andExpect(view().name("RedirectedUrl")).andExpect(model().attribute("attribute", equalTo("redirectWithXMLConfig")))
|
|
||||||
.andExpect(redirectedUrl("redirectedUrl?attribute=redirectWithXMLConfig"));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void whenRedirectOnUrlWithUsingRedirectPrefix_thenStatusRedirectionAndRedirectedOnUrl() throws Exception {
|
|
||||||
mockMvc.perform(get("/redirectWithRedirectPrefix")).andExpect(status().is3xxRedirection()).andExpect(view().name("redirect:/redirectedUrl")).andExpect(model().attribute("attribute", equalTo("redirectWithRedirectPrefix")))
|
|
||||||
.andExpect(redirectedUrl("/redirectedUrl?attribute=redirectWithRedirectPrefix"));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void whenRedirectOnUrlWithUsingRedirectAttributes_thenStatusRedirectionAndRedirectedOnUrlAndAddedAttributeToFlashScope() throws Exception {
|
|
||||||
mockMvc.perform(get("/redirectWithRedirectAttributes")).andExpect(status().is3xxRedirection()).andExpect(flash().attribute("flashAttribute", equalTo("redirectWithRedirectAttributes")))
|
|
||||||
.andExpect(model().attribute("attribute", equalTo("redirectWithRedirectAttributes"))).andExpect(model().attribute("flashAttribute", equalTo(null))).andExpect(redirectedUrl("redirectedUrl?attribute=redirectWithRedirectAttributes"));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void whenRedirectOnUrlWithUsingRedirectView_thenStatusRedirectionAndRedirectedOnUrlAndAddedAttributeToFlashScope() throws Exception {
|
|
||||||
mockMvc.perform(get("/redirectWithRedirectView")).andExpect(status().is3xxRedirection()).andExpect(model().attribute("attribute", equalTo("redirectWithRedirectView"))).andExpect(redirectedUrl("redirectedUrl?attribute=redirectWithRedirectView"));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void whenRedirectOnUrlWithUsingForwardPrefix_thenStatusOkAndForwardedOnUrl() throws Exception {
|
|
||||||
mockMvc.perform(get("/forwardWithForwardPrefix")).andExpect(status().isOk()).andExpect(view().name("forward:/redirectedUrl")).andExpect(model().attribute("attribute", equalTo("redirectWithForwardPrefix"))).andExpect(forwardedUrl("/redirectedUrl"));
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
|
@ -1,42 +0,0 @@
|
||||||
package org.baeldung.web.controller.status;
|
|
||||||
|
|
||||||
import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.get;
|
|
||||||
import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status;
|
|
||||||
|
|
||||||
import org.baeldung.config.WebConfig;
|
|
||||||
import org.junit.Before;
|
|
||||||
import org.junit.Test;
|
|
||||||
import org.junit.runner.RunWith;
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
|
||||||
import org.springframework.test.context.ContextConfiguration;
|
|
||||||
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
|
|
||||||
import org.springframework.test.context.web.WebAppConfiguration;
|
|
||||||
import org.springframework.test.web.servlet.MockMvc;
|
|
||||||
import org.springframework.test.web.servlet.setup.MockMvcBuilders;
|
|
||||||
import org.springframework.web.context.WebApplicationContext;
|
|
||||||
|
|
||||||
@RunWith(SpringJUnit4ClassRunner.class)
|
|
||||||
@ContextConfiguration(classes = WebConfig.class)
|
|
||||||
@WebAppConfiguration
|
|
||||||
public class ExampleControllerIntegrationTest {
|
|
||||||
|
|
||||||
private MockMvc mockMvc;
|
|
||||||
|
|
||||||
@Autowired
|
|
||||||
private WebApplicationContext webApplicationContext;
|
|
||||||
|
|
||||||
@Before
|
|
||||||
public void setUp() {
|
|
||||||
mockMvc = MockMvcBuilders.webAppContextSetup(webApplicationContext).build();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void whenGetRequestSentToController_thenReturnsStatusNotAcceptable() throws Exception {
|
|
||||||
mockMvc.perform(get("/controller")).andExpect(status().isNotAcceptable());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void whenGetRequestSentToException_thenReturnsStatusForbidden() throws Exception {
|
|
||||||
mockMvc.perform(get("/exception")).andExpect(status().isForbidden());
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,63 +0,0 @@
|
||||||
package org.baeldung.web.test;
|
|
||||||
|
|
||||||
import static org.hamcrest.Matchers.containsString;
|
|
||||||
import static org.hamcrest.Matchers.equalTo;
|
|
||||||
|
|
||||||
import org.junit.Test;
|
|
||||||
|
|
||||||
import com.jayway.restassured.RestAssured;
|
|
||||||
|
|
||||||
public class RequestMappingLiveTest {
|
|
||||||
private static String BASE_URI = "http://localhost:8082/spring-rest/ex/";
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void givenSimplePath_whenGetFoos_thenOk() {
|
|
||||||
RestAssured.given().accept("text/html").get(BASE_URI + "foos").then().assertThat().body(equalTo("Simple Get some Foos"));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void whenPostFoos_thenOk() {
|
|
||||||
RestAssured.given().accept("text/html").post(BASE_URI + "foos").then().assertThat().body(equalTo("Post some Foos"));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void givenOneHeader_whenGetFoos_thenOk() {
|
|
||||||
RestAssured.given().accept("text/html").header("key", "val").get(BASE_URI + "foos").then().assertThat().body(equalTo("Get some Foos with Header"));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void givenMultipleHeaders_whenGetFoos_thenOk() {
|
|
||||||
RestAssured.given().accept("text/html").headers("key1", "val1", "key2", "val2").get(BASE_URI + "foos").then().assertThat().body(equalTo("Get some Foos with Header"));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void givenAcceptHeader_whenGetFoos_thenOk() {
|
|
||||||
RestAssured.given().accept("application/json").get(BASE_URI + "foos").then().assertThat().body(containsString("Get some Foos with Header New"));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void givenPathVariable_whenGetFoos_thenOk() {
|
|
||||||
RestAssured.given().accept("text/html").get(BASE_URI + "foos/1").then().assertThat().body(equalTo("Get a specific Foo with id=1"));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void givenMultiplePathVariable_whenGetFoos_thenOk() {
|
|
||||||
RestAssured.given().accept("text/html").get(BASE_URI + "foos/1/bar/2").then().assertThat().body(equalTo("Get a specific Bar with id=2 from a Foo with id=1"));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void givenPathVariable_whenGetBars_thenOk() {
|
|
||||||
RestAssured.given().accept("text/html").get(BASE_URI + "bars/1").then().assertThat().body(equalTo("Get a specific Bar with id=1"));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void givenParams_whenGetBars_thenOk() {
|
|
||||||
RestAssured.given().accept("text/html").get(BASE_URI + "bars?id=100&second=something").then().assertThat().body(equalTo("Get a specific Bar with id=100"));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void whenGetFoosOrBars_thenOk() {
|
|
||||||
RestAssured.given().accept("text/html").get(BASE_URI + "advanced/foos").then().assertThat().body(equalTo("Advanced - Get some Foos or Bars"));
|
|
||||||
RestAssured.given().accept("text/html").get(BASE_URI + "advanced/bars").then().assertThat().body(equalTo("Advanced - Get some Foos or Bars"));
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,123 +0,0 @@
|
||||||
package org.baeldung.web.test;
|
|
||||||
|
|
||||||
import static org.hamcrest.Matchers.notNullValue;
|
|
||||||
import static org.junit.Assert.assertThat;
|
|
||||||
|
|
||||||
import java.util.Arrays;
|
|
||||||
|
|
||||||
import org.baeldung.config.converter.KryoHttpMessageConverter;
|
|
||||||
import org.baeldung.web.dto.Foo;
|
|
||||||
import org.baeldung.web.dto.FooProtos;
|
|
||||||
import org.junit.Assert;
|
|
||||||
import org.junit.Test;
|
|
||||||
import org.springframework.http.HttpEntity;
|
|
||||||
import org.springframework.http.HttpHeaders;
|
|
||||||
import org.springframework.http.HttpMethod;
|
|
||||||
import org.springframework.http.MediaType;
|
|
||||||
import org.springframework.http.ResponseEntity;
|
|
||||||
import org.springframework.http.converter.protobuf.ProtobufHttpMessageConverter;
|
|
||||||
import org.springframework.web.client.RestTemplate;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Integration Test class. Tests methods hits the server's rest services.
|
|
||||||
*/
|
|
||||||
public class SpringHttpMessageConvertersLiveTest {
|
|
||||||
|
|
||||||
private static String BASE_URI = "http://localhost:8082/spring-rest/";
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Without specifying Accept Header, uses the default response from the
|
|
||||||
* server (in this case json)
|
|
||||||
*/
|
|
||||||
@Test
|
|
||||||
public void whenRetrievingAFoo_thenCorrect() {
|
|
||||||
final String URI = BASE_URI + "foos/{id}";
|
|
||||||
|
|
||||||
final RestTemplate restTemplate = new RestTemplate();
|
|
||||||
final Foo resource = restTemplate.getForObject(URI, Foo.class, "1");
|
|
||||||
|
|
||||||
assertThat(resource, notNullValue());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void givenConsumingXml_whenReadingTheFoo_thenCorrect() {
|
|
||||||
final String URI = BASE_URI + "foos/{id}";
|
|
||||||
|
|
||||||
final RestTemplate restTemplate = new RestTemplate();
|
|
||||||
|
|
||||||
final HttpHeaders headers = new HttpHeaders();
|
|
||||||
headers.setAccept(Arrays.asList(MediaType.APPLICATION_XML));
|
|
||||||
final HttpEntity<String> entity = new HttpEntity<String>(headers);
|
|
||||||
|
|
||||||
final ResponseEntity<Foo> response = restTemplate.exchange(URI, HttpMethod.GET, entity, Foo.class, "1");
|
|
||||||
final Foo resource = response.getBody();
|
|
||||||
|
|
||||||
assertThat(resource, notNullValue());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void givenConsumingJson_whenReadingTheFoo_thenCorrect() {
|
|
||||||
final String URI = BASE_URI + "foos/{id}";
|
|
||||||
|
|
||||||
final RestTemplate restTemplate = new RestTemplate();
|
|
||||||
|
|
||||||
final HttpHeaders headers = new HttpHeaders();
|
|
||||||
headers.setAccept(Arrays.asList(MediaType.APPLICATION_JSON));
|
|
||||||
final HttpEntity<String> entity = new HttpEntity<String>(headers);
|
|
||||||
|
|
||||||
final ResponseEntity<Foo> response = restTemplate.exchange(URI, HttpMethod.GET, entity, Foo.class, "1");
|
|
||||||
final Foo resource = response.getBody();
|
|
||||||
|
|
||||||
assertThat(resource, notNullValue());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void givenConsumingXml_whenWritingTheFoo_thenCorrect() {
|
|
||||||
final String URI = BASE_URI + "foos/{id}";
|
|
||||||
final RestTemplate restTemplate = new RestTemplate();
|
|
||||||
|
|
||||||
final Foo resource = new Foo(4, "jason");
|
|
||||||
final HttpHeaders headers = new HttpHeaders();
|
|
||||||
headers.setAccept(Arrays.asList(MediaType.APPLICATION_JSON));
|
|
||||||
headers.setContentType((MediaType.APPLICATION_XML));
|
|
||||||
final HttpEntity<Foo> entity = new HttpEntity<Foo>(resource, headers);
|
|
||||||
|
|
||||||
final ResponseEntity<Foo> response = restTemplate.exchange(URI, HttpMethod.PUT, entity, Foo.class, resource.getId());
|
|
||||||
final Foo fooResponse = response.getBody();
|
|
||||||
|
|
||||||
Assert.assertEquals(resource.getId(), fooResponse.getId());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void givenConsumingProtobuf_whenReadingTheFoo_thenCorrect() {
|
|
||||||
final String URI = BASE_URI + "foos/{id}";
|
|
||||||
|
|
||||||
final RestTemplate restTemplate = new RestTemplate();
|
|
||||||
restTemplate.setMessageConverters(Arrays.asList(new ProtobufHttpMessageConverter()));
|
|
||||||
final HttpHeaders headers = new HttpHeaders();
|
|
||||||
headers.setAccept(Arrays.asList(ProtobufHttpMessageConverter.PROTOBUF));
|
|
||||||
final HttpEntity<String> entity = new HttpEntity<String>(headers);
|
|
||||||
|
|
||||||
final ResponseEntity<FooProtos.Foo> response = restTemplate.exchange(URI, HttpMethod.GET, entity, FooProtos.Foo.class, "1");
|
|
||||||
final FooProtos.Foo resource = response.getBody();
|
|
||||||
|
|
||||||
assertThat(resource, notNullValue());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void givenConsumingKryo_whenReadingTheFoo_thenCorrect() {
|
|
||||||
final String URI = BASE_URI + "foos/{id}";
|
|
||||||
|
|
||||||
final RestTemplate restTemplate = new RestTemplate();
|
|
||||||
restTemplate.setMessageConverters(Arrays.asList(new KryoHttpMessageConverter()));
|
|
||||||
final HttpHeaders headers = new HttpHeaders();
|
|
||||||
headers.setAccept(Arrays.asList(KryoHttpMessageConverter.KRYO));
|
|
||||||
final HttpEntity<String> entity = new HttpEntity<String>(headers);
|
|
||||||
|
|
||||||
final ResponseEntity<Foo> response = restTemplate.exchange(URI, HttpMethod.GET, entity, Foo.class, "1");
|
|
||||||
final Foo resource = response.getBody();
|
|
||||||
|
|
||||||
assertThat(resource, notNullValue());
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
|
@ -1,13 +0,0 @@
|
||||||
*.class
|
|
||||||
|
|
||||||
#folders#
|
|
||||||
/target
|
|
||||||
/neoDb*
|
|
||||||
/data
|
|
||||||
/src/main/webapp/WEB-INF/classes
|
|
||||||
*/META-INF/*
|
|
||||||
|
|
||||||
# Packaged files #
|
|
||||||
*.jar
|
|
||||||
*.war
|
|
||||||
*.ear
|
|
|
@ -1 +0,0 @@
|
||||||
hello world
|
|
Loading…
Reference in New Issue