当前位置: 编程技术>移动开发
本页文章导读:
▪透过手机发送短信的程序 通过手机发送短信的程序
最近几天研究通过数据线把手机和电脑连接起来,然后发送手机短信,看了点PDU编码的东西,那个PDU编码的东东害的我花费了两天时间没有发送出短信,而同事在.........
▪ 一些惯用的接口及sdk资源收集 一些常用的接口及sdk资源收集
新浪微博sdkhttp://open.weibo.com/wiki/SDKAndroid口袋微博案例http://open.weibo.com/wiki/Android%E5%8F%A3%E8%A2%8B%E5%BE%AE%E5%8D%9A%E6%A1%88%E4%BE%8B
......
▪ Widget中PendingIntent跟RemoteViews用法 Widget中PendingIntent和RemoteViews用法
PendingIntent是指把Intent包装了一层, 并且把PendingIntent放入一个新的进程. 通过触发事件去触发这个PendingIntent.创建PendingIntent方法.1. getActivity(Context context, int reques.........
[1]透过手机发送短信的程序
来源: 互联网 发布时间: 2014-02-18
通过手机发送短信的程序
最近几天研究通过数据线把手机和电脑连接起来,然后发送手机短信,看了点PDU编码的东西,那个PDU编码的东东害的我花费了两天时间没有发送出短信,而同事在无意中看到其编码的规则,加上我的理解,做些记录。
首先,通过手机发送中文短信,必须采用PDU的编码方式发送短信,所以在先要发送AT指令,告诉手机,发的是PDU编码:(C#伪代码)
SerialPort port
command = AT+CMGF=0
port.Write(command + "\r");
其次,再告诉手机,你的整个PDU的编码长度是多少:
int cnt = 15 + (pdu.Length - 32) / 2;
command = AT+CMGS=cnt;
port.Write(command + "\r");
String pdu = getPDUMessage(Message,PhoneNo);
//23=15+8,15是 PDU的编码规约头,固定是15,后面的8是你传的汉字的长度,一个汉字两个字符,所以这里的8是我传了4个汉字,规约头的购成见下面的PDU编码方法,即PDU的常量值
private string getPDUMessage(string Sms_Text, string Dest_Number)
{
string pdu = ""; //开始合成 PDU 串
pdu += "0011000D9168";
//SMSC中心号码补F凑成偶数
/*char[] tmpSmscNumber = ("13800100500" + "F").ToCharArray();
for (int i = 0; i < tmpSmscNumber.Length; i += 2) //字符两两对调
{
pdu += tmpSmscNumber[i + 1].ToString();
pdu += tmpSmscNumber[i].ToString();
}*/这段代码原来是要加上短信服务中心的号码,加上后不能发短信了,所以得去掉
char[] tmpDestNumber = (Dest_Number + "F").ToCharArray();//对方号码
for (int i = 0; i < tmpDestNumber.Length; i += 2) //字符两两对调
{
pdu += tmpDestNumber[i + 1].ToString();
pdu += tmpDestNumber[i].ToString();
}
pdu += "000800"; //08 表示采用 UCS2 编码
//短信正文转为Unicode
byte[] tmpSmsText = Encoding.Unicode.GetBytes(Sms_Text);
pdu += tmpSmsText.Length.ToString("X2"); //正文内容长度
for (int i = 0; i < tmpSmsText.Length; i += 2) //高低字节对调
{
pdu += tmpSmsText[i + 1].ToString("X2");//("X2")转为16进制
pdu += tmpSmsText[i].ToString("X2");
} //PDU串 完成
return pdu;
}
最后,发送PDU的短信
command = pdu + "\x01a";
port.Write(command);
我开始一直发送不成功的原因就是PDU的长度和实际长度不一致造成的
注意,里面的command是字符串,要用引号引起来
最近几天研究通过数据线把手机和电脑连接起来,然后发送手机短信,看了点PDU编码的东西,那个PDU编码的东东害的我花费了两天时间没有发送出短信,而同事在无意中看到其编码的规则,加上我的理解,做些记录。
首先,通过手机发送中文短信,必须采用PDU的编码方式发送短信,所以在先要发送AT指令,告诉手机,发的是PDU编码:(C#伪代码)
SerialPort port
command = AT+CMGF=0
port.Write(command + "\r");
其次,再告诉手机,你的整个PDU的编码长度是多少:
int cnt = 15 + (pdu.Length - 32) / 2;
command = AT+CMGS=cnt;
port.Write(command + "\r");
String pdu = getPDUMessage(Message,PhoneNo);
//23=15+8,15是 PDU的编码规约头,固定是15,后面的8是你传的汉字的长度,一个汉字两个字符,所以这里的8是我传了4个汉字,规约头的购成见下面的PDU编码方法,即PDU的常量值
private string getPDUMessage(string Sms_Text, string Dest_Number)
{
string pdu = ""; //开始合成 PDU 串
pdu += "0011000D9168";
//SMSC中心号码补F凑成偶数
/*char[] tmpSmscNumber = ("13800100500" + "F").ToCharArray();
for (int i = 0; i < tmpSmscNumber.Length; i += 2) //字符两两对调
{
pdu += tmpSmscNumber[i + 1].ToString();
pdu += tmpSmscNumber[i].ToString();
}*/这段代码原来是要加上短信服务中心的号码,加上后不能发短信了,所以得去掉
char[] tmpDestNumber = (Dest_Number + "F").ToCharArray();//对方号码
for (int i = 0; i < tmpDestNumber.Length; i += 2) //字符两两对调
{
pdu += tmpDestNumber[i + 1].ToString();
pdu += tmpDestNumber[i].ToString();
}
pdu += "000800"; //08 表示采用 UCS2 编码
//短信正文转为Unicode
byte[] tmpSmsText = Encoding.Unicode.GetBytes(Sms_Text);
pdu += tmpSmsText.Length.ToString("X2"); //正文内容长度
for (int i = 0; i < tmpSmsText.Length; i += 2) //高低字节对调
{
pdu += tmpSmsText[i + 1].ToString("X2");//("X2")转为16进制
pdu += tmpSmsText[i].ToString("X2");
} //PDU串 完成
return pdu;
}
最后,发送PDU的短信
command = pdu + "\x01a";
port.Write(command);
我开始一直发送不成功的原因就是PDU的长度和实际长度不一致造成的
注意,里面的command是字符串,要用引号引起来
[2] 一些惯用的接口及sdk资源收集
来源: 互联网 发布时间: 2014-02-18
一些常用的接口及sdk资源收集
新浪微博sdk
http://open.weibo.com/wiki/SDK
Android口袋微博案例
http://open.weibo.com/wiki/Android%E5%8F%A3%E8%A2%8B%E5%BE%AE%E5%8D%9A%E6%A1%88%E4%BE%8B
新浪微博sdk
http://open.weibo.com/wiki/SDK
Android口袋微博案例
http://open.weibo.com/wiki/Android%E5%8F%A3%E8%A2%8B%E5%BE%AE%E5%8D%9A%E6%A1%88%E4%BE%8B
[3] Widget中PendingIntent跟RemoteViews用法
来源: 互联网 发布时间: 2014-02-18
Widget中PendingIntent和RemoteViews用法
PendingIntent是指把Intent包装了一层, 并且把PendingIntent放入一个新的进程. 通过触发事件去触发这个PendingIntent.
创建PendingIntent方法.
1. getActivity(Context context, int requestCode, Intent intent, int flags)
2. getBroadcast(Context context, int requestCode, Intent intent, int flags)
3. getService(Context context, int requestCode, Intent intent, int flags)
例子:
在/res/xml中新建一个example_appwidget.xml
在/res/layout中新建一个example_widget.xml
main.xml的内容不变
ExampleAppWidgetProvider.java内容
AndroidManifest.xml
TargetActivity.java内容
PendingIntent是指把Intent包装了一层, 并且把PendingIntent放入一个新的进程. 通过触发事件去触发这个PendingIntent.
创建PendingIntent方法.
1. getActivity(Context context, int requestCode, Intent intent, int flags)
2. getBroadcast(Context context, int requestCode, Intent intent, int flags)
3. getService(Context context, int requestCode, Intent intent, int flags)
例子:
在/res/xml中新建一个example_appwidget.xml
<?xml version="1.0" encoding="utf-8"?> <appwidget-provider xmlns:android="http://schemas.android.com/apk/res/android" android:minWidth="294dp" android:minHeight="72dp" android:updatePeriodMillis="86400000" android:initialLayout="@layout/example_appwidget_info"> </appwidget-provider>
在/res/layout中新建一个example_widget.xml
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="match_parent" android:layout_height="match_parent"> <TextView android:text="firstWidgetText" android:background="#000000" android:id="@+id/widgetTextId" android:layout_width="fill_parent" android:layout_height="wrap_content"></TextView> <Button android:layout_width="match_parent" android:id="@+id/button1" android:text="Button" android:layout_height="wrap_content"></Button> </LinearLayout>
main.xml的内容不变
ExampleAppWidgetProvider.java内容
package com.cn; import android.app.PendingIntent; import android.appwidget.AppWidgetManager; import android.appwidget.AppWidgetProvider; import android.content.Context; import android.content.Intent; import android.widget.RemoteViews; public class ExampleAppWidgetProvider extends AppWidgetProvider { @Override public void onDeleted(Context context, int[] appWidgetIds) { System.out.println("onDeleted"); super.onDeleted(context, appWidgetIds); } @Override public void onDisabled(Context context) { System.out.println("onDisabled"); super.onDisabled(context); } @Override public void onEnabled(Context context) { System.out.println("onEnabled"); super.onEnabled(context); } @Override public void onReceive(Context context, Intent intent) { System.out.println("onReceive"); super.onReceive(context, intent); } @Override public void onUpdate(Context context, AppWidgetManager appWidgetManager, int[] appWidgetIds) { System.out.println("onUpdate"); for (int i = 0; i < appWidgetIds.length; i++) { System.out.println(appWidgetIds[i]); //创建一个intent对象 Intent intent = new Intent(context,TargetActivity.class); //创建一个PendingIntent PendingIntent pending = PendingIntent.getActivity(context, 0, intent, 0); RemoteViews remoteViews = new RemoteViews(context.getPackageName(),R.layout.example_widget); //第一个参数用来指定绑定事件的id //第二个参数指定事件发生时, 哪个pendingIntent会被执行 remoteViews.setOnClickPendingIntent(R.id.button1, pending); //第一个参数是更新哪个appwidget的id //第二个是传remoteView appWidgetManager.updateAppWidget(appWidgetIds[i], remoteViews); } super.onUpdate(context, appWidgetManager, appWidgetIds); } }
AndroidManifest.xml
<?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.cn" android:versionCode="1" android:versionName="1.0"> <uses-sdk android:minSdkVersion="10" /> <application android:icon="@drawable/icon" android:label="@string/app_name"> <activity android:name=".Appwidget2Activity" android:label="@string/app_name"> <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity> <receiver android:name="ExampleAppWidgetProvider"> <!-- 指定广播接收 --> <intent-filter> <action android:name="android.appwidget.action.APPWIDGET_UPDATE"></action> </intent-filter> <!-- appwidget的源文件 --> <meta-data android:name="android.appwidget.provider" android:resource="@xml/example_appwidget_info"></meta-data> </receiver> <activity android:name="TargetActivity"></activity> </application> </manifest>
TargetActivity.java内容
package com.cn; import android.app.Activity; import android.os.Bundle; public class TargetActivity extends Activity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); } }
最新技术文章: