>Java >java지도 시간 >Java에서 PhantomJS를 사용하여 HTML 페이지 스크린샷 기능을 구현하는 방법은 무엇입니까?

Java에서 PhantomJS를 사용하여 HTML 페이지 스크린샷 기능을 구현하는 방법은 무엇입니까?

王林
王林앞으로
2023-04-24 11:37:151427검색

I. 배경

미니 프로그램에서 사진을 생성하고 모멘트에 공유하는 방법은 무엇인가요? 현재로서는 프론트엔드에 대한 좋은 해결책이 없는 것 같습니다. 그래서 백엔드에서만 지원될 수 있습니다. 그러면 어떻게 재생할 수 있습니까?

그림 생성은 비교적 간단합니다.

간단한 장면은 jdk에서 직접 지원할 수 있습니다. 일반적으로 말하면 너무 복잡한 논리는 없습니다.

전에 awt를 사용하여 그림 합성 논리를 작성했습니다: 그림 합성

Universal, 복잡한 템플릿

은 단순한 것이라면 직접 지원할 수 있지만, 더 복잡한 경우 백엔드에서 지원한다면 의심할 여지 없이 역겨운 일이 될 것입니다. 또한 github에서 HTML을 렌더링하기 위한 일부 오픈 소스 라이브러리도 검색해 보았습니다. 잘못된 자세 때문인지는 모르겠지만 결과는 만족스럽습니다

이제 복잡한 템플릿을 지원하는 방법은 무엇인가요?

이 기사의 가이드는 html 렌더링을 구현하는 것입니다. PDF 생성, 그림 생성 및 DOM 구문 분석을 지원합니다. 다음으로 phantomjs를 결합하여 웹 페이지를 이미지로 렌더링하는 서비스를 구축하는 방법을 보여 드리겠습니다.

II. 전제조건 준비

1. phantom.js 설치

# 1. 下载
## mac 系统
wget https://bitbucket.org/ariya/phantomjs/downloads/phantomjs-2.1.1-macosx.zip
## linux 系统
wget https://bitbucket.org/ariya/phantomjs/downloads/phantomjs-2.1.1-linux-x86_64.tar.bz2
## windows 系统
## 就不要玩了,没啥意思
# 2. 解压
sudo su 
tar -jxvf phantomjs-2.1.1-linux-x86_64.tar.bz2
# 如果解压报错,则安装下面的
# yum -y install bzip2
# 3. 安装
## 简单点,移动到bin目录下
cp phantomjs-2.1.1-linux-x86_64/bin/phantomjs /usr/local/bin
# 4. 验证是否ok
phantomjs --version
# 输出版本号,则表示ok
2. Java 종속성 구성

종속성 추가를 위한 Maven 구성

<!--phantomjs -->
<dependency>
  <groupid>org.seleniumhq.selenium</groupid>
  <artifactid>selenium-java</artifactid>
  <version>2.53.1</version>
</dependency>
<dependency>
  <groupid>com.github.detro</groupid>
  <artifactid>ghostdriver</artifactid>
  <version>2.1.0</version>
</dependency>
<repositories>
  <repository>
    <id>jitpack.io</id>
    <url>https://jitpack.io</url>
  </repository>
</repositories>
Start

주로 phantomjs를 호출하여 html 렌더링 이미지를 구현하는 로직은 다음과 같습니다.

public class Html2ImageByJsWrapper {
  private static PhantomJSDriver webDriver = getPhantomJs();
  private static PhantomJSDriver getPhantomJs() {
    //设置必要参数
    DesiredCapabilities dcaps = new DesiredCapabilities();
    //ssl证书支持
    dcaps.setCapability("acceptSslCerts", true);
    //截屏支持
    dcaps.setCapability("takesScreenshot", true);
    //css搜索支持
    dcaps.setCapability("cssSelectorsEnabled", true);
    //js支持
    dcaps.setJavascriptEnabled(true);
    //驱动支持(第二参数表明的是你的phantomjs引擎所在的路径,which/whereis phantomjs可以查看)
    // fixme 这里写了执行, 可以考虑判断系统是否有安装,并获取对应的路径 or 开放出来指定路径
    dcaps.setCapability(PhantomJSDriverService.PHANTOMJS_EXECUTABLE_PATH_PROPERTY, "/usr/local/bin/phantomjs");
    //创建无界面浏览器对象
    return new PhantomJSDriver(dcaps);
  }
  public static BufferedImage renderHtml2Image(String url) throws IOException {
    webDriver.get(url);
    File file = webDriver.getScreenshotAs(OutputType.FILE);
    return ImageIO.read(file);
  }
}
테스트 사례

public class Base64Util {
  public static String encode(BufferedImage bufferedImage, String imgType) throws IOException {
    ByteArrayOutputStream outputStream = new ByteArrayOutputStream();
    ImageIO.write(bufferedImage, imgType, outputStream);
    return encode(outputStream);
  }
  public static String encode(ByteArrayOutputStream outputStream) {
    return Base64.getEncoder().encodeToString(outputStream.toByteArray());
  }
}
@Test
public void testRender() throws IOException {
  BufferedImage img = null;
  for (int i = 0; i  <p>III. 네트워크 실제 측정<strong></strong></p>작동 시연:<p></p><p><img src="https://img.php.cn/upload/article/000/465/014/168230743789738.gif" alt="Java에서 PhantomJS를 사용하여 HTML 페이지 스크린샷 기능을 구현하는 방법은 무엇입니까?"></p>

위 내용은 Java에서 PhantomJS를 사용하여 HTML 페이지 스크린샷 기능을 구현하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 yisu.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제