Архив метки: android

Перепрошивка приставки Vermax UHD200. Не удачная.

Прилетела задача чуть кастомизировать приставку Vermax UHD200 с прошивкой от НАГ. А именно часть приложений удалить, несколько приложений добавить. Образ оригинальной прошивки был в наличии. В формате zip. Решил попробовать ROM Helper,

Собственно эта программа позволяет выполнить именно те задачи которые мне нужны. А именно открыть архив, вывести список установленных программ, отметить галочками те которые нужно убрать, а так-же возможность добавить свои apk. Так-же было заявлено что умеет  «подписывать» прошивки. Но как оказалось таки — не умеет.

Как мы видим, ругается на подпись и ставить не хочет.

Пробовал подписывать архив и  не безызвестной программой ZipSigner — результат тот-же.

Думаю…

Запрос выбора SSL сертификата в компоненте WebView

Задача: при открытии страницы https необходимо позволить пользователю выбрать необходимый сертификат ssl из установленых в хранилище.

Решение:

private class NocWebViewClient extends WebViewClient {
    @Override
    public void onReceivedClientCertRequest(WebView view, final ClientCertRequest request) {
        Log.v(getClass().getSimpleName(), "===> certificate required!");

        KeyChain.choosePrivateKeyAlias(Form1.this, new KeyChainAliasCallback(){
            @TargetApi(Build.VERSION_CODES.LOLLIPOP)
            @Override
            public void alias(String alias) {
                Log.v(getClass().getSimpleName(), "===>Key alias is: " + alias);
                try {
                    PrivateKey changPrivateKey = KeyChain.getPrivateKey(Form1.this, alias);
                    X509Certificate[] certificates = KeyChain.getCertificateChain(Form1.this, alias);
                    Log.v(getClass().getSimpleName(), "===>Getting Private Key Success!" );
                    request.proceed(changPrivateKey, certificates);
                } catch (KeyChainException e) {
                    Log.e(getClass().getSimpleName(), Util.printException(e));
                } catch (InterruptedException e) {
                    Log.e(getClass().getSimpleName(), Util.printException(e));
                }
            }
        },new String[]{"RSA"}, null, null, -1, null);
    }
    @Override
    public void onReceivedSslError(WebView view, SslErrorHandler handler, SslError error) {
        handler.proceed();
    }

    @Override
    public boolean shouldOverrideUrlLoading(WebView view, String url)
    {
        return true;
    }
    @Override
    public void onPageFinished(WebView view, String url){

    }

Вывод телефона и сервиса из спящего режима. Разработка под Android

Задача: обеспечить вывод телефона из спящего режима, воспроизвести звук и вибрацию при выводе уведомления.

Решение:

Создадим стартующий при загрузке сервис при помощи класса WakefulBroadcastReceiver.

Android Manifest:

— назначаем права на вывод из спящего режима, загрузку при перезагрузке, полный доступ в интернет и сеть

— обьявляем ресивер BootBroadcast как выполняемый при перезагрузке телефона

Читать далее Вывод телефона и сервиса из спящего режима. Разработка под Android

Получение страницы по http протоколу на Android

Задача: получить «сырой» json  по протоколу http в приложении под андроид.

Решение:

1)  Разрешим доступ в интернет в AndroidManifest.xml

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="ru.erver.noc.nocmessages">
    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    <uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" />
    <application
        android:resource="@xml/netsec"
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:supportsRtl="true"
        android:theme="@style/Theme.AppCompat.NoActionBar" >
        <activity android:name=".Form1">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>

</manifest>

2) Код:

package ru.yarteleservice.noc.nocmessages;

import android.content.SharedPreferences;
import android.os.AsyncTask;
import android.preference.PreferenceManager;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.EditText;

import java.io.BufferedReader;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.net.HttpURLConnection;
import java.net.URL;

public class Form1 extends AppCompatActivity {
    EditText logv;
    jsonnoc jsn;

    public void AddToLog(String txt) {
        logv = (EditText) findViewById(R.id.editText3);
        if (txt == "clear") {
            logv.setText("");
        } else {
            logv.append(txt);
            logv.append("\n");
        }
        ;
    }

    ;

    public void ClickEnterNocButton(View view) {

        Log.d("неашипка", "--click!");
        AddToLog("clear");

        EditText elogin = (EditText) findViewById(R.id.editText);
        EditText epass = (EditText) findViewById(R.id.editText2);

        AddToLog("-пробуем залогиниться");
        // jsonnoc jsn=new jsonnoc();
        //jsn.GetJsonMet("{'userlogin':'login'}");
        new GetMyDataFromUrl().execute("!!!!!!!!!");

        AddToLog("-сохраняем настройки");

        SharedPreferences mSettings = PreferenceManager.getDefaultSharedPreferences(getApplicationContext());
        SharedPreferences.Editor mEdit = mSettings.edit();
        mEdit.putString("userlogin", elogin.getText().toString());
        mEdit.commit();
        mEdit.apply();
        mEdit.putString("userpass", epass.getText().toString());
        mEdit.commit();
        mEdit.apply();

    }

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_form1);
        AddToLog("-читаем настройки");

        EditText elogin = (EditText) findViewById(R.id.editText);
        EditText epass = (EditText) findViewById(R.id.editText2);

        SharedPreferences mSettings = PreferenceManager.getDefaultSharedPreferences(getApplicationContext());

        elogin.setText(mSettings.getString("userlogin", ""));
        epass.setText(mSettings.getString("userpass", ""));

        AddToLog(elogin.getText().toString());
        AddToLog(epass.getText().toString());

    }

    class GetMyDataFromUrl extends AsyncTask<String, Integer, String>{

        @Override
        protected String doInBackground(String... arg) {
            String res;
            BufferedReader reader = null;
            String resultJson = "";

            res=null;
            HttpURLConnection urlConnection = null;
            Log.d("неашипка", "--пробую почитать json");
            try {
                URL url = new URL("http://noc.dfvdfv.ru/getjsonmess.php");
                urlConnection = (HttpURLConnection) url.openConnection();
                urlConnection.setRequestMethod("GET");
                urlConnection.connect();

                InputStream inputStream = urlConnection.getInputStream();
                StringBuffer buffer = new StringBuffer();

                reader = new BufferedReader(new InputStreamReader(inputStream));

                String line;
                while ((line = reader.readLine()) != null) {
                    buffer.append(line);
                }
                resultJson = buffer.toString();
                Log.d("неашипка", resultJson);
            }
            catch (Exception e) {
                e.printStackTrace();
                Log.d("ашипка", "--не смогли прочитать JSON");
            }
            return res;
        }

        @Override
        protected void onPostExecute(String s) {
            super.onPostExecute(s);
        }
    }
}

Результат:

Android-X86

Спустя год, снова попробовал поставить на ноутбук андроид, проекта http://www.android-x86.org . Ну что? Уже лучше. Намного лучше. Wifi заработал сразу. Большинство не игровых приложений работают. С играми всё печально.. Часть пишет что «Ваше устройство не поддерживается». Другая часть не реагирует на нажатия тачпада. Корректно работает только малая часть игр.