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"