整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:

使用Qtwebkit和PHP将HTML转换为PDF

使用Qtwebkit和PHP将HTML转换为PDF

khtmltopdf是一个非常有用的应用程序,用于从html(网页)创建pdf。本篇文章将介绍关于如何使用php脚本和Linux命令行工具创建网页的pdf。



步骤1:在Linux中安装wkhtmltopdf

从google code下载wkhtmltopdf并安装到Linux系统。

# cd /opt

# wget https://wkhtmltopdf.googlecode.com/files/wkhtmltopdf-0.9.9-static-i386.tar.bz2

# tar xjf wkhtmltopdf-0.9.9-static-i386.tar.bz2

# mv wkhtmltopdf-i386 /usr/bin/wkhtmltopdf

# chown apache:apache /usr/bin/wkhtmltopdf

# chmod +x /usr/bin/wkhtmltopdf

步骤2:使用命令行创建PDF

首先检查wkhtmltopdf脚本,它在命令行中正常工作。下面的命令将创建http://google.com网页的pdf。

# /usr/bin/wkhtmltopdf http://google.com google.pdf

步骤3:使用wkhtmltopdf创建pdf的php代码

使用下面的PHP代码块从HTML(网页)生成PDF。此脚本需要为Apache启用shell_exec函数。大多数共享主机不允许此函数。

使用下面的代码创建一个文件名getpdf.php,并将其放到网站文档根目录中。

<?php

$url=$_GET['url']; // Website URL to Create pdf

$name=$_GET['pdf']; // Output pdf name

$command="/usr/bin/wkhtmltopdf ";

$pdf_dir="/var/www/html/pdfs/"; // Pdf files will be saved here

$ex_cmd="$command $url " . $pdf_dir . $name;

$output=shell_exec($ex_cmd);

?>

打开以下网址生成网站的pdf(html)。

语法:http:

//youdomain.com/getPdf.php?url=<website url>&pdf=<pdf name>

示例:

https : //tecadmin.net/getPdf.php?url=http : //google.com&pdf=google.pdf

本篇文章到这里就已经全部结束了,更多其他精彩内容可以关注的Linux视频教程栏目!

以上就是使用Qtwebkit和PHP将HTML转换为PDF的详细内容,更多请关注其它相关文章!

更多技巧请《转发 + 关注》哦!

# 一、前言

本人写Qt程序这么多年,比较喜欢支持多个Qt版本,尤其是钟情于支持任意Qt版本+任意系统+任意编译器,这句话说起来简单其实实现起来就不容易了,首先你得有个很多版本的测试环境,起码十几个Qt环境要的吧,四五种操作系统要的吧,还要安装各种VS版本免不了的,毕竟win上除了默认的mingw编译器还有很多人用的是msvc编译器,这么一大堆环境折腾下来,没有个1T硬盘是不够的,而且官网发布Qt版本的速度相当快,最慢半年肯定来一个版本,又得测试了,每次发布一个大的版本,除了常用的windows以外,linux要测试吧,而且现在还多出来一些国产linux系统比如deepin new start UOS之类的,也要试试吧,哎呀好累。

下面是部分代码:

//公用初始化浏览器控件配置
void WebHelper::initWebSetting()
{
    //全局配置只需要设置一次就行
    static bool isInit=false;
    if (!isInit) {
        isInit=true;
#ifdef webkit
        QWebSettings *webSetting=QWebSettings::globalSettings();
        webSetting->setAttribute(QWebSettings::JavascriptEnabled, true);
        webSetting->setAttribute(QWebSettings::PluginsEnabled, true);
        webSetting->setAttribute(QWebSettings::JavascriptCanOpenWindows, true);
#elif webengine
        QWebEngineSettings *webSetting=QWebEngineSettings::globalSettings();
        webSetting->setAttribute(QWebEngineSettings::JavascriptEnabled, true);
        webSetting->setAttribute(QWebEngineSettings::PluginsEnabled, true);
        webSetting->setAttribute(QWebEngineSettings::JavascriptCanOpenWindows, true);
#endif
    }
}

//通用浏览器组件加载
void frmMapBoundary::loadMap(bool tool)
{
    QString content;
    QString fileName=QString("%1/map_web.html").arg(AppPath);
    QString url="file:///" + fileName;

    baidu->reset();
    baidu->setMapZoom(10);
    baidu->setShowOverlayTool(tool);

    //设置默认的中心点坐标,建议采用中心点坐标的方式
    baidu->setMapCenterPoint("121.414,31.1828");

    //如果采用加载内容方式则需要先设置不存储文件
    //ie内核以及在linux上需要用load的方式加载
    //发现 Qt5.5 webkit 也需要用文件加载
#ifdef savehtmlfile
    baidu->setSaveFile(true);
#else
    baidu->setSaveFile(false);
#endif

    baidu->setFileName(fileName);
    content=baidu->newMap();

    //下面为两种方式加载网页,如果内容为空则加载网页文件否则加载内容
    //一般为了保密建议加载内容,这样看不到生成的网页文件
    //可能在linux上的webkit内核需要用load的方式加载
    if (baidu->getSaveFile()) {
#if (defined webkit) || (defined webengine)
        webView->load(QUrl(url));
#elif webie
        webView->dynamicCall("Navigate(const QString&)", url);
#endif
    } else {
        QUrl baseUrl(QString("%1/").arg(AppPath));
#if (defined webkit) || (defined webengine)
        webView->setHtml(content, baseUrl);
#endif
    }
}

