通过编程方式实现短信息的发送对很多人来说是一件比较烦杂的事情,目前一般的解决方法是通过计算机和手机的连线,通过可对手机编程的语言编写相关的手机短信息程序来实现,而这种方法对于一般人来说是很难达到的,因为此种方法不仅要有很多必备的硬件设备,也还需懂得手机编程的相关知识。本文就来探讨一下另外一种通过visual c#发送短信息的简单实现方法,这种方法在实现过程中比我们想象的要简单许多,只需拥有visual c#一般编程基础,并确定您的计算机接入互联网即可。下面就来详细介绍一下visual c#发送短信息的具体实现过程。
一. visual c#发送短信息的原理:
我想当很多读者一看到本文的题目一定会想本文内容一定非常深奥,并且作者一定知道了电信的发送短信的网关地址,其实并非如此。本文其实是利用一个现成的资源,一个可发送短信的web serviec。这个web service就是新浪网就提供的一个,可供用户直接调用的发送短消息的web service。这个service的地址是http://smsinter.sina.com.cn/ws/smswebservice0101.wsdl。在这个service中提供了一个发送短消息的方法"sendxml"。此方法的语法格式如下:
string sendxml (carrier , userid , password , mobilenumber , content , msgtype )
sendxml方法中的六个参数均为string类型,并且sendxml方法的返回值也是string类型。
以下是sendxml方法中的六个参数的具体说明:
·carrier:运营商名称,具体使用时此参数并没有什么具体要求,即这里面可以随便输,输入的字符串也不会在对方手机中有任何显示。
·userid:在新浪网上注册的手机号,注册手机所用的地址是:http://sms.sina.com.cn,具体注册方法下面会具体介绍。
·password:您在新浪网成功注册手机后,新浪网所反馈来的密码。
·mobilenumber:要发送短信到对方的手机号码。
·content:所要发送短消息的内容。
·msgtype:发送短消息的类型,由于本文发送的不是彩信,所以输入"text"。
调用此web service只需在visual c#开发环境中直接添加web引用,把该地址输入即可,就可以使用此web service中的sendxml方法发送短消息了。当然发送短消息的机器必须接入互联网。
二.在新浪网上注册手机:
按照如下步骤就可在新浪网上注册手机:
1. 打开浏览器,并在地址栏中输入新浪无线的地址:http://sms.sina.com.cn.。在浏览器德左上角,可见如图01界面:
![]() 图01:新浪网注册手机界面之一 |
输入手机号后,单击图01中的"登陆",如果你的手机没有在新浪,则提示如图02所示信息。
![]() 图02:新浪网注册手机界面之二 |
2. 按照图02中的选项输入相应的信息后,单击"登陆移动梦网"按钮,如果注册成功,移动梦网则会向你注册的手机上发送一个8位长度的口令就可以得到图03所示界面。
![]() 图03:新浪网注册手机界面之三 |
这个口令要保留,下面发送短信就要使用这个口令。
三.本文程序设计、调试和运行的环境:
(1).微软公司视窗2000服务器版。
(2).visual studio .net 2003企业构建版,.net framework sdk版本号4322。
四.visual c#实现短信息发送的具体实现步骤:
visual c#发送短信息的关键就是通过web引用新浪网提供的发送短信息的web service,并在引用完成后。调用此service的sendxml方法即可。以下就是visual c#引用web service发送短信息的具体实现步骤:
1. 启动visual studio .net。
2. 选择菜单【文件】|【新建】|【项目】后,弹出【新建项目】对话框。
3. 将【项目类型】设置为【visual basic项目】。
4. 将【模板】设置为【windows应用程序】。
5. 在【名称】文本框中输入【短信】。
6. 在【位置】的文本框中输入【e:\vs.net项目】,然后单击【确定】按钮,这样在"e:\vs.net项目"目录中就产生了名称为"短信"的文件夹,并在里面创建了名称为"短信"的项目文件。
7. 把visual studio .net的当前窗口切换到【form1.cs(设计)】窗口,并从【工具箱】中的【windows窗体组件】选项卡中往form1窗体中拖入下列组件,并执行相应的操作:
四个label组件。
四个textbox组件。
一个button组件,其作用是发送短信息。并在这个button组件拖入form1的设计窗体后,双击它,则系统会在form1.cs文件分别产生这个组件的click事件对应的处理代码。
8. 把visual studio .net的当前窗口切换到form1.vb的代码编辑窗口,并用下列代码替换form1.cs中的initializecomponent过程对应的代码,下列代码作用是初始化窗体中加入的组件:
| private void initializecomponent ( ) { this.textbox1 = new system.windows.forms.textbox ( ) ; this.textbox2 = new system.windows.forms.textbox ( ) ; this.textbox3 = new system.windows.forms.textbox ( ) ; this.button1 = new system.windows.forms.button ( ) ; this.label1 = new system.windows.forms.label ( ) ; this.label2 = new system.windows.forms.label ( ) ; this.label3 = new system.windows.forms.label ( ) ; this.label4 = new system.windows.forms.label ( ) ; this.textbox4 = new system.windows.forms.textbox ( ) ; this.suspendlayout ( ) ; this.textbox1.location = new system.drawing.point ( 144 , 16 ) ; this.textbox1.name = "textbox1" ; this.textbox1.size = new system.drawing.size ( 184 , 21 ) ; this.textbox1.tabindex = 0 ; this.textbox1.text = "" ; this.textbox2.location = new system.drawing.point ( 144 , 69 ) ; this.textbox2.name = "textbox2" ; this.textbox2.passwordchar = ''''''''*'''''''' ; this.textbox2.size = new system.drawing.size ( 184 , 21 ) ; this.textbox2.tabindex = 1 ; this.textbox2.text = "" ; this.textbox3.location = new system.drawing.point ( 144 , 122 ) ; this.textbox3.name = "textbox3" ; this.textbox3.size = new system.drawing.size ( 184 , 21 ) ; this.textbox3.tabindex = 2 ; this.textbox3.text = "" ; this.button1.location = new system.drawing.point ( 152 , 256 ) ; this.button1.name = "button1" ; this.button1.size = new system.drawing.size ( 80 , 32 ) ; this.button1.tabindex = 4 ; this.button1.text = "发送" ; this.button1.click += new system.eventhandler ( this.button1_click ) ; this.label1.location = new system.drawing.point ( 56 , 24 ) ; this.label1.name = "label1" ; this.label1.size = new system.drawing.size ( 88 , 16 ) ; this.label1.tabindex = 5 ; this.label1.text = "注册手机号:" ; this.label2.location = new system.drawing.point ( 88 , 77 ) ; this.label2.name = "label2" ; this.label2.size = new system.drawing.size ( 72 , 16 ) ; this.label2.tabindex = 6 ; this.label2.text = "口令:" ; this.label3.location = new system.drawing.point ( 56 , 128 ) ; this.label3.name = "label3" ; this.label3.size = new system.drawing.size ( 96 , 16 ) ; this.label3.tabindex = 7 ; this.label3.text = "目标手机号:" ; this.label4.location = new system.drawing.point ( 96 , 176 ) ; this.label4.name = "label4" ; this.label4.size = new system.drawing.size ( 72 , 16 ) ; this.label4.tabindex = 8 ; this.label4.text = "内容:" ; this.textbox4.location = new system.drawing.point ( 144 , 175 ) ; this.textbox4.multiline = true ; this.textbox4.name = "textbox4" ; this.textbox4.size = new system.drawing.size ( 184 , 48 ) ; this.textbox4.tabindex = 3 ; this.textbox4.text = "" ; this.autoscalebasesize = new system.drawing.size ( 6 , 14 ) ; this.clientsize = new system.drawing.size ( 410 , 303 ) ; this.controls.add ( this.button1 ) ; this.controls.add ( this.textbox4 ) ; this.controls.add ( this.textbox3 ) ; this.controls.add ( this.textbox2 ) ; this.controls.add ( this.textbox1 ) ; this.controls.add ( this.label4 ) ; this.controls.add ( this.label3 ) ; this.controls.add ( this.label2 ) ; this.controls.add ( this.label1 ) ; this.formborderstyle = system.windows.forms.formborderstyle.fixedsingle ; this.maximizebox = false ; this.name = "form1" ; this.text = "visual c#实现短信发送" ; this.resumelayout ( false ) ; } |
至此【短信】项目的界面设计和功能实现的准备工作就完成了,具体如图04所示:
![]() 图04:【短信】项目的设计界面 |
9. 选中【短信】的【解决方法资源管理器】,右击【引用】,弹出【添加web引用】对话框。在此对话框中的【url】文本框中输入"http://smsinter.sina.com.cn/ws/smswebservice0101.wsdl"后,单击【转到】按钮,则会得到图05所示界面:
![]() 图05:在【短信】项目中添加web引用的界面 |
此时单击图04中的【添加引用】按钮,则成功实现在【短信】项目中添加可发送短信息的新浪网提供的web service。
10. 把visual stuido .net的当前窗口切换到form1.cs的代码编辑窗口,并用下列代码替换from1.cs中的button1的click事件对应的代码,下列代码的作用是调用引入的web service中提供的sendxml方法向指定手机发送短信息:
| private void button1_click ( object sender , system.eventargs e ) { 短信.cn.com.sina.smsinter.smsws ws = new 短信.cn.com.sina.smsinter.smsws ( ) ; string result = ws.sendxml ( "sina" ,textbox1.text ,textbox2.text ,textbox3.text ,textbox4.text ,"new" ) ; messagebox.show ( result ) ; } |
11. 至此,在上述步骤都正确执行后,【短信】项目的全部工作就完成了。单击快捷键f5运行程序,在输入【注册手机号】、【口令】、【目标手机号】和【内容】后,单击【发送】按钮后,程序就会向指定的手机号发送短信息了。
五.总结:
本文介绍的这种visual c#发送短信息方法,其解决关键是引用web service,调用此web service中的方法。通观全文,此种方法是不是很简单。最后还要提醒诸位,利用这种发送短信息并不是免费的午餐,其资费标准可参看新浪无线网站上的相关说明,每发送一条收费一角钱,从在新浪网注册的手机上收费。在使用本文介绍的方法发送短信息时,在发送完成后,一般会有一个延迟。这是因为后台采用了了消息队列机制,不过这种延迟一般只会有几秒钟的时间。





