先看看抓取的结果。

8个Java类:

    • Startup.java - main函数
    • ImageCrawler.java - Crawler基类
    • BaiduImageCrawler.java - 百度图片的具体爬取实现
    • GoogleImageCrawler.java - Google图片的具体爬取实现
    • BingImageCrawler.java - Bing图片的具体爬取实现
    • ImageWorker.java - 定时从Queue中取图片URL下载(默认开启100个)
    • ImageDownloader.java - 图片下载
    • MD5Checksum.java - 文件MD5计算(文件去重)
  1. public class BaiduImageCrawler extends ImageCrawler {
  2. //tn:resultjsonavatarnew
  3. //ie:utf-8 字符编码(ie输入 oe输出)
  4. //word:美女 搜索关键字
  5. //pn:60 开始条数
  6. //rn:30 显示数量
  7. //z:0 尺寸(0全部尺寸 9特大 3大 2中 1小)
  8. //width:1024 自定义尺寸-宽
  9. //height:768 自定义尺寸-高
  10. //ic:0 颜色(0全部颜色 1红色 2黄色 4绿色 8青色 16蓝色 32紫色 64粉色 128棕色 256橙色 512黑色 1024白色 2048黑白)
  11. //s:0 3头像图片
  12. //face:0 1面部特写
  13. //st:-1 -1全部类型 1卡通画 2简笔画
  14. //lm:-1 (6动态图片 7静态图片)
  15. //gsm:3c pn值的十六进制数
  16. private static final String BAIDU_IMAGE_SEARCH_URL = "http://image.baidu.com/search/avatarjson?tn=resultjsonavatarnew&ie=utf-8&word=%s&pn=%d&rn=%d&z=3&ic=0&s=0&face=0&st=-1&lm=-1&gsm=%s";
  17. private static final int PAGE_SIZE = 60;
  18. private static final String IMAGE_URL_REG = "\"objURL\":\"(https?://[^\"]+)\"";
  19. private static final Pattern IMAGE_PATTERN = Pattern.compile(IMAGE_URL_REG);
  20. @Override
  21. public String getSearchUrl(String keyword, int page) {
  22. int begin = page * PAGE_SIZE;
  23. return String.format(BAIDU_IMAGE_SEARCH_URL, keyword, begin, PAGE_SIZE, Integer.toHexString(begin));
  24. }
  25. @Override
  26. public int parseImageUrl(ConcurrentLinkedQueue<String> queue, StringBuffer data) {
  27. int count = 0;
  28. Matcher matcher = IMAGE_PATTERN.matcher(data);
  29. while (matcher.find()) {
  30. queue.offer(matcher.group(1));
  31. count++;
  32. }
  33. return count;
  34. }
  35. }
  1. public class GoogleImageCrawler extends ImageCrawler {
  2. //tbm=isch
  3. //q=美女 搜索关键字
  4. //ijn=0 页码(***Google只提供到0到8页数据!)
  5. //start=0 开始条数
  6. //tbs=isz:l 搜索条件
  7. //  尺寸
  8. //  tbs=isz:l 大
  9. //  tbs=isz:m 中
  10. //  颜色
  11. //  tbs=ic:color 彩色
  12. //  tbs=ic:gray 黑白
  13. //  tbs=ic:trans 透明
  14. //  类型
  15. //  tbs=itp:face 脸部特写
  16. //  tbs=itp:photo 照片
  17. //  tbs=itp:clipart 剪贴画
  18. //  tbs=itp:lineart 素描画
  19. //  tbs=itp:animated 动画
  20. //  条件组合
  21. //  tbs=isz:l,ic:color,itp:face
  22. private static final String GOOGLE_IMAGE_SEARCH_URL = "https://www.google.com/search?tbm=isch&q=%s&ijn=%d&start=%d&tbs=isz:l";
  23. private static final int PAGE_SIZE = 100;
  24. private static final String IMAGE_URL_REG = "\"ou\":\"(https?://[^\"]+)\"";
  25. private static final Pattern IMAGE_PATTERN = Pattern.compile(IMAGE_URL_REG);
  26. @Override
  27. public String getSearchUrl(String keyword, int page) {
  28. int begin = page * PAGE_SIZE;
  29. return String.format(GOOGLE_IMAGE_SEARCH_URL, keyword, page, begin);
  30. }
  31. @Override
  32. public int parseImageUrl(ConcurrentLinkedQueue<String> queue, StringBuffer data) {
  33. int count = 0;
  34. Matcher matcher = IMAGE_PATTERN.matcher(data);
  35. while (matcher.find()) {
  36. queue.offer(matcher.group(1));
  37. count++;
  38. }
  39. return count;
  40. }
  41. }
    1. public class BingImageCrawler extends ImageCrawler {
    2. //async=content
    3. //q=美女 搜索关键字
    4. //first=118 开始条数
    5. //count=35 显示数量
    6. private static final String BING_IMAGE_SEARCH_URL = "http://www.bing.com/images/async?async=content&q=%s&first=%d&count=%d";
    7. private static final int PAGE_SIZE = 35;
    8. private static final String IMAGE_URL_REG = "imgurl:&quot;(https?://[^,]+)&quot;";
    9. private static final Pattern IMAGE_PATTERN = Pattern.compile(IMAGE_URL_REG);
    10. @Override
    11. public String getSearchUrl(String keyword, int page) {
    12. int begin = page * PAGE_SIZE;
    13. return String.format(BING_IMAGE_SEARCH_URL, keyword, begin, PAGE_SIZE);
    14. }
    15. @Override
    16. public int parseImageUrl(ConcurrentLinkedQueue<String> queue, StringBuffer data) {
    17. int count = 0;
    18. Matcher matcher = IMAGE_PATTERN.matcher(data);
    19. while (matcher.find()) {
    20. queue.offer(matcher.group(1));
    21. count++;
    22. }
    23. return count;
    24. }
    25. }

