[nodeJS] PDF-LIB 한글폰트 사용(Error: WinAnsi cannot encode ) > javascript
javascript

[nodeJS] PDF-LIB 한글폰트 사용(Error: WinAnsi cannot encode )

조회 2,089회 댓글 0건

백엔드의 PDF-LIB에서 폰트를 지정하지 않으면 오류가 발생 합니다.

영문은 문제 되지 않지만 한글의 경우 오류를 만나게 됩니다.

그렇기 때문에 커스텀 폰드를 지정해야 하는데 스탠다드폰트가 아닌 별도 폰트를 사용할 때 필요한 부분입니다.


Error: WinAnsi cannot encode "한" 

이러한 오류를 만나게 된다면 한글을 사용할 수 없는 폰트이기 때문입니다.


 
  import { PDFDocument, StandardFonts, rgb } from 'pdf-lib'

  // Cannot import fontkit from @pdf-lib/fontkit
  // Error [ERR_MODULE_NOT_FOUND]: Cannot find package '@pdf-lib/fontkit' imported from
  import fontkit from '@pdf-lib/fontkit'
  import fs from "fs";

  async function createPdf()
  {
    const pdfDoc    = await PDFDocument.create();

    // Error: WinAnsi cannot encode "한"
    const fontfile  = '/www/fonts/NanumGothic.ttf';
    if ( fs.existsSync(fontfile) )
    {
      const fontBytes = fs.readFileSync(fontfile);
      let customFont;
      if (fontBytes) {
        pdfDoc.registerFontkit(fontkit);
        await pdfDoc.embedFont(fontBytes);
        customFont = await pdfDoc.embedFont(fontBytes);
      }  

      const page = pdfDoc.addPage()
      const { width, height } = page.getSize()
      const fontSize = 20
      page.drawText('Creating PDFs in JavaScript is awesome! - 한글', {
        x: 50,
        y: height - 4 * fontSize,
        size: fontSize,
        font: customFont,
        color: rgb(20, 30.53, 0.71),
      });
    }
    const pdfBytes = await pdfDoc.save()

    let file = '/www/pdf/result/test1.pdf';
    if ( fs.existsSync(file) ) {
      fs.unlinkSync(file);
    }
    fs.writeFileSync(file, pdfBytes);
    let aStats    = fs.statSync(file)
    let filesize  = aStats.size;
    console.log('write pdf file: ', file);

  }
 


[nodeJS] PDF-LIB 한글폰트 사용(Error: WinAnsi cannot encode )
 

텍스트를 지정하고 병합된 결과를 PDF 파일로 저장하는 예제 입니다.

높은 버전의 PDF 파일까지 지원이 되기 때문에 사용할만한 PDF 라이브러리 중 하나 입니다.


● 참고자료

  https://pdf-lib.js.org/#examples

  https://pdf-lib.js.org/docs/api/classes/pdffont

  https://pdf-lib.js.org/docs/api/interfaces/embedfontoptions#index

  https://pdf-lib.js.org/docs/api/classes/pdfdocument#registerfontkit

  https://www.npmjs.com/package/@pdf-lib/fontkit

  https://github.com/Hopding/pdf-lib/issues/548



  • 페이스북으로 공유
  • 트위터로  공유
  • 구글플러스로 공유
