當前位置: 首頁>>代碼示例>>Java>>正文


Java WARCRecordInfo類代碼示例

本文整理匯總了Java中org.archive.io.warc.WARCRecordInfo的典型用法代碼示例。如果您正苦於以下問題:Java WARCRecordInfo類的具體用法?Java WARCRecordInfo怎麽用?Java WARCRecordInfo使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


WARCRecordInfo類屬於org.archive.io.warc包,在下文中一共展示了WARCRecordInfo類的10個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: acceptContent

import org.archive.io.warc.WARCRecordInfo; //導入依賴的package包/類
@Override
public boolean acceptContent(WARCRecordInfo recordInfo)
{
    ByteArrayInputStream contentStream = (ByteArrayInputStream) recordInfo.getContentStream();

    try {
        List<String> lines = IOUtils.readLines(contentStream);
        contentStream.reset();

        for (String line : lines) {
            if (line.contains("creativecommons")) {
                return true;
            }
        }
    }
    catch (IOException e) {
        throw new RuntimeException(e);
    }

    return false;
}
 
開發者ID:habernal,項目名稱:nutch-content-exporter,代碼行數:22,代碼來源:CreativeCommonsCandidateFilter.java

示例2: insert

import org.archive.io.warc.WARCRecordInfo; //導入依賴的package包/類
@Override
public boolean insert(Page target) {
    try {
        if (writer == null) {
            createWarcWriter();
        }
        WARCRecordInfo warcRecord = getWarcRecordInfo(target, generator.getRecordID());
        synchronized (writer) {
            writer.checkSize();
            writer.writeRecord(warcRecord);
            writer.resetTmpStats();
            writer.resetTmpRecordLog();
        }
        return true;
    } catch (IOException e) {
        logger.error("Exception thrown while creating a WARC record.", e);
    }
    return false;
}
 
開發者ID:ViDA-NYU,項目名稱:ache,代碼行數:20,代碼來源:WarcTargetRepository.java

示例3: writeRequest

import org.archive.io.warc.WARCRecordInfo; //導入依賴的package包/類
protected URI writeRequest(URI id) throws IOException, ParseException {
  WARCRecordInfo record = new WARCRecordInfo();

  record.setType(WARCConstants.WARCRecordType.request);
  record.setUrl(getUrl());
  record.setCreate14DigitDate(DateUtils
      .getLog14Date(Long.parseLong(metadata.get("nutch.fetch.time"))));
  record.setMimetype(WARCConstants.HTTP_REQUEST_MIMETYPE);
  record.setRecordId(GENERATOR.getRecordID());

  if (id != null) {
    ANVLRecord headers = new ANVLRecord();
    headers.addLabelValue(WARCConstants.HEADER_KEY_CONCURRENT_TO,
        '<' + id.toString() + '>');
    record.setExtraHeaders(headers);
  }

  ByteArrayOutputStream output = new ByteArrayOutputStream();

  output.write(metadata.get("_request_").getBytes());
  record.setContentLength(output.size());
  record.setContentStream(new ByteArrayInputStream(output.toByteArray()));

  writer.writeRecord(record);

  return record.getRecordId();
}
 
開發者ID:jorcox,項目名稱:GeoCrawler,代碼行數:28,代碼來源:CommonCrawlFormatWARC.java

示例4: acceptContent

import org.archive.io.warc.WARCRecordInfo; //導入依賴的package包/類
@Override
public boolean acceptContent(WARCRecordInfo recordInfo)
{
    frequency.addValue(getContentType(recordInfo));

    return true;
}
 
開發者ID:habernal,項目名稱:nutch-content-exporter,代碼行數:8,代碼來源:ContentTypeStatistics.java

示例5: getContentType

import org.archive.io.warc.WARCRecordInfo; //導入依賴的package包/類
/**
 * Returns the given content-type or empty string, if not available
 *
 * @param recordInfo WARC record info
 * @return string, never null
 */
protected String getContentType(WARCRecordInfo recordInfo)
{
    String contentTypeFull = recordInfo.getExtraHeaders().asMap().get("Nutch_Content-Type");

    if (contentTypeFull != null) {
        // split by ";"
        return contentTypeFull.split(";")[0];
    }

    return "";
}
 
開發者ID:habernal,項目名稱:nutch-content-exporter,代碼行數:18,代碼來源:ContentTypeFilter.java

示例6: acceptContent

import org.archive.io.warc.WARCRecordInfo; //導入依賴的package包/類
@Override
public boolean acceptContent(WARCRecordInfo recordInfo)
{
    String contentType = getContentType(recordInfo);

    return ACCEPTED_CONTENT_TYPE.contains(contentType);
}
 
開發者ID:habernal,項目名稱:nutch-content-exporter,代碼行數:8,代碼來源:ContentTypeFilter.java

示例7: getWarcRecordInfo