//通用数据交互类
//需要自定义继承自QObject的类来接收QWebEngineView交互数据,不然会打印很多烦人的信息
class WebJsData : public QObject
{
    Q_OBJECT
public:
    static WebJsData *Instance();
    explicit WebJsData(QObject *parent=0);

public slots:
    //定义两个参数,这样就涵盖了所有的情况 type表示类型相当于唯一标识
    void receiveData(const QString &type, const QVariant &data);

signals:
    void receiveDataFromJs(const QString &type, const QVariant &data);
};

WebJsData *WebJsData::Instance()
{
    static WebJsData self;
    return &self;
}

WebJsData::WebJsData(QObject *parent)
{
}

void WebJsData::receiveData(const QString &type, const QVariant &data)
{
    //可以在这里重新梳理好再发出去信号
    emit receiveDataFromJs(type, data);
}

## 二、功能特点

1. 同时支持在线地图和离线地图两种模式。

2. 同时支持webkit内核、webengine内核、IE内核。

3. 支持设置多个标注点,信息包括名称、地址、经纬度。

4. 可设置地图是否可单击、拖动、鼠标滚轮缩放。

5. 可设置协议版本、秘钥、主题样式、中心坐标、中心城市、地理编码位置等。

6. 可设置地图缩放比例和级别,缩略图、比例尺、路况信息等控件的可见。

7. 支持地图交互,比如鼠标按下获取对应位置的经纬度。

8. 支持查询路线,可设置起点位置、终点位置、路线模式、路线方式、路线方案(最少时间、最少换乘、最少步行、不乘地铁、最短距离、避开高速)。

9. 可显示点线面工具,可直接在地图上划线、点、矩形、圆形等。

10. 可设置行政区划,指定某个城市区域绘制图层,在线地图自动输出行政区划边界点集合到js文件给离线地图使用。

11. 可静态或者动态添加多个覆盖物。支持点、折线、多边形、矩形、圆形、弧线、点聚合等。

12. 函数接口友好和统一,使用简单方便,就一个类。

13. 支持js动态交互添加点、删除点、清空点、重置点,不需要刷新页面。

14. 支持任意Qt版本、任意系统、任意编译器。

## 三、体验地址

