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


Java DataSource類代碼示例

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


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

示例1: getAndroidManifestFromApk

import com.android.apksig.util.DataSource; //導入依賴的package包/類
/**
 * Returns the contents of the APK's {@code AndroidManifest.xml} or {@code null} if this entry
 * is not present in the APK.
 */
static ByteBuffer getAndroidManifestFromApk(
        List<CentralDirectoryRecord> cdRecords, DataSource lhfSection)
                throws IOException, ApkFormatException, ZipFormatException {
    CentralDirectoryRecord androidManifestCdRecord = null;
    for (CentralDirectoryRecord cdRecord : cdRecords) {
        if (ANDROID_MANIFEST_ZIP_ENTRY_NAME.equals(cdRecord.getName())) {
            androidManifestCdRecord = cdRecord;
            break;
        }
    }
    if (androidManifestCdRecord == null) {
        throw new ApkFormatException("Missing " + ANDROID_MANIFEST_ZIP_ENTRY_NAME);
    }

    return ByteBuffer.wrap(
            LocalFileRecord.getUncompressedData(
                    lhfSection, androidManifestCdRecord, lhfSection.size()));
}
 
開發者ID:F8LEFT,項目名稱:FApkSigner,代碼行數:23,代碼來源:ApkSigner.java

示例2: outputZipSections

import com.android.apksig.util.DataSource; //導入依賴的package包/類
@Override
public OutputApkSigningBlockRequest outputZipSections(
        DataSource zipEntries,
        DataSource zipCentralDirectory,
        DataSource zipEocd)
                throws IOException, InvalidKeyException, SignatureException,
                        NoSuchAlgorithmException {
    checkNotClosed();
    checkV1SigningDoneIfEnabled();
    if (!mV2SigningEnabled) {
        return null;
    }
    invalidateV2Signature();

    byte[] apkSigningBlock =
            V2SchemeSigner.generateApkSigningBlock(
                    zipEntries, zipCentralDirectory, zipEocd, mV2SignerConfigs);

    mAddV2SignatureRequest = new OutputApkSigningBlockRequestImpl(apkSigningBlock);
    return mAddV2SignatureRequest;
}
 
開發者ID:F8LEFT,項目名稱:FApkSigner,代碼行數:22,代碼來源:DefaultApkSignerEngine.java

示例3: verify

import com.android.apksig.util.DataSource; //導入依賴的package包/類
/**
 * Verifies the APK's signatures and returns the result of verification. The APK can be
 * considered verified iff the result's {@link Result#isVerified()} returns {@code true}.
 * The verification result also includes errors, warnings, and information about signers.
 *
 * @throws IOException if an I/O error is encountered while reading the APK
 * @throws ApkFormatException if the APK is malformed
 * @throws NoSuchAlgorithmException if the APK's signatures cannot be verified because a
 *         required cryptographic algorithm implementation is missing
 * @throws IllegalStateException if this verifier's configuration is missing required
 *         information.
 */
public Result verify() throws IOException, ApkFormatException, NoSuchAlgorithmException,
        IllegalStateException {
    Closeable in = null;
    try {
        DataSource apk;
        if (mApkDataSource != null) {
            apk = mApkDataSource;
        } else if (mApkFile != null) {
            RandomAccessFile f = new RandomAccessFile(mApkFile, "r");
            in = f;
            apk = DataSources.asDataSource(f, 0, f.length());
        } else {
            throw new IllegalStateException("APK not provided");
        }
        return verify(apk);
    } finally {
        if (in != null) {
            in.close();
        }
    }
}
 
開發者ID:F8LEFT,項目名稱:FApkSigner,代碼行數:34,代碼來源:ApkVerifier.java

示例4: outputRecordWithModifiedExtra

import com.android.apksig.util.DataSource; //導入依賴的package包/類
/**
 * Outputs this record, replacing its extra field with the provided one, and returns returns the
 * number of bytes output.
 */
public long outputRecordWithModifiedExtra(
        DataSource sourceApk,
        ByteBuffer extra,
        DataSink output) throws IOException {
    long recordStartOffsetInSource = getStartOffsetInArchive();
    int extraStartOffsetInRecord = getExtraFieldStartOffsetInsideRecord();
    int extraSizeBytes = extra.remaining();
    int headerSize = extraStartOffsetInRecord + extraSizeBytes;
    ByteBuffer header = ByteBuffer.allocate(headerSize);
    header.order(ByteOrder.LITTLE_ENDIAN);
    sourceApk.copyTo(recordStartOffsetInSource, extraStartOffsetInRecord, header);
    header.put(extra.slice());
    header.flip();
    ZipUtils.setUnsignedInt16(header, EXTRA_LENGTH_OFFSET, extraSizeBytes);

    long outputByteCount = header.remaining();
    output.consume(header);
    long remainingRecordSize = getSize() - mDataStartOffset;
    sourceApk.feed(recordStartOffsetInSource + mDataStartOffset, remainingRecordSize, output);
    outputByteCount += remainingRecordSize;
    return outputByteCount;
}
 