import org.archive.io.warc.WARCRecordInfo; //導入依賴的package包/類
public WARCRecordInfo getWarcRecordInfo(Page page, URI uri) throws IOException {
    WARCRecordInfo warcRecord = new WARCRecordInfo();

    warcRecord.setUrl(page.getFinalUrl());
    warcRecord.setRecordId(uri);
    warcRecord.setType(WARCRecordType.response);
    warcRecord.setMimetype(WARCConstants.HTTP_RESPONSE_MIMETYPE);

    // Store fetch times using ISO-8601 format
    Date fetchTime = createFetchTimeDate(page);
    warcRecord.setCreate14DigitDate(dateFormater.get().format(fetchTime));

    // Re-create response body based on content bytes and response headers
    byte[] contentBytes = createContentBytes(page);
    warcRecord.setContentLength(contentBytes.length);
    warcRecord.setContentStream(new ByteArrayInputStream(contentBytes));

    // Store ACHE-specific metadata as non-standard extension header fields
    if (page.getTargetRelevance() != null) {
        TargetRelevance targetRelevance = page.getTargetRelevance();
        warcRecord.addExtraHeader("ACHE-IsRelevant", String.valueOf(targetRelevance.isRelevant()));
        warcRecord.addExtraHeader("ACHE-Relevance", String.format("%.10f", targetRelevance.getRelevance()));
    }
    warcRecord.addExtraHeader("ACHE-Requested-URL", page.getRequestedUrl());

    return warcRecord;
}
 
開發者ID:ViDA-NYU,項目名稱:ache,代碼行數:28,代碼來源:WarcTargetRepository.java

示例8: writeResponse

import org.archive.io.warc.WARCRecordInfo; //導入依賴的package包/類
protected URI writeResponse() throws IOException, ParseException {
  WARCRecordInfo record = new WARCRecordInfo();

  record.setType(WARCConstants.WARCRecordType.response);
  record.setUrl(getUrl());

  String fetchTime;

  record.setCreate14DigitDate(DateUtils
      .getLog14Date(Long.parseLong(metadata.get("nutch.fetch.time"))));
  record.setMimetype(WARCConstants.HTTP_RESPONSE_MIMETYPE);
  record.setRecordId(GENERATOR.getRecordID());

  String IP = getResponseAddress();

  if (StringUtils.isNotBlank(IP))
    record.addExtraHeader(WARCConstants.HEADER_KEY_IP, IP);

  if (ParseSegment.isTruncated(content))
    record.addExtraHeader(WARCConstants.HEADER_KEY_TRUNCATED, "unspecified");

  ByteArrayOutputStream output = new ByteArrayOutputStream();

  String httpHeaders = metadata.get("_response.headers_");

  if (StringUtils.isNotBlank(httpHeaders)) {
    output.write(httpHeaders.getBytes());
  } else {
    // change the record type to resource as we not have information about
    // the headers
    record.setType(WARCConstants.WARCRecordType.resource);
    record.setMimetype(content.getContentType());
  }

  output.write(getResponseContent().getBytes());

  record.setContentLength(output.size());
  record.setContentStream(new ByteArrayInputStream(output.toByteArray()));

  if (output.size() > 0) {
    // avoid generating a 0 sized record, as the webarchive library will
    // complain about it
    writer.writeRecord(record);
  }

  return record.getRecordId();
}
 
開發者ID:jorcox,項目名稱:GeoCrawler,代碼行數:48,代碼來源:CommonCrawlFormatWARC.java

示例9: write

import org.archive.io.warc.WARCRecordInfo; //導入依賴的package包/類
protected void write(final WARCWriter writer, final Content content)
        throws IOException, ParseException
{
    WARCRecordInfo recordInfo = new WARCRecordInfo();
    recordInfo.setUrl(content.getUrl());

    byte[] byteContent = content.getContent();

    // skip empty records
    if (byteContent.length == 0) {
        return;
    }

    recordInfo.setContentStream(new ByteArrayInputStream(byteContent));
    recordInfo.setContentLength(byteContent.length);
    recordInfo.setEnforceLength(true);

    String warcDateString = DEFAULT_WARC_DATE;

    // convert date to WARC-Date format
    String date = content.getMetadata().get("Date");
    if (date != null) {
        try {
            warcDateString = String.valueOf(
                    new SimpleDateFormat("EEE, dd MMM yyyy kk:mm:ss ZZZ", Locale.ENGLISH)
                            .parse(date).getTime());
        }
        catch (ParseException ex) {
            // ignore
        }
    }

    recordInfo.setCreate14DigitDate(warcDateString);

    recordInfo.setType(WARCConstants.WARCRecordType.response);
    recordInfo.setMimetype(WARCConstants.HTTP_RESPONSE_MIMETYPE);
    recordInfo.setRecordId(generator.getRecordID());

    // add some extra headers from nutch
    Set<String> extraHeaders = new HashSet<String>(
            Arrays.asList("nutch.crawl.score", "nutch.segment.name", "Set-Cookie",
                    "Content-Type", "Server", "Pragma", "Cache-Control"));

    for (String extraHeader : extraHeaders) {
        String value = content.getMetadata().get(extraHeader);
        if (value != null) {
            recordInfo.addExtraHeader("Nutch_" + extraHeader, value);
        }
    }

    // apply filters
    boolean acceptExport = true;
    for (ExportContentFilter filter : filters) {
        acceptExport &= filter.acceptContent(recordInfo);
    }

    // and write only if we accept this content
    if (acceptExport) {
        writer.writeRecord(recordInfo);

        totalBytesWritten += byteContent.length;
        entriesCounter++;
    }

}
 
開發者ID:habernal,項目名稱:nutch-content-exporter,代碼行數:66,代碼來源:NutchToWARCConverter.java

示例10: acceptContent

import org.archive.io.warc.WARCRecordInfo; //導入依賴的package包/類
/**
 * Returns true, if the filter should accept this content for exporting to WARC file; false
 * otherwise
 *
 * @param recordInfo record info
 * @return boolean value
 */
boolean acceptContent(WARCRecordInfo recordInfo);
 
開發者ID:habernal,項目名稱:nutch-content-exporter,代碼行數:9,代碼來源:ExportContentFilter.java


注:本文中的org.archive.io.warc.WARCRecordInfo類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。