java调用phantomjs实现网页截图

记一次淘宝详情页面图片生成

背景

公司最近会在天猫上开店,会显示很多商品,商品量巨大且非标准,商品信息详情页美工一张一张做,工作量太大。所以就调研了一下如何用程序生成图片,并且截图,用以实现批量化(毕竟我们程序员就是干这个的)商品详情页大概如下:


商品详情demo
商品详情demo

调研

调研么,无非对着目标寻找方案,并验证可行性。在最开始的时候,明确了任务核心,第一个是数据渲染,第二个是截图。数据渲染没什么说的,基本都是通过动态模板生成html。第二个是截图,这个试了很多方案,最开始的时候试了下html2image这个java第三方包,它最后采用的是java原生的swing。超级丑,尤其表格。然后呢,之前在公司写过一段时间selenium自动化测试,记得它可以截图。然后验证一番,发现它的确可以做到截图,但是有两个确定,第一它截全屏有点问题,第二就是它依赖于浏览器。百度selenium截图。最终在度娘的指导下,发现了一款神器phantomjs

image.png

你可以理解为提供了一些api的无头浏览器。简单搜索了下,大家最常用的就是将它用来作为爬虫。

Demo(代码很随意)

调研差不了,写个demo 把步骤穿起来,验证其可行性。

/**
 * 生成图片
 */
public class MainTest{


    public static void main(String[] args) throws IOException, TemplateException {
        //获取数据,根据模板生成图片
        FreemarkerTest.main(null);
        //调用phantomjs脚本截图
        PhantomjsTest.main(null);
        //调用java 裁剪图片
        TailorTest.main(null);
    }
}

第一步

获取数据,通过freeMaker模板,生成html页面。

/**
 * 用来生成静态html
 */
public class FreemarkerTest {

    public static void main(String args[]) throws IOException, TemplateException {

        //这里只是简单地拼接数据,真实场景下应该调用服务获取需要的数据
        MealDetail mealDetail = new MealDetail();
        mealDetail.setName("你好啊");
        ExamItem examItem = new ExamItem();
        examItem.setName("项目1");
        examItem.setDescription("这个是体检项目1啊");

        ExamItem examItem1 = new ExamItem();
        examItem1.setName("项目2");
        examItem1.setDescription("这个是体检项目2啊");
        List<ExamItem> list = Lists.newArrayList();
        list.add(examItem);
        list.add(examItem1);
        mealDetail.setItemList(list);

        Configuration configuration = new Configuration(Configuration.VERSION_2_3_23);
        configuration.setDirectoryForTemplateLoading(new File("/Users/king/Desktop"));
        //这个就是freeMaker的模板文件,很简单就是把上面那个数据展示出来
        Template template = configuration.getTemplate("meal.ftl");


        //生成html
        File file = new File("/Users/king/meal.html");
        if (!file.exists()) {
            file.createNewFile();
        }
        //设置输出流
        FileWriter out = new FileWriter(file);
        //模板输出静态文件
        template.process(mealDetail, out);
    }
}
第二步

java 调用phantomjs执行脚本,打开第一步中生成的图片,截图保存。
下面是phantomjs官网截图的示例。

var page = require('webpage').create();
//第一个参数,可以传递进来需要截图的路径
page.open('http://example.com', function(status) {
  console.log("Status: " + status);
  if(status === "success") {
    //截图 图片名称。可以选择图片质量
    page.render('example.png');
  }
  phantom.exit();
});

java 调用phantomjs

/**
 * Created by king on 2017/9/6.
 */
public class PhantomjsTest {

    public static void main(String[] args) throws IOException {
        Runtime rt = Runtime.getRuntime();
        //这里的url 换成上一步生成的html文件路径
        String url = "file///:/Users/king/demo.html";
       //java 调用phantomjs执行脚本,传入需要截图的url。这里的phantomjs可以添加的环境bin下,或者在程序目录
        Process p = rt.exec("phantomjs /Users/king/Desktop/dem2.js" +url);
        InputStream is = p.getInputStream();
        BufferedReader br = new BufferedReader(new InputStreamReader(is));
        StringBuffer sbf = new StringBuffer();
        String tmp = "";
        while((tmp = br.readLine())!=null){
            sbf.append(tmp);
        }
        //System.out.println(sbf.toString());
    }
}

第三步
java 裁剪生成的图片

/**
 * 图片裁剪
 */
public class TailorTest {

    public static void main(String[] args) throws IOException {
       //打开刚刚生成的图片
        BufferedImage bufferedImage = ImageIO.read(new File("meal.png"));
        int width = bufferedImage.getWidth();
        int height = bufferedImage.getHeight();
        System.out.println("图片的宽度为"+width+",高度为"+height);
       //截图,这里可以根据需要各种裁剪
        BufferedImage subimage = bufferedImage.getSubimage(0, 0, 400, 870);
        File file = new File("meal3.png"); 
       //生成一张新的图片
        ImageIO.write(subimage,"PNG",file);

    }
}

第四部
以上,一个demo 就完成了。其中有很多细节,需要实施的时候再进行优化。其中需要注意的地方是。phantomjs执行环境需要在官网下载,java只是调用phantomjs执行环境去执行js脚本。你可以下载到项目目录里面,方便任何地方使用。

总结

做一个方案调研的时候,需要确定自己的目标,或者将自己的目标简单地拆解,有可能拆的不对,但是一定要确保大体方向。然后只需要替换不同步骤的实施即可。当然,本文的重点多是java 调用phantomjs截图。好吧,只是我记下我一次任务的记录。这里是项目地址:屎一样的demo

可以参考的链接
phantomjs官网
百度selenium,这个超级强大
百度html2image,这个也不错

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,864评论 6 494
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,175评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,401评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,170评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,276评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,364评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,401评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,179评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,604评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,902评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,070评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,751评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,380评论 3 319
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,077评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,312评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,924评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,957评论 2 351

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,918评论 25 707
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,074评论 4 62
  • 文章出处,感谢作者的无私奉献 前言 前阵子遇到一个需求,微信小程序的某一个界面,需要屏幕截图,然后分享出去。但小程...
    code追命阅读 7,181评论 3 2
  • 晚上看了古典老师写的这篇:学点心理学技巧,帮你跳出“定计划又做不完”的死循环https://mp.weixin.q...
    江嫚青阅读 170评论 0 0
  • 作者:康卫军 文章:你是一个聪明的投资者吗? 链接:你是一个聪明的投资者吗? 点评:王雪梅 看到康书记的文,赶紧交...
    苏醒7阅读 158评论 0 0