Форум программистов, компьютерный форум, киберфорум
Программирование Android
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.93/15: Рейтинг темы: голосов - 15, средняя оценка - 4.93
0 / 0 / 0
Регистрация: 30.01.2015
Сообщений: 19

Блокировка входящего вызова

20.07.2016, 16:09. Показов 2970. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Коллеги, всех приветствую!
Суть задачи, думаю, всем ясна из темы, собственно - описание текущей ситуации.
В одном из классов - назовем его N1 в методе onCreate(Bundle savedInstanceState):

Java
1
2
3
4
5
6
7
8
9
10
11
...
br = new BroadcastReceiver() {
 @Override
 public void onReceive(Context context, Intent intent) {
   TelephonyManager telephony = (TelephonyManager)  context.getSystemService(Context.TELEPHONY_SERVICE);
   CustomPhoneStateListener customPhoneListener = new [B]CustomPhoneStateListener[/B] (context);
   telephony.listen(customPhoneListener, PhoneStateListener.LISTEN_CALL_STATE);
 }
};
IntentFilter inf = new IntentFilter(Intent.ACTION_CALL);
registerReceiver(br, inf);
Выключение широковещательного приемника происходит сразу после этого же метода onCreate(Bundle savedInstanceState):

Java
1
2
3
4
5
6
7
8
@Override
protected void onDestroy() {
 super.onDestroy();
 PaymentFragment pf = new PaymentFragment();
 if(!pf.flagIbox) {
  unregisterReceiver(br);
 }
}
Класс CustomPhoneStateListener содержит код:
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
public class CustomPhoneStateListener extends PhoneStateListener {
    Context context;
 
    public CustomPhoneStateListener(Context context) {
        super();
        this.context = context;
    }
 
    @Override
    public void onCallStateChanged(int state, String callingNumber)
    {
        super.onCallStateChanged(state, callingNumber);
        switch (state) {
            case TelephonyManager.CALL_STATE_IDLE:  //неактивен
                break;
            case TelephonyManager.CALL_STATE_OFFHOOK: //вызов активен
                //handle out going call
                endCallIfBlocked(callingNumber);
                break;
            case TelephonyManager.CALL_STATE_RINGING:   //есть входящий
                //handle in coming call
                endCallIfBlocked(callingNumber);
                break;
            default:
                break;
        }
    }
 