開發者ID:F8LEFT,項目名稱:FApkSigner,代碼行數:27,代碼來源:LocalFileRecord.java

示例5: outputUncompressedData

import com.android.apksig.util.DataSource; //導入依賴的package包/類
/**
 * Sends uncompressed data pointed to by the provided ZIP Central Directory (CD) record into the
 * provided data sink.
 */
public static void outputUncompressedData(
        DataSource source,
        CentralDirectoryRecord cdRecord,
        long cdStartOffsetInArchive,
        DataSink sink) throws ZipFormatException, IOException {
    // IMPLEMENTATION NOTE: This method attempts to mimic the behavior of Android platform
    // exhibited when reading an APK for the purposes of verifying its signatures.
    // When verifying an APK, Android doesn't care reading the extra field or the Data
    // Descriptor.
    LocalFileRecord lfhRecord =
            getRecord(
                    source,
                    cdRecord,
                    cdStartOffsetInArchive,
                    false, // don't care about the extra field
                    false // don't read the Data Descriptor
                    );
    lfhRecord.outputUncompressedData(source, sink);
}
 
開發者ID:F8LEFT,項目名稱:FApkSigner,代碼行數:24,代碼來源:LocalFileRecord.java

示例6: getUncompressedData

import com.android.apksig.util.DataSource; //導入依賴的package包/類
/**
 * Returns the uncompressed data pointed to by the provided ZIP Central Directory (CD) record.
 */
public static byte[] getUncompressedData(
        DataSource source,
        CentralDirectoryRecord cdRecord,
        long cdStartOffsetInArchive) throws ZipFormatException, IOException {
    if (cdRecord.getUncompressedSize() > Integer.MAX_VALUE) {
        throw new IOException(
                cdRecord.getName() + " too large: " + cdRecord.getUncompressedSize());
    }
    byte[] result = new byte[(int) cdRecord.getUncompressedSize()];
    ByteBuffer resultBuf = ByteBuffer.wrap(result);
    ByteBufferSink resultSink = new ByteBufferSink(resultBuf);
    outputUncompressedData(
            source,
            cdRecord,
            cdStartOffsetInArchive,
            resultSink);
    return result;
}
 
開發者ID:F8LEFT,項目名稱:FApkSigner,代碼行數:22,代碼來源:LocalFileRecord.java

示例7: verify

import com.android.apksig.util.DataSource; //導入依賴的package包/類
/**
 * Verifies the provided APK's APK Signature Scheme v2 signatures and returns the result of
 * verification. APK is considered verified only if {@link Result#verified} is {@code true}. If
 * verification fails, the result will contain errors -- see {@link Result#getErrors()}.
 *
 * @throws ApkFormatException if the APK is malformed
 * @throws NoSuchAlgorithmException if the APK's signatures cannot be verified because a
 *         required cryptographic algorithm implementation is missing
 * @throws SignatureNotFoundException if no APK Signature Scheme v2 signatures are found
 * @throws IOException if an I/O error occurs when reading the APK
 */
public static Result verify(DataSource apk, ApkUtils.ZipSections zipSections)
        throws IOException, ApkFormatException, NoSuchAlgorithmException,
                SignatureNotFoundException {
    Result result = new Result();
    SignatureInfo signatureInfo = findSignature(apk, zipSections, result);

    DataSource beforeApkSigningBlock = apk.slice(0, signatureInfo.apkSigningBlockOffset);
    DataSource centralDir =
            apk.slice(
                    signatureInfo.centralDirOffset,
                    signatureInfo.eocdOffset - signatureInfo.centralDirOffset);
    ByteBuffer eocd = signatureInfo.eocd;

    verify(beforeApkSigningBlock,
            signatureInfo.signatureBlock,
            centralDir,
            eocd,
            result);
    return result;
}
 
開發者ID:F8LEFT,項目名稱:FApkSigner,代碼行數:32,代碼來源:V2SchemeVerifier.java

示例8: findSignature

import com.android.apksig.util.DataSource; //導入依賴的package包/類
/**
 * Returns the APK Signature Scheme v2 block contained in the provided APK file and the
 * additional information relevant for verifying the block against the file.
 *
 * @throws SignatureNotFoundException if the APK is not signed using APK Signature Scheme v2
 * @throws IOException if an I/O error occurs while reading the APK
 */