国内站点:[https://gitee.com/feiyangqingyun](https://gitee.com/feiyangqingyun)

国际站点:[https://github.com/feiyangqingyun](https://github.com/feiyangqingyun)

## 四、效果图

# 一、前言

跨平台着实花了不少的精力,为了从Qt4.7兼容到Qt6.2及后续版本,头发掉了不少,仅有的几根毛所剩无几,哎,可能这就是程序员的命,本人写Qt程序这么多年,比较喜欢支持多个Qt版本,尤其是钟情于支持任意Qt版本+任意系统+任意编译器,这句话说起来简单其实实现起来就不容易了,首先你得有个很多版本的测试环境,起码十几个Qt环境要的吧,四五种操作系统要的吧,还要安装各种VS版本免不了的,毕竟win上除了默认的mingw编译器还有很多人用的是msvc编译器,这么一大堆环境折腾下来,没有个1T硬盘是不够的,而且官网发布Qt版本的速度相当快,最慢半年肯定来一个版本,又得测试了,每次发布一个大的版本,除了常用的windows以外,linux要测试吧,而且现在还多出来一些国产linux系统比如deepin new start UOS之类的,也要试试吧,哎呀好累。

## 二、功能特点

### 1 省市区域地图封装类功能特点

1. 同时支持闪烁点图、迁徙图、区域地图、世界地图、仪表盘等。

2. 可以设置标题、提示信息、背景颜色、文字颜色、线条颜色、区域颜色等各种颜色。

3. 可设置城市的名称、值、经纬度 集合。

4. 可设置地图的放大倍数、是否允许鼠标滚轮缩放。

5. 内置世界地图、全国地图、省份地图、地区地图,可以精确到县,所有地图全部离线使用。

6. 内置了各省市json数据文件转js文件功能,如有数据更新自行转换即可,支持单个文件转换和一键转换所有文件。

7. 内置了从json文件或者js文件获取该区域的所有名称和经纬度信息集合的功能,可以通过该方法获取到信息用来显示。

8. 依赖浏览器组件显示地图,提供的demo支持webkit/webengine/miniblink/ie 多种方式加载网页。

9. 采用miniblink浏览器内核打通了Qt5.6及后续版本+mingw编译器缺少浏览器模块的遗憾,使得整个项目支持所有Qt版本,亲测4.7到6.2等任意版本。

10. 闪烁点迁徙图等设置的点支持单独设置颜色。

11. 提供接口直接获取点击的点相关信息,方便程序联动处理。

12. 拓展性极强,可以依葫芦画瓢自行增加各种精美的echarts组件,做出牛逼的效果。

13. 内置的仪表盘组件提供交互功能,demo演示中包含了对应的代码。

14. 函数接口友好和统一,使用简单方便,就一个类。

15. 支持任意Qt版本、任意系统、任意编译器。

### 2 百度地图封装类功能特点

1. 同时支持在线地图和离线地图两种模式。

2. 同时支持webkit内核、webengine内核、miniblink内核、IE内核。

3. 支持设置多个标注点,信息包括名称、地址、经纬度。

4. 可设置地图是否可单击、拖动、鼠标滚轮缩放。

5. 可设置协议版本、秘钥、主题样式、中心坐标、中心城市、地理编码位置等。

6. 可设置地图缩放比例和级别,缩略图、比例尺、路况信息等控件的可见。

7. 支持地图交互,比如鼠标按下获取对应位置的经纬度。

8. 支持查询路线,可设置起点位置、终点位置、路线模式、路线方式、路线方案(最少时间、最少换乘、最少步行、不乘地铁、最短距离、避开高速)。

9. 可显示点线面工具,可直接在地图上划线、点、矩形、圆形等。

10. 可设置行政区划,指定某个城市区域绘制图层,在线地图自动输出行政区划边界点集合到js文件给离线地图使用。

11. 可静态或者动态添加多个覆盖物。支持点、折线、多边形、矩形、圆形、弧线、点聚合等。

12. 提供函数接口处理经纬度解析成地址和地址解析成经纬度坐标。

13. 提供的demo直接可以单独选点执行对应的处理比如路线查询。

14. 可以拿到路线查询到的点坐标信息集合,比如用于机器人坐标导航等。

15. 封装了丰富的函数比如删除指定点和所有点,删除指定覆盖物和所有覆盖物等。

16. 标注点弹框信息可以自定义内容,标准html格式。

17. 标注点单击事件可选 0-不处理 1-自己弹框 2-发送信号。

18. 标注点可设置动画效果 0-不处理 1-跳动 2-坠落

19. 标注点可设置本地图片文件等。

20. 函数接口友好和统一,使用简单方便,就一个类。

21. 支持js动态交互添加点、删除点、清空点、重置点,不需要刷新页面。

22. 支持任意Qt版本、任意系统、任意编译器。

### 3 离线地图下载类功能特点

1. 多线程同步下载多级别瓦片地图,不卡界面。

2. 内置多个离线地图下载请求地址,自动随机选择一个发送请求。

3. 下载地图类型同时支持街道图和卫星图。

4. 自动计算可视区域或者行政区域的下载瓦片数量。

5. 下载的级别可以自定义范围和选择。

6. 每个瓦片下载完成都发送信号通知,参数包括下载用时。

7. 可设置下载最大超时时间,超过了则丢弃跳到下一个下载任务。

8. 实时显示下载进度,以及当前级别已经下载的瓦片数和总瓦片数。

9. 下载过程中可以停止下载,下载完成自动统计总用时。

10. 内置经纬度和屏幕坐标互相转换函数。

11. 目前支持百度地图,其他地图比如谷歌地图、腾讯地图、高德地图可以定制。

12. 函数接口友好和统一,使用简单方便,就一个类。

13. 支持任意Qt版本、任意系统、任意编译器。

### 4 省市轮廓下载类功能特点

1. 定时器排队下载省市轮廓图点坐标集合存储到JS文件。

2. 支持一个行政区域多个不规则区域下载。

3. 自动计算行政区域的下载轮廓数量。

4. 可精确选择省份、市区、县城,也可直接输入行政区域的名称。

5. 可以设置下载间隔、随时开始下载和停止下载。

6. 提供编辑边界功能,可以直接在地图上编辑好不规则区域的点集合,然后获取边界点集合数据,这个可以用来自己绘制区域拿到数据,比如某个乡镇甚至某个小区的行政区域数据,很牛逼。

## 三、体验地址

1. 体验地址:[https://pan.baidu.com/s/1ZxG-oyUKe286LPMPxOrO2A](https://pan.baidu.com/s/1ZxG-oyUKe286LPMPxOrO2A) 提取码:o05q 文件名:bin_map.zip

2. 国内站点:[https://gitee.com/feiyangqingyun](https://gitee.com/feiyangqingyun)

3. 国际站点:[https://github.com/feiyangqingyun](https://github.com/feiyangqingyun)

4. 个人主页:[https://blog.csdn.net/feiyangqingyun](https://blog.csdn.net/feiyangqingyun)

5. 知乎主页:[https://www.zhihu.com/people/feiyangqingyun/](https://www.zhihu.com/people/feiyangqingyun/)

## 四、效果图

## 五、相关代码