Java爬取 百度图片Google图片Bing图片的更多相关文章

  1. JAVA爬取百度贴吧图片

    package com.wang.xiaowei.utils; import com.sun.image.codec.jpeg.JPEGCodec; import com.sun.image.code ...

  2. 使用python爬取百度贴吧内的图片

    1. 首先通过urllib获取网页的源码 # 定义一个getHtml()函数 def getHtml(url): try: page = urllib.urlopen(url) # urllib.ur ...

  3. Python 爬虫练习: 爬取百度贴吧中的图片

    背景:最近开始看一些Python爬虫相关的知识,就在网上找了一些简单已与练习的一些爬虫脚本 实现功能:1,读取用户想要爬取的贴吧 2,读取用户先要爬取某个贴吧的页数范围 3,爬取每个贴吧中用户输入的页 ...

  4. java爬取百度首页源代码

    爬虫感觉挺有意思的,写一个最简单的抓取百度首页html代码的程序.虽然简单了一点,后期会加深的. package test; import java.io.BufferedReader; import ...

  5. 百度图片爬虫-python版-如何爬取百度图片?

    上一篇我写了如何爬取百度网盘的爬虫,在这里还是重温一下,把链接附上: http://www.cnblogs.com/huangxie/p/5473273.html 这一篇我想写写如何爬取百度图片的爬虫 ...

  6. python 3 爬取百度图片

    python 3 爬取百度图片 学习了:https://blog.csdn.net/X_JS612/article/details/78149627

  7. Python 爬虫实例(1)—— 爬取百度图片

    爬取百度图片  在Python 2.7上运行 #!/usr/bin/env python # -*- coding: utf-8 -*- # @Author: loveNight import jso ...

  8. Python爬虫实例(一)爬取百度贴吧帖子中的图片

    程序功能说明:爬取百度贴吧帖子中的图片,用户输入贴吧名称和要爬取的起始和终止页数即可进行爬取. 思路分析: 一.指定贴吧url的获取 例如我们进入秦时明月吧,提取并分析其有效url如下 http:// ...

  9. selenium+chrome浏览器驱动-爬取百度图片

    百度图片网页中中,当页面滚动到底部,页面会加载新的内容. 我们通过selenium和谷歌浏览器驱动,执行js,是浏览器不断加载页面,通过抓取页面的图片路径来下载图片. from selenium im ...

随机推荐

  1. Codeforces475D - CGCDSSQ

    Portal Description 给出长度为\(n(n\leq10^5)\)的序列\(\{a_n\}\),给出\(q(q\leq3\times10^5)\)个\(x\),对于每个\(x\),求满足 ...

  2. 在SpringBoot中使用FluentValidator验证插件

    前言 在我们编写项目的时候,在controller中往往离不开对一些数据的校验.这里并不是说对于这些数据业务上面的校验,而是对这些数据进行空校验或者是长度校验等. 有些时候校验可以省略,根据业务的需要 ...

  3. elasticsearch-5.1.1使用snapshot接口备份索引

    如果ES是集群,那么需要使用共享存储,支持的存储有:a.shared file systemb.S3c.HDFS 我使用的是第一种,NFS共享文件系统.这里要说一下权限问题,ES一般是使用 elast ...

  4. 64位Kali无法顺利执行pwn1问题的解决方案

    问题描述 ​ 环境:VMware Fusion + kali-linux-2018.1-amd64.iso ​ 问题:在Terminal利用./pwn1执行pwn1会出现 bash: ./pwn1:没 ...

  5. shell脚本基础 循环机构

    循环结构 for循环格式一格式:for 变量 in 值1 值2 ........(值不一定是数字,可以是命令或者其他的)do 命令done [root@ceshiji ~]# vim a.sh #!/ ...

  6. probabilistic robotics_Kalman filter(一)

    码农生活告一段落,继续.... 多元正态分布 协方差矩阵,为正定对称矩阵.det表示行列式 协方差反应随机样本变量各分量之间的相关性. 当变量的假设模型不一致时,不适合用高斯滤波. 叠加高斯噪声的线性 ...

  7. Android Scheme协议与应用全解析

    URL Scheme 的作用 客户端应用可以向操作系统注册一个 URL Scheme,该 Scheme 用于从浏览器或其他应用中启动本应用. 通过指定的 URL 字段,可以让应用在被调起后直接打开某些 ...

  8. Android WebView编程的那些坑(一)

    最大的坑是ROM不同,webkit不同,差异性很大.再加上google的坑,真是坑上加坑.比如js注入问题,比如client回调接口时序问题, 比如内存回收问题,etc 1.内存泄漏问题,尤其注意An ...

  9. Android5.1系统WebView内存泄漏场景

    问题现象 (该文章,引自零号路的私人博客,本人在浏览框架的开发过程中,用该方式,规避了内存泄露的问题.) 在Android5.1系统中,会发现App存在 WebView 泄漏情况,还比较严重.并且只是 ...

  10. dojo、iframe和FusionCharts兼容性

    今天,我们项目组对项目收尾检查,却突然发现了一个问题,FusionCharts出现兼容性问题. 在火狐浏览器上,项目运行正常:在IE8(标准模式下)运行正常,但是在IE8杂项出现兼容性问题.经过检查, ...