2

256バイトの長さのmd5のような文字列を160文字以内に圧縮できないため、Androidでマルチパートメッセージを使用してSMSをいくつかの部分に分割すると、受信者はSMSをリッスンし、それらのメッセージを結合することにしました。

ここから組み合わせアルゴリズムを使用します:Android-長いSMSの受信(マルチパート)

そして、いくつかのテストの結果、送信する前にBase64でエンコードしたにもかかわらず、送信したSMSが完全に混乱していることがわかりました。

SMSは7ビットのエンコーディング方法だと思っていたので、エンコーディングの問題かもしれないと思いました。

しかし、Base 64でエンコードされたメッセージを正常に送信しましたが、それは短く、1SMS以内でした。

私の質問は:

エンコードの問題である場合、160文字以内で完全に読み取り可能なBase64エンコードメッセージを送信できるのに、160文字を超えるメッセージを送信すると読み取り可能な結果が得られないのはなぜですか?

ここにコードを添付しました:送信する予定の文字列:

static final String bigNum = "C196BA05AC29E1F9C3C72D56DFFC6154A033F1477AC88EC37F09BE6C5BB95F51C296DD20D1A28A067CCC4D4316A4BD1DCA55ED1066D438C35AEBAABF57E7DAE428782A95ECA1C143DB701FD48533A3C18F0FE23557EA7AE619ECACC7E0B51652A8776D02A425567DED36EABD90CA33A1E8D988F0BBB92D02D1D20290113BB562CE1FC856EEB7CDD92D33EEA6F410859B179E7E789A8F75F645FAE2E136D252BFFAFF89528945C1ABE705A38DBC2D364AADE99BE0D0AAD82E5320121496DC65B3930E38047294FF877831A16D5228418DE8AB275D7D75651CEFED65F78AFC3EA7FE4D79B35F62A0402A1117599ADAC7B269A59F353CF450E6982D3B1702D9CA83";

コード

private void sendMsg (String phoneNum, String msg) {
    SmsManager sms = SmsManager.getDefault();
    ArrayList<String> parts = sms.divideMessage(msg);
    sms.sendMultipartTextMessage(phoneNum, null, parts, null, null);
}

public void onStart() {
    super.onStart();
    final String bigNum64 = Base64.encodeToString(bigNum.getBytes(), 0);
    button.setOnClickListener(new OnClickListener() {
        public void onClick(View v) {
            sendMsg("5554", bigNum64);
            textView.setText(bigNum64);
        }
    });
}

public void onResume() {
    super.onResume();
    Bundle receiver = getIntent().getExtras();
    if (receiver != null) {
        String msg = receiver.getString("SMS");
        textView.setText("Received" + msg);
    }
}
}

SMSレシーバー:

public void onReceive(Context context, Intent intent) {
    // TODO Auto-generated method stub
    Bundle bundle = intent.getExtras();
    Object[] pdus = (Object[]) bundle.get("pdus");
    SmsMessage[] messages = new SmsMessage[pdus.length];
    String body = "";
    for (int i = 0; i < pdus.length; i++) {
        messages[i] = SmsMessage.createFromPdu((byte[]) pdus[i]);
    }
    SmsMessage sms = messages[0];
    try {
        if (messages.length == 1 || sms.isReplace()) {
            body = sms.getDisplayMessageBody();

        }
        else {
            StringBuilder bodyText = new StringBuilder();
            for (int i = 0; i < messages.length; i++) {
                bodyText.append(messages[i].getMessageBody());
            }
            body = bodyText.toString();
        }
    }
    catch (Exception e) {

    }
    Intent start = new Intent(context, SendLongSMSActivity.class);
    start.putExtra("SMS", body);
    start.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
    context.startActivity(start);
}

ご協力いただきありがとうございます!

関連記事:256バイトの「MD5のような」文字列を160バイト以下に圧縮する方法はありますか?

かなり単純な長い文字列を与えても

"0123456789ABCDEF0123456789ABCDEF0123456789ABCDEF0123456789ABCDEF0123456789ABCDEF0123456789ABCDEF0123456789ABCDEF0123456789ABCDEF0123456789ABCDEF0123456789ABCDEF0123456789ABCDEF"

また、Base64エンコーディングの有無に関係なく、受信者は正しい結果を得ることができません。

更新#2

テストに実際の電話を使用すると、受信者はbase 64なしで正しいメッセージを受信できます。これは、エミュレーターがテキストを文字化けさせたことが原因でした。

質問は終了しました。

助けてくれたみんなに感謝します!そして@Danに感謝します

アップデート:

2つの部分に分割されたbase64なしの文字列"0123456789ABCDEF...":

part [0]    "0123456789ABCDEF0123456789ABCDEF0123456789ABCDEF0123456789ABCDEF0123456789ABCDEF0123456789ABCDEF0123456789ABCDEF0123456789ABCDEF0123456789ABCDEF012345678" 

part [1]    "9ABCDEF0123456789ABCDEF"   

これが「0123456789ABCDEF...」の分割されたbase64文字列です。

part[0] "MDEyMzQ1Njc4OUFCQ0RFRjAxMjM0NTY3ODlBQkNERUYwMTIzNDU2Nzg5QUJDREVGMDEyMzQ1Njc4\nOUFCQ0RFRjAxMjM0NTY3ODlBQkNERUYwMTIzNDU2Nzg5QUJDREVGMDEyMzQ1Njc4OUFCQ0RFRjAx"    

part[1] "\nMjM0NTY3ODlBQkNERUYwMTIzNDU2Nzg5QUJDREVGMDEyMzQ1Njc4OUFCQ0RFRjAxMjM0NTY3ODlB\nQkNERUY=\n"    
4

1 に答える 1

0

SMS分割は、77文字ごとに\ n文字を追加しているようです。最後に、文字列からそれらを削除するだけで、正しくデコードされます。

于 2011-08-03T16:50:24.540 に答える