private static SignatureInfo findSignature(
        DataSource apk, ApkUtils.ZipSections zipSections, Result result)
                throws IOException, SignatureNotFoundException {
    // Find the APK Signing Block. The block immediately precedes the Central Directory.
    ByteBuffer eocd = zipSections.getZipEndOfCentralDirectory();
    Pair<DataSource, Long> apkSigningBlockAndOffset = findApkSigningBlock(apk, zipSections);
    DataSource apkSigningBlock = apkSigningBlockAndOffset.getFirst();
    long apkSigningBlockOffset = apkSigningBlockAndOffset.getSecond();
    ByteBuffer apkSigningBlockBuf =
            apkSigningBlock.getByteBuffer(0, (int) apkSigningBlock.size());
    apkSigningBlockBuf.order(ByteOrder.LITTLE_ENDIAN);

    // Find the APK Signature Scheme v2 Block inside the APK Signing Block.
    ByteBuffer apkSignatureSchemeV2Block =
            findApkSignatureSchemeV2Block(apkSigningBlockBuf, result);

    return new SignatureInfo(
            apkSignatureSchemeV2Block,
            apkSigningBlockOffset,
            zipSections.getZipCentralDirectoryOffset(),
            zipSections.getZipEndOfCentralDirectoryOffset(),
            eocd);
}
 
開發者ID:F8LEFT,項目名稱:FApkSigner,代碼行數:31,代碼來源:V2SchemeVerifier.java

示例9: ApkSigner

import com.android.apksig.util.DataSource; //導入依賴的package包/類
private ApkSigner(
        List<SignerConfig> signerConfigs,
        Integer minSdkVersion,
        boolean v1SigningEnabled,
        boolean v2SigningEnabled,
        boolean otherSignersSignaturesPreserved,
        String createdBy,
        ApkSignerEngine signerEngine,
        File inputApkFile,
        DataSource inputApkDataSource,
        File outputApkFile,
        DataSink outputApkDataSink,
        DataSource outputApkDataSource) {

    mSignerConfigs = signerConfigs;
    mMinSdkVersion = minSdkVersion;
    mV1SigningEnabled = v1SigningEnabled;
    mV2SigningEnabled = v2SigningEnabled;
    mOtherSignersSignaturesPreserved = otherSignersSignaturesPreserved;
    mCreatedBy = createdBy;

    mSignerEngine = signerEngine;

    mInputApkFile = inputApkFile;
    mInputApkDataSource = inputApkDataSource;

    mOutputApkFile = outputApkFile;
    mOutputApkDataSink = outputApkDataSink;
    mOutputApkDataSource = outputApkDataSource;
}
 
開發者ID:F8LEFT,項目名稱:FApkSigner,代碼行數:31,代碼來源:ApkSigner.java

示例10: fulfillInspectInputJarEntryRequest

import com.android.apksig.util.DataSource; //導入依賴的package包/類
private static void fulfillInspectInputJarEntryRequest(
        DataSource lfhSection,
        LocalFileRecord localFileRecord,
        ApkSignerEngine.InspectJarEntryRequest inspectEntryRequest)
                throws IOException, ApkFormatException {
    try {
        localFileRecord.outputUncompressedData(lfhSection, inspectEntryRequest.getDataSink());
    } catch (ZipFormatException e) {
        throw new ApkFormatException("Malformed ZIP entry: " + localFileRecord.getName(), e);
    }
    inspectEntryRequest.done();
}
 
開發者ID:F8LEFT,項目名稱:FApkSigner,代碼行數:13,代碼來源:ApkSigner.java

示例11: outputInputJarEntryLfhRecordPreservingDataAlignment

