HTTP/HTTPS-Verbindungen für dedizierte Ausgangs-IP-Adressen und VPN

HTTP/HTTPS-Verbindungen werden automatisch aus AEM as a Cloud Service mit dedizierter Ausgangs-IP-Adresse oder VPN bereitgestellt und benötigen keine speziellen portForwards-Regeln.

Erweiterte Netzwerkunterstützung

Das folgende Code-Beispiel wird von den folgenden erweiterten Netzwerkoptionen unterstützt.

Vergewissern Sie sich, dass die erweiterte Netzwerkkonfiguration ( dedizierte Ausgangs-IP-Adresse oder VPN) eingerichtet wurde, bevor Sie dieses Tutorial durchführen.

Keine erweiterten Netzwerkfunktionen
Flexibler Port-Ausgang
Dedizierte Ausgangs-IP-Adresse
Virtuelles privates Netzwerk
CAUTION
Dieses Code-Beispiel gilt nur für dedizierte Ausgangs-IP-Adressen und VPN. Ein ähnliches, aber anderes Code-Beispiel ist für HTTP/HTTPS-Verbindungen auf nicht standardmäßigen Ports für flexible Port-Ausgänge verfügbar.

Code-Beispiel

Dieses Java™-Code-Beispiel zeigt einen OSGi-Dienst, der in AEM as a Cloud Service ausgeführt werden kann und eine HTTP-Verbindung zu einem externen Web-Server auf 8080 herstellt. Die HTTPS- (oder HTTP-) Verbindungen werden von AEM as a Cloud Service automatisch bereitgestellt und erfordern keine spezielle Entwicklung.

NOTE
Es wird empfohlen, die Java™ 11-HTTP-APIs zu verwenden, um HTTP/HTTPS-Aufrufe von AEM aus durchzuführen.
  • core/src/com/adobe/aem/wknd/examples/connections/impl/HttpExternalServiceImpl.java
package com.adobe.aem.wknd.examples.core.connections.impl;

import com.adobe.aem.wknd.examples.core.connections.ExternalService;
import org.osgi.service.component.annotations.Component;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import java.io.IOException;
import java.net.URI;
import java.net.http.HttpClient;
import java.net.http.HttpRequest;
import java.net.http.HttpResponse;
import java.time.Duration;

@Component
public class HttpExternalServiceImpl implements ExternalService {
    private static final Logger log = LoggerFactory.getLogger(HttpExternalServiceImpl.class);

    // client with connection pool reused for all requests
    private HttpClient client = HttpClient.newBuilder().build();

    @Override
    public boolean isAccessible() {

        // Prepare the full URI to request, note this will have the
        // - Scheme (http/https)
        // - External host name
        // - External port
        // The external service URI, including the scheme/host/port, is defined in code, rather than in Cloud Manager portForwards rules.
        URI uri = URI.create("http://api.example.com:8080/test.json");

        // Prepare the HttpRequest
        HttpRequest request = HttpRequest.newBuilder().uri(uri).timeout(Duration.ofSeconds(2)).build();

        // Send the HttpRequest using the configured HttpClient
        HttpResponse<String> response = null;
        try {
            // Request the URL
            response = client.send(request, HttpResponse.BodyHandlers.ofString());

            log.debug("HTTP response body: {} ", response.body());

            // Our simple example returns true is response is successful! (200 status code)
            return response.statusCode() == 200;
        } catch (IOException e) {
            return false;
        } catch (InterruptedException e) {
            return false;
        }
    }
}
recommendation-more-help
4859a77c-7971-4ac9-8f5c-4260823c6f69