Не удается установить программное обеспечение (Armory) - опция установки не предусмотрена

Я посмотрел ответ от «emmby» (ответил 16 июня '11 в 21:29), пункт № 4: «Создайте собственный SSLSocketFactory, который использует встроенный сертификат KeyStore, но использует альтернативный KeyStore для все, что не удается проверить по умолчанию. "

Это упрощенная реализация. Загрузите системное хранилище ключей & amp; объединить с хранилищем ключей приложения.

public HttpClient getNewHttpClient() {
    try {
        InputStream in = null;
        // Load default system keystore
        KeyStore trusted = KeyStore.getInstance(KeyStore.getDefaultType()); 
        try {
            in = new BufferedInputStream(new FileInputStream(System.getProperty("javax.net.ssl.trustStore"))); // Normally: "/system/etc/security/cacerts.bks"
            trusted.load(in, null); // no password is "changeit"
        } finally {
            if (in != null) {
                in.close();
                in = null;
            }
        }

        // Load application keystore & merge with system
        try {
            KeyStore appTrusted = KeyStore.getInstance("BKS"); 
            in = context.getResources().openRawResource(R.raw.mykeystore);
            appTrusted.load(in, null); // no password is "changeit"
            for (Enumeration e = appTrusted.aliases(); e.hasMoreElements();) {
                final String alias = e.nextElement();
                final KeyStore.Entry entry = appTrusted.getEntry(alias, null);
                trusted.setEntry(System.currentTimeMillis() + ":" + alias, entry, null);
            }
        } finally {
            if (in != null) {
                in.close();
                in = null;
            }
        }

        HttpParams params = new BasicHttpParams();
        HttpProtocolParams.setVersion(params, HttpVersion.HTTP_1_1);
        HttpProtocolParams.setContentCharset(params, HTTP.UTF_8);

        SSLSocketFactory sf = new SSLSocketFactory(trusted);
        sf.setHostnameVerifier(SSLSocketFactory.BROWSER_COMPATIBLE_HOSTNAME_VERIFIER);

        SchemeRegistry registry = new SchemeRegistry();
        registry.register(new Scheme("http", PlainSocketFactory.getSocketFactory(), 80));
        registry.register(new Scheme("https", sf, 443));

        ClientConnectionManager ccm = new ThreadSafeClientConnManager(params, registry);

        return new DefaultHttpClient(ccm, params);
    } catch (Exception e) {
        return new DefaultHttpClient();
    }
}

Простой режим для преобразования из JKS в BKS:

keytool -importkeystore -destkeystore cacerts.bks -deststoretype BKS -providerclass org.bouncycastle.jce.provider.BouncyCastleProvider -providerpath bcprov-jdk16-141.jar -deststorepass changeit -srcstorepass changeit -srckeystore $JAVA_HOME/jre/lib/security/cacerts -srcstoretype JKS -noprompt

* Примечание. В Android 4.0 (ICS) изменилось хранилище доверия, дополнительная информация: http: // nelenkov.blogspot.com.es/2011/12/ics-trust-store-implementation.html

0
задан 07.05.2020, 08:01

1 ответ

Из терминала введите следующее:

$ sudo dpkg -i /path/to/package.deb
-1
ответ дан 07.05.2020, 08:01
  • 1
    dpkg используется, чтобы вручную установить и удалить пакеты – chris 07.05.2020, 08:01
  • 2
    средства sudo выполняют это как суперпользователь –  07.05.2020, 08:02
  • 3
    -i параметр является сокращенной версией - параметр установки – Johannes Schaub - litb 07.05.2020, 08:02
  • 4
    Что делает это делает? – Johannes Schaub - litb 07.05.2020, 08:03

Теги

Похожие вопросы