import com.android.apksig.util.DataSource; //導入依賴的package包/類
private static long outputInputJarEntryLfhRecordPreservingDataAlignment(
        DataSource inputLfhSection,
        LocalFileRecord inputRecord,
        DataSink outputLfhSection,
        long outputOffset) throws IOException {
    long inputOffset = inputRecord.getStartOffsetInArchive();
    if (inputOffset == outputOffset) {
        // This record's data will be aligned same as in the input APK.
        return inputRecord.outputRecord(inputLfhSection, outputLfhSection);
    }
    int dataAlignmentMultiple = getInputJarEntryDataAlignmentMultiple(inputRecord);
    if ((dataAlignmentMultiple <= 1)
            || ((inputOffset % dataAlignmentMultiple)
                    == (outputOffset % dataAlignmentMultiple))) {
        // This record's data will be aligned same as in the input APK.
        return inputRecord.outputRecord(inputLfhSection, outputLfhSection);
    }

    long inputDataStartOffset = inputOffset + inputRecord.getDataStartOffsetInRecord();
    if ((inputDataStartOffset % dataAlignmentMultiple) != 0) {
        // This record's data is not aligned in the input APK. No need to align it in the
        // output.
        return inputRecord.outputRecord(inputLfhSection, outputLfhSection);
    }

    // This record's data needs to be re-aligned in the output. This is achieved using the
    // record's extra field.
    ByteBuffer aligningExtra =
            createExtraFieldToAlignData(
                    inputRecord.getExtra(),
                    outputOffset + inputRecord.getExtraFieldStartOffsetInsideRecord(),
                    dataAlignmentMultiple);
    return inputRecord.outputRecordWithModifiedExtra(
            inputLfhSection, aligningExtra, outputLfhSection);
}
 
開發者ID:F8LEFT,項目名稱:FApkSigner,代碼行數:36,代碼來源:ApkSigner.java

示例12: getZipCentralDirectory

import com.android.apksig.util.DataSource; //導入依賴的package包/類
private static ByteBuffer getZipCentralDirectory(
        DataSource apk,
        ApkUtils.ZipSections apkSections) throws IOException, ApkFormatException {
    long cdSizeBytes = apkSections.getZipCentralDirectorySizeBytes();
    if (cdSizeBytes > Integer.MAX_VALUE) {
        throw new ApkFormatException("ZIP Central Directory too large: " + cdSizeBytes);
    }
    long cdOffset = apkSections.getZipCentralDirectoryOffset();
    ByteBuffer cd = apk.getByteBuffer(cdOffset, (int) cdSizeBytes);
    cd.order(ByteOrder.LITTLE_ENDIAN);
    return cd;
}
 
開發者ID:F8LEFT,項目名稱:FApkSigner,代碼行數:13,代碼來源:ApkSigner.java

示例13: getMinSdkVersionFromApk

import com.android.apksig.util.DataSource; //導入依賴的package包/類
/**
 * Returns the minimum Android version (API Level) supported by the provided APK. This is based
 * on the {@code android:minSdkVersion} attributes of the APK's {@code AndroidManifest.xml}.
 */
private static int getMinSdkVersionFromApk(
        List<CentralDirectoryRecord> cdRecords, DataSource lhfSection)
                throws IOException, MinSdkVersionException {
    ByteBuffer androidManifest;
    try {
        androidManifest = getAndroidManifestFromApk(cdRecords, lhfSection);
    } catch (ZipFormatException | ApkFormatException e) {
        throw new MinSdkVersionException(
                "Failed to determine APK's minimum supported Android platform version",
                e);
    }
    return ApkUtils.getMinSdkVersionFromBinaryAndroidManifest(androidManifest);
}
 
開發者ID:F8LEFT,項目名稱:FApkSigner,代碼行數:18,代碼來源:ApkSigner.java

示例14: setInputApk

import com.android.apksig.util.DataSource; //導入依賴的package包/類
/**
 * Sets the APK to be signed.
 *
 * @see #setInputApk(File)
 */
public Builder setInputApk(DataSource inputApk) {
    if (inputApk == null) {
        throw new NullPointerException("inputApk == null");
    }
    mInputApkDataSource = inputApk;
    mInputApkFile = null;
    return this;
}
 
開發者ID:F8LEFT,項目名稱:FApkSigner,代碼行數:14,代碼來源:ApkSigner.java

示例15: setOutputApk

import com.android.apksig.util.DataSource; //導入依賴的package包/類
/**
 * Sets the sink which will receive the output (signed) APK. Data received by the
 * {@code outputApkOut} sink must be visible through the {@code outputApkIn} data source.
 *
 * <p>This is an advanced variant of {@link #setOutputApk(ReadableDataSink)}, enabling the
 * sink and the source to be different objects.
 *
 * @see #setOutputApk(ReadableDataSink)
 * @see #setOutputApk(File)
 */
public Builder setOutputApk(DataSink outputApkOut, DataSource outputApkIn) {
    if (outputApkOut == null) {
        throw new NullPointerException("outputApkOut == null");
    }
    if (outputApkIn == null) {
        throw new NullPointerException("outputApkIn == null");
    }
    mOutputApkFile = null;
    mOutputApkDataSink = outputApkOut;
    mOutputApkDataSource = outputApkIn;
    return this;
}
 
開發者ID:F8LEFT,項目名稱:FApkSigner,代碼行數:23,代碼來源:ApkSigner.java


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