单片机控制SIM900A型GSM模块发送数字短信(附源码)

一、模块概述

SIM900A是由SIMCom推出的新款紧凑型产品,它属于双频GSM/GPRS模块,完全采用SMT封装形式,SIM900A仅适用于中国市场,其性能稳定,外观精巧,性价比高。

SIM900A采用工业标准接口,工作频率为GSM/GPRS 850/900/1800/1900MHz,可以低功耗实现语音、SMS、数据和传真信息的传输。另外,SIM900A的尺寸大小为24x24x3mm,能适用于M2M应用中的各类设计需求,尤其适用于紧凑型产品设计。

二、产品特性与接口

2.1 SIM900A的主要特性

2.2 SIM900A的TTL电平接口

SIM900A模块提供两组TTL接口,一组为2.85V的TTL接口,可以与3.3V的单片机直接连接(已做了电平匹配);另一组为兼容各种电压的TTL电平,可以与5V、3.3V等单片机直接连接。连接时,需要将SIM900A的TXD与单片机的RXD连接,SIM900A的RXD与单片机的TXD相连接,GND与单片机的GND相连接。例如,模块与普通51系列单片机(TTL电平为5V)的连接应该是:SIM900A的5VT连接到单片机的P3.0管脚,SM900A的5VR连接到单片机的P3.1管脚,SM900A的VCC_MCU连接到直流5V上,SM900A的GND连接到单片机的GND上。如果您的单片机的TTL电平电压为3.3V时,可将单片机的TXD连接到模块上的5VR,将单片机的RXD连接到模块上的5VT,单片机的GND连接到模块的GND,模块上的VCC_MCU接到直流3.3V上。 从这里可以看出来,模块上5VR、5VT 是可以兼容单片机各种TTL电平接口的。接不同的单片机TTL电平接口时,只要保证模块上VCC_MCU接入的电压跟单片机的TTL电平电压一致就可以了。

三、模块供电

SIM900A模块提供一路电源接口,需要接入5V 1A或1A以上的直流电源,推荐1.5A以上的直流电源。模块的正负极在板子的后面有标出:VCC代表接入电源正极,GND代表接入电源负极。电源接口如下图所示:

电源电路设计如下。注意 IN4007允许通过的最大电流为1A,推荐在VCC_4电源正负极跨接1000UF或以上的极性电容

 

四、模块工作状态指示

五、用到的AT指令

1. AT+CSCS="UCS2"

设置为16位通用8字节倍数编码字符集

2. AT+CMGF=1

设置短信为文本格式

3. AT+CSCA?

提供短消息服务中心的号码

4. AT+CSMP=17,167,0,25

在SUBMIT(提交)消息时,SMSC(短消息服务中心)收到消息起的有效时间为24,协议标识为“0”,编码方式为UNICODE

5. AT+CMGS="*************"

设置接收方手机号,*********为接收方手机号的Unicode码

六、例程(例程均为自己编写且通过验证成功)

6.1 头文件定义(.h)

/*该头文件是Sim900a的头文件*/

#ifndef __Sim_H
#define __Sim_H

void Delay1ms(unsigned int x);//一毫秒延时子函数
void Uart1Sends(unsigned char *str);//发送字符串
void SendOneByte(unsigned char c);//发送一字节
void InitUART();//串口初始化
void Change(unsigned int x);//unicode码转化
void Send(unsigned int t,unsigned int ppm);//发送两个数值

#endif

6.2 函数体(.c)

#include<reg51.h>
#include<Sim.h>/

char mess[40];//短信内容的unicode码的倒序排列
unsigned char count;

/*毫秒级延时子函数*/
void Delay1ms(unsigned int x)   //误差 -0.651041666667us
{
    unsigned char a,b;
    while(x>0)
    {
        for(b=4;b>0;b--)
            for(a=113;a>0;a--);
        x--;
    }
}
/*串口初始化*/
void InitUART()
{
    TMOD = 0x20;
    SCON = 0x40;
    TH1 = 0xFD;
    TL1 = TH1;
    PCON = 0x00;
    EA = 1;
    ES = 0;//关闭串口中断
    TR1 = 1;
}

/*给mess赋值*/
void Change(unsigned int x)
{
	char count1=0;
	unsigned char  a[5];
	while(x>0)//温度取位
	{
		a[count1]=x%10;
		x/=10;
		count1++;
	}
	count1--;//减去多于的count1
	while(count1>=0)//转化温度
	{
		switch(a[count1])
		{
			case 0:mess[count]='0';count++;mess[count]='0';count++;mess[count]='3';count++;mess[count]='0';count++;break;
			case 1:mess[count]='0';count++;mess[count]='0';count++;mess[count]='3';count++;mess[count]='1';count++;break;
			case 2:mess[count]='0';count++;mess[count]='0';count++;mess[count]='3';count++;mess[count]='2';count++;break;
			case 3:mess[count]='0';count++;mess[count]='0';count++;mess[count]='3';count++;mess[count]='3';count++;break;
			case 4:mess[count]='0';count++;mess[count]='0';count++;mess[count]='3';count++;mess[count]='4';count++;break;
			case 5:mess[count]='0';count++;mess[count]='0';count++;mess[count]='3';count++;mess[count]='5';count++;break;
			case 6:mess[count]='0';count++;mess[count]='0';count++;mess[count]='3';count++;mess[count]='6';count++;break;
			case 7:mess[count]='0';count++;mess[count]='0';count++;mess[count]='3';count++;mess[count]='7';count++;break;
			case 8:mess[count]='0';count++;mess[count]='0';count++;mess[count]='3';count++;mess[count]='8';count++;break;
			case 9:mess[count]='0';count++;mess[count]='0';count++;mess[count]='3';count++;mess[count]='9';count++;break;
		}
		count1--;
	}
					
}

