Windows Mobile 发送短信

Windows Mobile发送短信应用分为两种,一是调用Windows Mobile自有的发送短信窗口,将接收用户的手机号码传递给该窗口,完成短信发送(暂且称为窗口短信),另一种是通过调用API将文本发送给指定的号码,这中发送方式对于用户是无感知的(暂且称为无感知短信,下面对这两种方式的实现分别介绍。

窗口短信:
窗口短信实现比较简单,可以直接使用下面的启动参数启动系统的EXE文件即可, System.Diagnostics.Process.Start("tmail.exe", "-transport /"SMS/" -to /"" + 手机号码 + "/" -body /"短信内容/"");但要注意的是,在发送完毕后,短信列表页面会在你关闭发送信息窗口后呈现出来,可以在页面的关闭事件中,使用FindWind方法,找到系统的【短信】窗口,将其关闭即可。

无感知短信
1.Windows Mobile 5.0及以上版本
无感知短信接口与Mobile操作系统的版本有关,如果是基于Windows Mobile5.0 的设备 ,完成短信发送比较容易,因为微软已经给你封装好了底层的API,可以直接进行调用,引用Microsoft.WindowsMobile.PocketOutlook.dll后,使用SmsMessage smsSend = new SmsMessage(phone, sms);smsSend.Send();方法便可以完成对一条短息的发送。

2.Windows Mobile 2003或Windows Mobile2003SE设备
在5.0以前的版本,虽然现在使用量比较小了,但是在2年前,在其上面发送短息可以说很是费劲,当时确实还让我头疼了一段时间,需要用户自己封装底层的API,然后进行调用,我这里有一个,贴出来,以供大家参考
using System;
using System.Runtime.InteropServices;
using System.Text;

namespace SmartSMS
{
    /// <summary>
    /// 短信发送程序
    /// </summary>
    public class SMS
    {
        public SMS()
        {
            //
            // TODO: 在此处添加构造函数逻辑
            //
        }
        private const string SMS_MSGTYPE_TEXT = "Microsoft Text SMS Protocol";
        private const int SMS_MODE_SEND = 2;             // Open in send mode
        private const int SMSDE_GSM = 2;                 // Use standard GSM encoding
        private const int SMSAT_INTERNATIONAL = 1;       // International number format
        private const int PS_MESSAGE_OPTION_NONE = 0;    // No message options
        private const int PS_MESSAGE_CLASS0 = 0;         // Show but do not store
        private const int PS_MESSAGE_CLASS1 = 1;         // Store and show
        private const int PSRO_NONE = 0;                 // No replacements
        private const int SMS_OPTION_DELIVERY_NONE = 0; // No delivery options
        private const int SMS_MAX_ADDRESS_LENGTH = 256; // Max length of address

        [DllImport("sms.dll")]
        private static extern int SmsOpen(
            string ptsMessageProtocol,
            int dwMessageModes,
            ref IntPtr psmshHandle,
            int phMessageAvailableEvent);

        [DllImport("sms.dll")]
        private static extern int SmsSendMessage(
            IntPtr smshHandle,
            int psmsaSMSCAddress,
            IntPtr psmsaDestinationAddress,
            int pstValidityPeriod,
            IntPtr pbData,
            int dwDataSize,
            IntPtr pbProviderSpecificData,
            int dwProviderSpecificDataSize,
            int smsdeDataEncoding,
            int dwOptions,
            int psmsmidMessageID);

        [DllImport("sms.dll")]
        private static extern int SmsClose(IntPtr smshHandle);

        [DllImport("coredll.dll")]
        private static extern IntPtr LocalAlloc(uint uFlags, uint uBytes);

        [DllImport("coredll.dll")]
        internal static extern IntPtr LocalFree(IntPtr hMem);

        private static IntPtr AllocHGlobal(IntPtr cb)
        {
            IntPtr hmem;

            hmem = LocalAlloc(0x40, (uint) cb);
            return hmem;
        }

        private static void FreeHGlobal(IntPtr hglobal)
        {
            LocalFree(hglobal);
        }

        public static int SendSMS(string Number, string Message)
        {
            int returnValue = 0;
            IntPtr smsHandle = new IntPtr(0);

            // Set address structure
            byte[] smsatAddressType = BitConverter.GetBytes(SMSAT_INTERNATIONAL);
            byte[] ptsAddress = Encoding.Unicode.GetBytes(Number);
            byte[] smsAddressTag = new byte[smsatAddressType.Length + ptsAddress.Length];
            Array.Copy(smsatAddressType, 0, smsAddressTag, 0, smsatAddressType.Length);
            Array.Copy(ptsAddress, 0, smsAddressTag, smsatAddressType.Length, ptsAddress.Length);
            IntPtr smsAddress = AllocHGlobal((IntPtr)smsAddressTag.Length);
            Marshal.Copy(smsAddressTag, 0, smsAddress, smsAddressTag.Length);

            // Set provider data structure
            byte[] dwMessageOptions = BitConverter.GetBytes(PS_MESSAGE_OPTION_NONE);
            byte[] psMessageClass = BitConverter.GetBytes(PS_MESSAGE_CLASS1);
            byte[] psReplaceOption = BitConverter.GetBytes(PSRO_NONE);
            byte[] smsProviderDataTag = new byte[dwMessageOptions.Length +
                psMessageClass.Length +    psReplaceOption.Length];
            Array.Copy(dwMessageOptions, 0, smsProviderDataTag, 0, dwMessageOptions.Length);
            Array.Copy(psMessageClass, 0, smsProviderDataTag, dwMessageOptions.Length,
                psMessageClass.Length);
            Array.Copy(psReplaceOption, 0, smsProviderDataTag, dwMessageOptions.Length +
                psMessageClass.Length, psReplaceOption.Length);
            IntPtr smsProviderData = AllocHGlobal((IntPtr) smsProviderDataTag.Length);
            Marshal.Copy(smsProviderDataTag, 0, smsProviderData, smsProviderDataTag.Length);

            // Set message
//            Encoding unicode = Encoding.Unicode;
//            Encoding utf8 = Encoding.ASCII;
//            byte[] smsMessageTag1 = Encoding.ASCII.GetBytes(Message);
//            byte[] smsMessageTag = Encoding.Convert(utf8,unicode,smsMessageTag1);
            byte[] smsMessageTag = Encoding.Unicode .GetBytes(Message);
            IntPtr smsMessage = AllocHGlobal((IntPtr)smsMessageTag.Length);
            Marshal.Copy(smsMessageTag, 0, smsMessage, smsMessageTag.Length);

            // Get handle
            if (0 != SmsOpen(SMS_MSGTYPE_TEXT, SMS_MODE_SEND, ref smsHandle, 0))
                returnValue = -1; // Could not open

            // Send message
            if (0 != SmsSendMessage(smsHandle, 0, smsAddress, 0,
                smsMessage, smsMessageTag.Length,
                smsProviderData, smsProviderDataTag.Length,
                SMSDE_GSM, SMS_OPTION_DELIVERY_NONE, 0))
                returnValue = -2;

            FreeHGlobal(smsMessage);
            FreeHGlobal(smsProviderData);
            FreeHGlobal(smsAddress);

            // Release handle
            if (0 != SmsClose(smsHandle))
                returnValue = -3; // Could not close

            return returnValue;
        }
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
最近在网上看了一下,有很多利用飞信协议发送短信的程序,有基于Web的、有脚本写的、有C#写的、还有Delphi写的;一些是以Web API提供的,还有一些是以客户端用户界面形式提供的。感觉好像还缺点什么!于是写了一个基于命令行的和大家分享。 该程序使用VC ++ 6.0编译通过,后面为程序直接运行时的帮助信息。 作者联系方式:[email protected] [飞信]短信发送程序(v1.0.0) 作者:王真 日期:2009年5月25日 使用方法:FetionSMS [-d | -q] [-sms] <登录飞信手机号> <登录飞信密码> <目的标识 | 目的文件> <短信内容> 参数说明: -d : 导出联系人列表,文件名为“飞信联系人_手机号.txt”; -q : 使用快速模式,该模式下仅能使用飞信号或完整飞信URI发送短信; -sms : 强制发送短信模式;默认如果目的用户已登录,则发送至用户飞信客户端; 目的标识: 接收短信用户标识,可以是手机号、飞信号、完整飞信URI、飞信用户昵称; 目的文件: 用于群发短信,文件中每个接收短信的用户占一行,每行内容格式同“目的标识”,文件名必须以“.txt”的扩展名结尾; 短信内容: 最长180字符,超长的部分有可能会被服务器截断;如果内容中包含回车换行符,请用“\r\n”代替,“\”符号用“\\”代替; 特别说明: 本程序仅能向飞信好友和飞信用户自己发送短信,且长短信不分条,故使用本程序前请首先保证短信接收人是自己或是自己的飞信好友! 使用本程序会造成用户“已登录”状态的飞信客户端注销,故使用本程序后,用户可能需要手动重新登录飞信客户端! 本程序适用于中国移动飞信2008版本,请勿将本程序用于发送垃圾短信或用于其它非法用途,否则一切后果自负!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值