如何在 Azure 功能中运行 IronPDF for Java

This article was translated from English: Does it need improvement?
Translated
View the article in English

  • IronPDF for Java 仅支持 Docker 部署。
  • 不支持压缩部署,因为 IronPDF 需要在运行时执行二进制文件。

  1. 按照使用自定义映像在 Linux 上创建函数的微软官方指南

    • 选择编程语言 -> 选择 Java

    • 按照指南操作,直到您的应用程序启动并运行。
  2. 添加IronPDF依赖

    • 将此添加到您的pom中,使用最新的`
    <dependencies>
        <dependency>
                <groupId>com.ironsoftware</groupId>
                <artifactId>ironpdf</artifactId>
                <version>2022.xx.x</version>
            </dependency>
            <dependency>
                <groupId>com.ironsoftware</groupId>
                <artifactId>ironpdf-engine-linux-x64</artifactId>
                <version>2022.xx.x</version>
            </dependency>
        </dependencies>
XML
  • 注意:在 Docker 中运行 IronPDF 必须安装 ironpdf-engine-linux
  1. 添加RenderPdf函数

    • Function.java中添加一个新功能。

    • 该函数将接收 URL 并返回渲染后的 PDF。
    public class Function {

    //...
    @FunctionName("RenderPdf")
    public HttpResponseMessage renderPdf(
            @HttpTrigger(
                    name = "req",
                    methods = {HttpMethod.GET, HttpMethod.POST},
                    authLevel = AuthorizationLevel.ANONYMOUS)
            HttpRequestMessage<Optional<String>> request,
            final ExecutionContext context) {
        context.getLogger().info("Java HTTP trigger processed a request. (RenderPdf)");
        // Parse query parameter
        final String url = request.getQueryParameters().get("url");
        if (url == null) {
            return request.createResponseBuilder(HttpStatus.BAD_REQUEST).body("Please pass a url on the query string").build();
        } else {
            context.getLogger().info("IronPDF try to render url: " + url);
            PdfDocument pdfDocument = com.ironsoftware.ironpdf.PdfDocument.renderUrlAsPdf(url);
            byte [] content = pdfDocument.getBinaryData();
            return request.createResponseBuilder(HttpStatus.OK)
                    .body(content)
                    .header("Content-Disposition", "attachment; filename=ironpdf_result.pdf")
                    .build();
        }
    }
    }
JAVA
  1. 更新 Dockerfile

    • 添加 IronPDF Linux 所需的包。

    从示例来看,基础 Docker 映像是 mcr.microsoft.com/azure-functions/java:4-java$JAVA_VERSION-build,即 Debian 11

    因此,我们需要将这些软件包添加到 Docker 文件中。

   RUN apt update \
   && apt install -y libgdiplus libxkbcommon-x11-0 libc6 libc6-dev libgtk2.0-0 libnss3 libatk-bridge2.0-0 libx11-xcb1 libxcb-dri3-0 libdrm-common libgbm1 libasound2 libxrender1 libfontconfig1 libxshmfence1
   RUN apt-get install -y xvfb libva-dev libgdiplus
  1. 将您的函数重新部署到 Azure

    1. 构建与打包 mvn clean package

    2. 构建 Docker 镜像,例如 docker build --tag <DOCKER_ID>/azurefunctionsimage:v1.0.0 .

    3. 将 Docker 镜像推送,例如 docker push <DOCKER_ID>/azurefunctionsimage:v1.0.0

    4. 更新 Azure 函数,例如 az functionapp create --name <APP_NAME> --storage-account <STORAGE_NAME> --resource-group AzureFunctionsContainers-rg --plan myPremiumPlan --deployment-container-image-name <DOCKER_ID>/azurefunctionsimage:v1.0.0
  2. 享受IronPDF

    • 在以下位置触发功能:https://<APP_NAME>.azurewebsites.net/api/RenderPdf?url=https://www.google.com.

    • 注意:首次触发函数时,可能会由于初始化而导致速度变慢或失败,但之后就不会有问题了。