Авто выборка отплин котлин для чтения смс - PullRequest
0 голосов
/ 05 сентября 2018

друзья, Я работаю над Kotlin и пытаюсь получить полученный SMS в тексте редактирования. Я не знаю, как это реализовать. Если у кого-то есть правильный Kotlin код для извлечения OTP, пожалуйста, опубликуйте его ниже, однако я только что реализовал, как показано ниже, и добавил в реализацию, поэтому, пожалуйста, опубликуйте ниже Kotlin код, если у кого-то есть

class SmsReceiver: BroadcastReceiver() {

    private val mListener: SmsListener? = null
    var b: Boolean? = null
    var abcd: String? = null
    var xyz:String? = null

    @Suppress("DEPRECATION")
    override fun onReceive(context: Context?, intent: Intent?) {
        //val bundle = intent!!.getExtras()
        val data = intent!!.extras
        val pdus = data.get("pdus") as Array<Any>


    }
}

ниже активность

public class OtpActivity extends Activity
{
    EditText ed;
    TextView tv;
    String otp_generated,contactNo,id1;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.otp);
        ed=(EditText)findViewById(R.id.otp_et);
        tv=(TextView) findViewById(R.id.verify_otp);

        SmsReceiver.bin(new SmsListener() {
            @Override
            public void messageReceived(String messageText) {
                ed.setText(messageText);
            }
        });

    }
}

Ответы [ 2 ]

0 голосов
/ 17 октября 2018

Если вы не хотите писать приемник, вы можете использовать простую облегченную библиотеку https://github.com/VitaliBov/SmsInterceptor

Библиотека имеет 100% совместимость с Kotlin

Вам нужно только переопределить метод интерфейса, создать класс Interceptor и связать его с жизненным циклом. Это выглядит так:

public class AuthActivity extends AppCompatActivity implements OnMessageListener {
    private SmsInterceptor smsInterceptor;
    private EditText etAuthPassword;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_auth);
        initViews();
        initSmsInterceptor();
    }

    @Override
    protected void onResume() {
        super.onResume();
        smsInterceptor.register();
    }

    @Override
    protected void onPause() {
        super.onPause();
        smsInterceptor.unregister();
    }

    @Override
    public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
        super.onRequestPermissionsResult(requestCode, permissions, grantResults);
        smsInterceptor.onRequestPermissionsResult(requestCode, permissions, grantResults);
    }

    @Override
    public void messageReceived(String message) {
        // You can perform your validation here
        etAuthPassword.setText(message);
    }

    private void initViews() {
        etAuthPassword = findViewById(R.id.etAuthPassword);
        etAuthPassword.addTextChangedListener(new SmsTextWatcher() {
            @Override
            public void onTextChanged(CharSequence charSequence, int i, int i1, int i2) {
                if (charSequence.length() == 4) {
                    btnAuthPassword.setEnabled(true);
                    checkCode();
                } else {
                    btnAuthPassword.setEnabled(false);
                }
            }
        });
    }

    private void initSmsInterceptor() {
        smsInterceptor = new SmsInterceptor(this, this);
        // Not necessary
        smsInterceptor.setRegex(SMS_CODE_REGEX);
        smsInterceptor.setPhoneNumber(PHONE_NUMBER);
    }

    private void checkCode() {
        // Validation
        if (isValid) {
            navigateToMainScreen();
        }
    }
}
0 голосов
/ 05 сентября 2018

Это можно сделать с помощью RxJava:

public static Observable<String> createMessageMonitor(@NonNull final Context context) {
        IntentFilter intentFilter = new IntentFilter();
        intentFilter.addAction("android.provider.Telephony.SMS_RECEIVED");
        return fromIntentFilter(context, intentFilter)
                .filter(intent -> intent != null && intent.getExtras() != null)
                .map(intent -> {
                    Bundle bundle = intent.getExtras();
                    Object[] pdu_Objects = (Object[]) bundle.get("pdus");
                    if (pdu_Objects != null) {
                        for (Object aObject : pdu_Objects) {
                            final SmsMessage currentSMS = getIncomingMessage(aObject, bundle);
                            final String senderNumber = currentSMS.getDisplayOriginatingAddress();
                            final String message = currentSMS.getDisplayMessageBody().trim();
                            Matcher matcher = OTP_PATTERN.matcher(message);
                            if (matcher.matches()) {
                                return matcher.group(1);
                            }
                        }
                    }
                    return "";
                }).filter(message -> !message.isEmpty());

    }

Ваш OTP_PATTERN:

private static Pattern OTP_PATTERN = Pattern.compile("^(\\d{4}) is the OTP for your App.$");

Тогда подпишитесь на поток:

RxBroadcastReceivers2.createMessageMonitor(this)
                .subscribeWith(this,
                        onNext = { /*Your OTP is here*/ },
                        onError = {
                            Timber.e(it, "Registration permission request failed")
                        }
                )

ПРИМЕЧАНИЕ: Вам необходимо получить Manifest.permission.READ_SMS перед использованием createMessageMonitor метода.

...