/*发送一个字节*/
void SendOneByte(unsigned char c)
{
    SBUF = c;
    while(!TI);
    TI = 0;
}

//串行口连续发送char型数组,遇到终止号'/0'将停止
void Uart1Sends(unsigned char *str)
{
	while(*str!='\0')
	{
		SBUF=*str;
		while(!TI);
		TI=0;
		str++;
	}
}

void Send(unsigned t,unsigned int ppm)
{
	InitUART();//串口初始化
	count=0;//使用前清零
	Change(t);
	mess[count]='0';count++;mess[count]='0';count++;mess[count]='2';count++;mess[count]='0';count++;
	Change(ppm);
	mess[count]='\0';
	Uart1Sends("AT+CSCS=\"UCS2\"\r\n");
	Delay1ms(3000);
	Uart1Sends("AT+CMGF=1\r\n");
	Delay1ms(3000);
	Uart1Sends("AT+CSCA?\r\n");
	Delay1ms(3000);
	Uart1Sends("AT+CSMP=17,167,0,25\r\n");
	Delay1ms(3000);
	Uart1Sends("AT+CMGS=\"******************\"\r\n");//此处修改为对方的电话号的unicode值
	Delay1ms(3000);
	Uart1Sends(&mess);//修改短信内容
	Delay1ms(5000);
	SendOneByte(0x1a);
	Delay1ms(20000);

}

 

注:想要UNICODE转码工具的可以私聊我,我会发给大家

 

左肩理想,右肩担当。君子不怨永远不会停下脚步!

 

 

 

 

 

 

  • 31
    点赞
  • 252
    收藏
    觉得还不错? 一键收藏
  • 28
    评论
以下是使用SIM900A模块和32单片机发送短信的示例代码: ```c #include <REG51.H> #include <stdio.h> #include <string.h> #define FREQ_OSC 12000000UL // 定义振荡器频率为12MHz #define BAUD_RATE 9600 // 串口波特率 sbit SIM900A_ON = P1^0; // SIM900A模块开关引脚 sbit SIM900A_RST = P1^1; // SIM900A模块复位引脚 void delay_ms(unsigned int ms) // 延时函数 { unsigned int i, j; for(i = 0; i < ms; i++) { for(j = 0; j < 120; j++); } } void init_uart() // 初始化串口 { TMOD |= 0x20; // 设置定时器1为模式2 TH1 = 256 - FREQ_OSC / (32 * BAUD_RATE); // 设置波特率 TL1 = TH1; TR1 = 1; // 启动定时器1 SM0 = 0; // 串口工作在模式1,波特率可变 SM1 = 1; REN = 1; // 允许接收数据 TI = 0; // 清除发送完成标志 RI = 0; // 清除接收完成标志 } void send_char(char c) // 发送一个字符 { SBUF = c; while(!TI); // 等待发送完成 TI = 0; } void send_string(char *str) // 发送一个字符串 { while(*str) { send_char(*str++); } } void init_sim900a() // 初始化SIM900A模块 { SIM900A_RST = 0; // 拉低复位引脚 delay_ms(100); SIM900A_RST = 1; // 拉高复位引脚 delay_ms(5000); // 等待SIM900A模块启动完成 send_string("AT\r\n"); // 发送AT指令,检测SIM900A模块是否正常工作 delay_ms(1000); send_string("AT+CMGF=1\r\n"); // 设置短信格式为文本模式 delay_ms(500); } void send_sms(char *phone_number, char *message) // 发送短信 { char buffer[40]; send_string("AT+CMGS=\""); send_string(phone_number); send_string("\"\r\n"); // 设置短信接收号码 delay_ms(1000); sprintf(buffer, "%s%c", message, 26); // 将发送内容和Ctrl+Z组合成一个字符串 send_string(buffer); delay_ms(3000); // 短信发送需要一定时间,延长等待时间 } void main() { init_uart(); // 初始化串口 init_sim900a(); // 初始化SIM900A模块 send_sms("13812345678", "Hello, world!"); // 发送短信 while(1); } ``` 这段代码使用了定时器1来控制串口波特率,并实现了发送一个字符和发送一个字符串的函数。在初始化SIM900A模块时,需要先将复位引脚拉低一段时间,然后再拉高。在发送短信时,需要先设置短信接收号码和短信格式,并将发送内容和Ctrl+Z组合成一个字符串发送
评论 28
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值