전체 98건 1 페이지
  • profile_image 자바와 자바스크립트는 직접적인 관계는 없습니다. 다만 문법이 C계열인 정도 인데 의미는 없습니다.의미가 없다는 의미는 자바스크립트 할줄 하는 개발자가 자바를 다르지 못하고 반대도 그렇다고 봐야 합니다.* 이런 생각도 가능!!  - 스크립트(SCRIPT) 비교적(프로그램에 비해) 간단한 형태를 말함  - JAVA + SCRIPT = 자바로 만들어진 스크립트?그런데 같은 줄 아는 사람이 있는 경우는 왜? 그런가사람이 모르는 것을 접할 때 기본적으로 생각하는 방향에 따라 생각 하는 것일 뿐입니다.즉, 사람들이 Java와 JavaScript를 같은 것으로 오해하는 이유는 주로 인지적 작용과 언어적 연상에서 기인 하는 것이다. …
  • profile_image 중복된 처리를 제외하고자 할때 일정 부분 쿠키로 가지고 있다가 비교해서 동일한 것은 처리 하지 않기 위한것입니다.이것을 쿠키를 이용하는 방법이 있고 요즘은 로컬스토리지를 이용하는 방법도 있겠습니다. 특정 게시물의 번호나. 방문자의 로그를 저장하여 처리 하는 경우는 중복 처리 방지를 위한 간단한 방식 입니다.게시물의 경우 중복제외 처리를 하지 않으면 들쑥 날쑥 하지만 최고 30% 넘게 차이나는 경우도 있었습니다.  <!DOCTYPE html>  <html>  <head>      <title>Click Event Test</title>  </head>  &l…
  • profile_image 블로그에 있는 datepicker는  안되는것이 많아서 사용할 일이 있어서 완성한것 올립니다.jquery는 버전이 다르면 안될 수 있으니 버전을 맞우는것이 중요하며 아래 순서도 중요합니다.jquery를 이용하기 때문에 jquery-ui가 아래에 있어야 한다는 것입니다. 그리고 jquery-ui 압축 파일을 받으면 아래와 같이 CDN 이용하지 않고 사이트에 올려 놓고 사용할 수 있으며 압축 파일 안에 아래 cdn 링크 걸린 모든 파일과 더불어 필요한 다른 파일들도 같이 모두 들어 있습니다. 같이 사용되는 jquery 도 별도 디렉토리에 있습니다.△ 아래 달력 datepicker(데이트티커)minDate 사용하면 적용한 이…
  • profile_image Node Express는 Node.js와 Express.js를 결합하여 웹 애플리케이션 개발에 사용되는 프레임워크입니다. 이를 통해 비동기적인 서버 측 코드 작성과 HTTP 요청 및 응답 처리 등 다양한 웹 개발 작업을 보다 쉽게 처리할 수 있습니다.  1) 간단하게 띄울 프로그램을 하나 준비 서버가 잘 작동하는지 확인을 할 수 있는 간단한 프로그램을 준비 하도록 합니다.자신이 하는것이 디비커넥션이 들어가게 되면 이 부분도 간단하게 CRUD 프로그램 하나 준비 하면 됩니다.  const express = require('express');  const app     = express();  const port    = …
  • profile_image -g 옵션을 주어 글로벌로 설치한것이 아닌데 현재 디렉토리에 node_modules이 없고 다른곳에 설치 된경우는 아래처럼 초기화하면 package.json 파일이 생성 되고 현재 디렉토리에 node_modules 디렉토리가 생기면서 설치 됩니다. 아래와 같이 초기화 후 설치 하면 됩니다.  npm init -y  npm install express 그리고 초기화 했는데 안되는 경우는 시스템 로그인할때 홈 디렉토리나 또는 기본적으로 있어야할 스크립트 등이 없는 경우는 아닌지 살펴 보면 됩니다.예를 들면 bash shell의 경우 로그인 하면서 실행 되는 스크립트 들이 있습니다. 파일명은 .(점) 으로 시작하기 때문에 숨…
  • profile_image 실제 파일은 있는데 없는다는 메시지가 나올 경우는 PATH 설정 값을 확인해 봐야 합니다.만약 whereis env 했는데 있다면 로그인할 때 실행되는 파일에 PATH 설정을 추가해 주면 됩니다./usr/local/nodejs/bin/npm install yarn/usr/bin/env: node: 그런 파일이나 디렉터리가 없습니다위와 같은 오류가 발생 하는 경우는 경로를 추가해 주면 된다.vim /etc/bashrcexport PATH=$PATH:/usr/local/nodejs/bin이 경우는 nodejs를 압축파일을 받아서 별도의 디렉토리에 압축을 풀고 심복릴 링크 처리한 경우 입니다.
  • profile_image 프로그래머가 아니라 일반인이면 PDF 페이지번호 추가해주는 사이트가 있으니 아래를 참고하시면 됩니다.https://tools.pdf24.org/ko/add-page-numbers#s=1687481961009여기선 nodejs와 pdf-lib 설치에 대해선 언급하지 않습니다.아래는 간단한 소스 입니다.PDF파일에 페이지 번호가 없어서 인쇄하는데 있어 페이지수가 적으면 문제가 안되지만 수십페이지만 되어도 읽을때 문제가 될 수 있습니다. 페이지가 바뀐다거나 아니면 인쇄할때 잘못되어 중간부터 인쇄할때 몇페이지 부터 인쇄해야 될지 찾는데 시간이 소요 될 수 있는 문제를 해결하려면 페이지번호가 들어가 있는것이 좋습니다.  /** …