2011-12-17 20 views
1

JavaコードでSMSを送信しようとしています。英語のSMSを送信するとうまく動作します。しかし、私は下のロシアのメッセージを試してみると失敗します。それはNullPointerExceptionを投げます。SMSを送信中に奇妙なエラーが発生しました

String message = "Здравствуйтe, сейчас я не могу ответить на Ваш звонок. Перезвоните через 10 минут, если Вам не ответили. Спасибо"; 
PendingIntent pi = PendingIntent.getActivity(this, 0, 
    new Intent(this, RussianSmsProblemActivity.class), 0);     
SmsManager sms = SmsManager.getDefault(); 

sms.sendTextMessage("5556", null, message,sentPI,deliveredPI);//getting Null Pointer Exception here 

コードに問題がない、NullPointerExceptionがAndroidのAPIで提供されます。いくつかの専門家にこの問題についてのガイドをお願いしてください。

ここ

例外スタックトレースがある...

12-15 16:48:32.994: ERROR/AndroidRuntime(347): FATAL EXCEPTION: main 
    12-15 16:48:32.994: ERROR/AndroidRuntime(347): java.lang.NullPointerException 
    12-15 16:48:32.994: ERROR/AndroidRuntime(347):  at android.os.Parcel.readException(Parcel.java:1328) 
    12-15 16:48:32.994: ERROR/AndroidRuntime(347):  at android.os.Parcel.readException(Parcel.java:1276) 
    12-15 16:48:32.994: ERROR/AndroidRuntime(347):  at com.android.internal.telephony.ISms$Stub$Proxy.sendText(ISms.java:369) 
    12-15 16:48:32.994: ERROR/AndroidRuntime(347):  at android.telephony.SmsManager.sendTextMessage(SmsManager.java:87) 
    12-15 16:48:32.994: ERROR/AndroidRuntime(347):  at android.telephony.gsm.SmsManager.sendTextMessage(SmsManager.java:79) 
    12-15 16:48:32.994: ERROR/AndroidRuntime(347):  at com.test.RussianSmsProblemActivity.sendSms(RussianSmsProblemActivity.java:102) 
    12-15 16:48:32.994: ERROR/AndroidRuntime(347):  at com.test.RussianSmsProblemActivity$1.onClick(RussianSmsProblemActivity.java:39) 
    12-15 16:48:32.994: ERROR/AndroidRuntime(347):  at android.view.View.performClick(View.java:2485) 
    12-15 16:48:32.994: ERROR/AndroidRuntime(347):  at android.view.View$PerformClick.run(View.java:9080) 
    12-15 16:48:32.994: ERROR/AndroidRuntime(347):  at android.os.Handler.handleCallback(Handler.java:587) 
    12-15 16:48:32.994: ERROR/AndroidRuntime(347):  at android.os.Handler.dispatchMessage(Handler.java:92) 
    12-15 16:48:32.994: ERROR/AndroidRuntime(347):  at android.os.Looper.loop(Looper.java:123) 
    12-15 16:48:32.994: ERROR/AndroidRuntime(347):  at android.app.ActivityThread.main(ActivityThread.java:3683) 
    12-15 16:48:32.994: ERROR/AndroidRuntime(347):  at java.lang.reflect.Method.invokeNative(Native Method) 
    12-15 16:48:32.994: ERROR/AndroidRuntime(347):  at java.lang.reflect.Method.invoke(Method.java:507) 
    12-15 16:48:32.994: ERROR/AndroidRuntime(347):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839) 
    12-15 16:48:32.994: ERROR/AndroidRuntime(347):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597) 
    12-15 16:48:32.994: ERROR/AndroidRuntime(347):  at dalvik.system.NativeStart.main(Native Method) 
+1

Logcat出力も入れてください。 –

+0

私は答えを知りたいと思うだろう。 –

答えて

1

あなたはSmsManagerにそれを渡す前に、さまざまな方法でString messageをエンコードしようとしたことがありますか?

+0

Stringをエンコードすることで何を意味するのかをお聞かせください。 'メッセージ=新しい文字列( "Здравствуйтe、сейчасянемогуответитьнаВашзвонокПерезвонитечерез10минут、еслиВамнеответилиСпасибо。" .getBytes()、 "UTF-8" – user835791

+0

私は明示的に符号化タイプを述べることを意味しました); 'しかし、修正されたバグを見つけたようです:' 'でコードを実行してください。 – Nick

3

ロシア語の文字がUTF-8で2バイトを消費するため、これが起こっていると思います。メッセージが160バイト制限を超えています。代わりにsendMultiPartMessage()を使用してみてください。

関連する問題