Матлер не будет соответствовать шаблону в AndroidAndroid

Форум для тех, кто программирует под Android
Ответить
Anonymous
 Матлер не будет соответствовать шаблону в Android

Сообщение Anonymous »

Я пытаюсь разработать приложение, которое автоматически считывает одноразовый пароль из входящих SMS. У меня есть класс под названием SMS , где я храню в настоящее время чтение сообщений и класс под названием SMSRule , который содержит информацию о возможных отправителях OTP. < /p>

Все идет гладко, за исключением извлечения OTP из сообщения. My SMS is containing the message, but when I try to match the Pattern against the message, my match.find() returns false.

Following are my files:

OTPAutoRead.java

Код: Выделить всё

import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.content.IntentFilter;
import android.content.pm.PackageManager;
import android.os.Bundle;
import android.support.annotation.NonNull;
import android.telephony.SmsMessage;
import android.util.Log;
import android.widget.Toast;

import java.util.List;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

import auro.widget.OTP.SMS.SMS;
import auro.widget.OTP.SMS.SMSRule;

/**
* Created on 26/8/16.
* @author Auro
* @since 1.0
*/

public class OTPAutoRead extends BroadcastReceiver {

private static final String LOG_TAG = OTPAutoRead.class.getCanonicalName();

private static final String mReadPermission = "android.permission.READ_SMS";
private static final String mReceivePermission = "android.permission.RECEIVE_SMS";

private List smsRules;
private Context context;
private String OTP;

public OTPAutoRead() {throw new InstantiationError("Empty Constructor");}

public OTPAutoRead(@NonNull Context context, final List smsRules) {

if (smsRules == null || smsRules.size() == 0) {

throw new AuroMissingRulesException("No SMS Rules Found");
}

this.smsRules = smsRules;
this.context = context;
CheckSMSReadPermission();

IntentFilter itf = new IntentFilter();
itf.addAction("android.provider.Telephony.SMS_RECEIVED");
itf.setPriority(999);
context.registerReceiver(this,itf);

}

private void CheckSMSReadPermission() {

PackageManager packageManager = context.getPackageManager();
String packageName = context.getPackageName();

int readPermission = packageManager.checkPermission(mReadPermission,packageName);
int receivePermission = packageManager.checkPermission(mReceivePermission, packageName);

boolean canRead = (readPermission == PackageManager.PERMISSION_GRANTED);

if (!canRead)
Toast.makeText(context,"Please enable SMS read permission for auto OTP read", Toast.LENGTH_SHORT).show();
}

@Override
public void onReceive(Context context, Intent intent) {

try {
if (intent.getAction().equals("android.provider.Telephony.SMS_RECEIVED"))
tryReceiveMessage(intent);
}   catch (Exception e) {
Log.i(LOG_TAG, "Failed to read SMS", e);
}
}

private void tryReceiveMessage(Intent intent) {

Bundle bundle = intent.getExtras();

SmsMessage[] messages = null;

if (bundle != null) {

Object[] pdus = (Object[]) bundle.get("pdus");

if (pdus != null) {
messages = new SmsMessage[pdus.length];

for (int i = 0; i < messages.length; i++) {

messages[i] = SmsMessage.createFromPdu((byte[]) pdus[i]);
String messageFrom = messages[i].getOriginatingAddress().toUpperCase();
String messageBody = messages[i].getMessageBody().toUpperCase();

Log.d(LOG_TAG, "Message is from: " + messageFrom + " and its content is: " + messageBody);

SMS sms = new SMS();
sms.setMessage(messageBody).setAddress(messageFrom);

processOTP(sms);
}
}
}
}

private void processOTP(SMS sms) {

int i;

for (i = 0; i < smsRules.size();  i ++) {

if (sms.getAddress().toUpperCase().contains(smsRules.get(i).getSender().toUpperCase())) {

Pattern pattern = smsRules.get(i).getOTPPattern();

System.out.println(pattern.pattern());
System.out.println(sms.getMessage());

Matcher matcher = pattern.matcher(sms.getMessage().toUpperCase());

if (matcher.find()) {

OTP = matcher.group(1);
Log.i(LOG_TAG,"Extracted OTP is: " + OTP);
Toast.makeText(context,"OTP RECEIVED IS: " + OTP,Toast.LENGTH_SHORT).show();
return;
} else
Log.d(LOG_TAG,"Failed to extract OTP");
}
}
}

public String getOTP() {
return OTP;
}

}
< /code>

[b]sms.java[/b]

import android.support.annotation.NonNull;

/**
* Created on 26/8/16.
* @author Auro
* @since 1.0
*/
public class SMS {

private String mID;
private String mAddress;
private String mMessage;
private boolean isRead = false;
private String mTime;

public String getID() {

return mID;
}

public SMS setID(@NonNull final String ID) {

mID = ID;
return this;
}

public String getAddress() {

return mAddress;
}

public SMS setAddress(@NonNull final String Address) {

mAddress = Address;
return this;
}

public String getMessage() {
return mMessage;
}

public SMS setMessage(@NonNull final String Message) {

mMessage = Message;
return this;
}

public boolean isRead() {

return isRead;
}

public SMS setReadState(boolean ReadState) {

isRead = ReadState;
return this;
}

public String getTime() {

return mTime;
}

public SMS setTime(@NonNull String Time) {

mTime = Time;
return this;
}
}
< /code>

[b]smrule.java[/b]

import java.util.regex.Pattern;

/**
* Created on 26/8/16.
* @author Auro
* @since 1.0
*/
public class SMSRule {

private String mSender;
private String mGroupID;
private Pattern mOTPPattern;

private SMS sms;

public String getSender() {

return mSender;
}

public SMSRule setSender(final String sender) {

mSender = sender;
return this;
}

public String getGroupID() {

return mGroupID;
}

public SMSRule setGroupID(final String groupID) {

mGroupID = groupID;
return this;

}

public Pattern getOTPPattern() {

return mOTPPattern;
}

public SMSRule setOTPPattern(final Pattern otpPattern) {

mOTPPattern = otpPattern;
return this;
}

}
< /code>

[b] mainactivity.java[/b]

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.widget.EditText;

import java.util.ArrayList;
import java.util.List;
import java.util.regex.Pattern;

import auro.widget.OTP.OTPAutoRead;
import auro.juspay.widget.OTP.SMS.SMSRule;

public class MainActivity extends AppCompatActivity {

private EditText editText;

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);

editText = (EditText) findViewById(R.id.editText);

SMSRule rule = new SMSRule();
Pattern pattern = Pattern.compile("One Time Password is (\\d{6})".toUpperCase());

rule.setSender("BANK-XYZ");
rule.setOTPPattern(pattern);

List  smsRules = new ArrayList();
smsRules.add(rule);

OTPAutoRead otpAutoRead = new OTPAutoRead(this,smsRules);

String OTP = otpAutoRead.getOTP();

if (OTP != null)
{
editText.setText(OTP);
}
}

}
Проблема , когда я запускаю это в режиме отладки , я получаю matchfound = false . Я также попытался изменить regex < /code> на < /p>

Код: Выделить всё

Pattern pattern = Pattern.compile("One Time Password is \d{6}".toUpperCase());


это просто не сработало бы

.>

Подробнее здесь: https://stackoverflow.com/questions/391 ... in-android
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Android»