>  기사  >  웹 프론트엔드  >  nodejs를 pdf로

nodejs를 pdf로

WBOY
WBOY원래의
2023-05-23 12:27:071749검색

인터넷이 발전함에 따라 쉽게 인쇄하고 공유하고 저장하기 위해 점점 더 많은 웹 페이지를 PDF 파일로 변환해야 합니다. Node.js의 출현으로 서버 측에서 실행할 수 있는 환경이 제공되어 웹 페이지를 PDF 파일로 변환하는 것이 더욱 편리하고 효율적이게 되었습니다. 이 문서에서는 Node.js를 사용하여 웹 페이지를 PDF 파일로 변환하는 방법을 설명합니다.

1. Node.js 및 관련 모듈 설치

Node.js를 사용하여 웹 페이지를 PDF 파일로 변환하려면 먼저 컴퓨터에 Node.js 환경을 설치해야 합니다. Node.js는 공식 홈페이지(https://nodejs.org/)에서 다운로드하여 설치할 수 있습니다.

Node.js를 설치한 후 일부 관련 모듈을 설치해야 합니다.

  1. Express: 웹 애플리케이션 개발 프레임워크를 제공합니다.
  2. Puppeteer: 헤드리스 Chrome 제어를 위해 Google에서 개발한 Node.js 라이브러리입니다.

다음 명령을 통해 명령줄 도구에 설치할 수 있습니다:

npm install express puppeteer

2. 코드 작성

Node.js 및 관련 모듈을 설치한 후 코드 작성을 시작합니다. 다음은 웹 페이지가 브라우저에 로드될 때 자동으로 PDF 파일로 변환하는 간단한 Express 애플리케이션입니다.

const express = require('express')
const puppeteer = require('puppeteer')

const app = express()
const port = 3000

app.get('/', async (req, res) => {
  const browser = await puppeteer.launch()
  const page = await browser.newPage()
  await page.goto('https://www.example.com')
  const pdf = await page.pdf()
  res.contentType("application/pdf")
  res.send(pdf)
  await browser.close()
})

app.listen(port, () => {
  console.log(`Server running at http://localhost:${port}`)
})

이 애플리케이션은 Express 프레임워크를 사용하여 웹 서버를 생성하고 Puppeteer 라이브러리를 사용하여 웹 페이지를 PDF 파일로 변환합니다. 브라우저를 열고 http://localhost:3000을 입력하면 변환된 PDF 파일을 볼 수 있습니다.

3. 매개변수 설정

Puppeteer 라이브러리는 웹 페이지를 PDF 파일로 변환하는 과정에서 페이지 크기, 여백, 머리글/바닥글, 크기 조정 및 페이징 등과 같은 다양한 매개 변수를 사용자 정의하도록 설정할 수 있습니다. 일반적으로 사용되는 일부 매개변수 설정은 다음과 같습니다.

  1. 형식: 웹페이지의 페이지 형식. A4, Letter 등과 같은 표준 페이지 형식으로 설정하거나 사용자 정의 페이지 크기로 설정할 수 있습니다.
  2. margin: 웹페이지의 여백입니다. 위쪽 여백, 아래쪽 여백, 왼쪽 여백, 오른쪽 여백 등을 설정할 수 있습니다.
  3. headerTemplate/footerTemplate: 머리글과 바닥글을 설정할 수 있는 HTML 템플릿입니다. 템플릿에 페이지라는 클래스 이름의 요소를 추가하고 변환된 페이지 번호를 추가할 수 있습니다.
  4. displayHeaderFooter: 머리글과 바닥글 표시 여부를 설정할 수 있습니다. 표시하려면 true로 설정하고, 표시하지 않으려면 false로 설정하세요.
  5. 배율: 출력 PDF 파일에 맞게 웹 페이지의 배율 비율을 설정할 수 있습니다.
  6. pageRanges: 여러 페이지로 구성된 문서의 변환에 맞게 변환해야 하는 페이지 번호 범위를 설정할 수 있습니다. 예를 들어, pageRanges: '1-10'은 1페이지부터 10페이지까지의 콘텐츠만 변환된다는 의미입니다.

다음은 웹 페이지를 PDF 파일로 변환할 때 일부 매개변수를 설정하는 예입니다.

const express = require('express')
const puppeteer = require('puppeteer')

const app = express()
const port = 3000

app.get('/', async (req, res) => {
  const browser = await puppeteer.launch()
  const page = await browser.newPage()
  await page.goto('https://www.example.com')

  const pdf = await page.pdf({
    format: 'A4',
    margin: {
      top: '20mm',
      right: '20mm',
      bottom: '20mm',
      left: '20mm'
    },
    displayHeaderFooter: true,
    headerTemplate: '<div class="page-number"></div>',
    footerTemplate:
      '<div class="page-number"></div>',
    scale: 0.8
  })

  res.contentType("application/pdf")
  res.send(pdf)
  await browser.close()
})

app.listen(port, () => {
  console.log(`Server running at http://localhost:${port}`)
})

이 애플리케이션은 A4 페이지 형식, 20mm 여백, 표시 머리글 및 바닥글, 머리글 및 바닥글 템플릿, 0.8배 확대/축소 비율 및 1~10페이지만 포함하도록 출력 PDF 파일을 제어합니다.

4. 요약

Node.js를 사용하여 웹 페이지를 PDF 파일로 변환하는 것은 매우 편리하고 효율적입니다. Puppeteer 라이브러리는 헤드리스 Chrome에 대한 완벽한 제어 기능을 제공하므로 다양한 요구 사항에 맞게 페이지 크기, 여백, 머리글/바닥글, 크기 조정 및 페이징 등을 쉽게 제어할 수 있습니다. 이 기사의 소개를 통해 독자들은 웹 페이지를 PDF 파일로 변환하는 과정을 어느 정도 이해하고 실제로 지속적으로 개선하고 최적화할 수 있다고 믿습니다.

위 내용은 nodejs를 pdf로의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.