    private void endCallIfBlocked(String callingNumber) {
        try {
 
            // Java reflection to gain access to TelephonyManager's
            // ITelephony getter
            TelephonyManager tm = (TelephonyManager) context.getSystemService(Context.TELEPHONY_SERVICE);
            Class<?> c = Class.forName(tm.getClass().getName());
            Method m = c.getDeclaredMethod("getITelephony");
            m.setAccessible(true);
 
            ITelephony telephonyService = (ITelephony) m.invoke(tm);
 
            telephonyService.silenceRinger();
            telephonyService.endCall();
            
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}
Все бы неплохо, но вот только получаю сообщение об ошибке типа:
android.internal.ITelephony$Stub$Proxy cannot be cast to com...
Понимаю, что частично дело в строке:
Java
1
ITelephony telephonyService = (ITelephony) m.invoke(tm);
В примерах прописано:
Java
1
android.internal.telephony.ITelephony telephonyService = (ITelephony) m.invoke(tm);
Выходит, что в android.internal.telephony должен располагаться .java-файл? И, как кто-то пишет, это переименованный ITelephony.aidl...

В одном пакете с вышеуказанными файлами находится ITelephony.java с кодом:
Java
1
2
3
4
5
public interface ITelephony {
    boolean endCall();
    void answerRingingCall();
    void silenceRinger();
}
В пакете android.internal.telephony расположен файл ITelephony.aidl с кодом, который можно посмотреть на разных ресурсах.
Может, кто знает, как решить проблему?
Спасибо!

Добавлено через 13 часов 57 минут
Аналогичная проблема наблюдается у другого разработчика. Там обращают его внимание на файл proguard.cfg..

Добавлено через 46 минут
Здесь пишут, что необходимо исключить ITelephony из proguard.
Попробовал найти файл proguard.cfg в корне - не нашел. Пишут, что необходимо обновить Android SDK. Посмотрим..

Добавлено через 5 часов 3 минуты
К счастью для PM задача решена оперативно, к моему сожалению - другими методами. Озвученная проблема остается актуальной..
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
20.07.2016, 16:09
Ответы с готовыми решениями:

Как определить "переадресованность" входящего вызова
Доброго времени суток! Подскажите из какого свойства и каким образом можно получить признак &quot;переадресованности&quot; входящего...

Как поймать момент входящего вызова и номер телефона входящего вызова?
всем привет, у меня странный вопрос, есть стационарный телефон, подключенный через четырехканальный адаптер SpRecord AT4 к ПК по USB, как...

Блокировка входящего трафика
Всем привет, помогите с такой проблемой у меня есть сервер Rust legacy и его ддосят через чит (Поднимают пинг) нужно написать плагин для...

3
103 / 69 / 19
Регистрация: 07.07.2014
Сообщений: 240
20.07.2016, 21:53
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
    private void BreakCall(){
        try {
            String serviceManagerName = "android.os.ServiceManager";
            String serviceManagerNativeName = "android.os.ServiceManagerNative";
            String telephonyName = "com.android.internal.telephony.ITelephony";
            Class<?> telephonyClass;
            Class<?> telephonyStubClass;
            Class<?> serviceManagerClass;
            Class<?> serviceManagerNativeClass;
            Method telephonyEndCall;
            Object telephonyObject;
            Object serviceManagerObject;
            telephonyClass = Class.forName(telephonyName);
            telephonyStubClass = telephonyClass.getClasses()[0];
            serviceManagerClass = Class.forName(serviceManagerName);
            serviceManagerNativeClass = Class.forName(serviceManagerNativeName);
            Method getService = // getDefaults[29];
            serviceManagerClass.getMethod("getService", String.class);
            Method tempInterfaceMethod = serviceManagerNativeClass.getMethod("asInterface", IBinder.class);
            Binder tmpBinder = new Binder();
            tmpBinder.attachInterface(null, "fake");
            serviceManagerObject = tempInterfaceMethod.invoke(null, tmpBinder);
            IBinder retbinder = (IBinder) getService.invoke(serviceManagerObject, "phone");
            Method serviceMethod = telephonyStubClass.getMethod("asInterface", IBinder.class);
            telephonyObject = serviceMethod.invoke(null, retbinder);
            telephonyEndCall = telephonyClass.getMethod("endCall");
            telephonyEndCall.invoke(telephonyObject);
 
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
0
0 / 0 / 0
Регистрация: 30.01.2015
Сообщений: 19
21.07.2016, 11:42  [ТС]
Спасибо, надо протестировать.

Добавлено через 6 минут
Честно говоря, использовал нечто подобное через рефлексию:

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
public class CustomPhoneStateListener extends PhoneStateListener {
 
    Context context;
 
    private static boolean keyIn;
 
    public void setKeyIn(boolean newKeyIn) {
        keyIn = newKeyIn;
    }
 
    public CustomPhoneStateListener(Context context) {
        super();
        this.context = context;
    }
 
    @Override
    public void onCallStateChanged(int state, String callingNumber)
    {
        super.onCallStateChanged(state, callingNumber);
        switch (state) {
            case TelephonyManager.CALL_STATE_IDLE:
                break;
            case TelephonyManager.CALL_STATE_OFFHOOK: 
                //handle out going call
                endCallIfBlocked(callingNumber);
                break;
            case TelephonyManager.CALL_STATE_RINGING:
                //handle in coming call
                endCallIfBlocked(callingNumber);
                break;
            default:
                break;
        }
    }
 
    private void endCallIfBlocked(String callingNumber) {
        try {
 
            // Java reflection to gain access to TelephonyManager's
            TelephonyManager tm = (TelephonyManager) context.getSystemService(Context.TELEPHONY_SERVICE);
            Class<?> c = Class.forName(tm.getClass().getName());
            Method m = c.getDeclaredMethod("getITelephony");
 
            /* keyIn - если значение параметра равно false, блокировка не происходит;
            *  если true - происходит
            */
            m.setAccessible(keyIn);
 
            Object telephonyService = m.invoke(tm);
            Class<?> telephonyServiceClass = Class.forName(telephonyService.getClass().getName());
            Method endCallMethod = telephonyServiceClass.getDeclaredMethod("endCall");
            endCallMethod.invoke(telephonyService);
 
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}
Добавлено через 2 минуты
Ситуация осложнялась тем, что блокировка входящих вызовов должна происходить не всегда, а только в определенных активностях - в этом участвует глобальная переменная с булевыми значениями keyIn.

Добавлено через 2 минуты
Ее значение передается в:

Java
1
m.setAccessible(keyIn);
false - блокировка не происходит, true - блокировка происходит.
0
103 / 69 / 19
Регистрация: 07.07.2014
Сообщений: 240
21.07.2016, 12:11
Цитата Сообщение от AlekseyCyber Посмотреть сообщение
Спасибо, надо протестировать.
Честно говоря, это довольно давно использовал этот метод, и не могу сказать корректно ли он работает на android 5+, так что проверьте. Но работал он хорошо и вызывать его можно абсолютно из любого места.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
21.07.2016, 12:11
Помогаю со студенческими работами здесь

[SIP] Одновременная сигнализация входящего вызова на несколько устройств
Добрый вечер. Ситуация следующая: есть роутер, который поддерживает технологию SIP, и к которому подключен стационарный телефон, а также...

Блокировка вызова фунции
Доброе время суток форумчане! Такая проблема: нужно ограничить выполнение фунции. Подробнее: Есть функция, нужно запретить ее...

После вызова печати, я хочу попасть на ту форму что вызывала, и на то поле где была до вызова
Например я в форме на каком-то поле Вызываю с формы отчет, потом закрываю отчет, и моя форма видна, но не активна, на ней нет фокуса....

нужно чтобы функция располагалась до ее вызова, после ее вызова и в другом файле. Как это сделать?
#include &lt;iostream&gt; #include &lt;conio.h&gt; using namespace std; int n, *c; void fun(int a, int b) { for (int i = 0; i &lt;...

Блокировка клавиши при нажатии в одной форме и блокировка в другой, третьей
Здравствуйте нужно что бы при вызове помощи в 1ом вопросе она блокировалась во 2ом вопросе,подскажите как сделать. Вам нужно...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru