SIM9001GSM模块教程

博主最近在做一个项目,用到了GSM模块,博主不是什么单片机大神,只是感觉某宝附带的资料太水,所以上传一些自己写的程序和经验,供需要的人参考


1,拨打电话

/************************************************************
程序说明:
本程序运行后如果gprs模块找到服务商信号,就拨打指定电话。
1.将自己的51单片机的串口1连接到GSM 的232接口
2.找到程序中前面的#define处,根据说明修改好自己的单片机配置,编译程序
2.下载程序
3.等待接通电话


*************************************************************/
#include <REG51.H>

#define uchar unsigned char
#define uint unsigned int
//以下是板子上LED的配置,把Px_x改成自己对应的脚。

//以下是你的51单片机的晶振大小
#define FOSC_110592M
//#define FOSC_12M

//以下是开机后拨打的手机号,改成自己想要打的号码即可。
uchar num[] = "ATD15296811438;\r\n";
  
//注意,无论接收到信号还是发送完信号,都会进中断服务程序的
/*初始化程序(必须使用,否则无法收发),次程序将会使用定时器1*/
void SerialInti()//初始化程序(必须使用,否则无法收发)
{
	TMOD=0x20;//定时器1操作模式2:8位自动重载定时器

#ifdef FOSC_12M		   //在这里根据晶振大小设置不同的数值初始化串口
	TH1=0xf3;//装入初值,波特率2400
	TL1=0xf3;	
#else 	
	TH1=0xfd;//装入初值,波特率9600
	TL1=0xfd;
#endif //end of SOC_12M
	
	TR1=1;//打开定时器
	SM0=0;//设置串行通讯工作模式,(10为一部发送,波特率可变,由定时器1的溢出率控制)
	SM1=1;//(同上)在此模式下,定时器溢出一次就发送一个位的数据
	REN=1;//串行接收允许位(要先设置sm0sm1再开串行允许)
	EA=1;//开总中断
	ES=1;//开串行口中断	
}

/*串行通讯中断,收发完成将进入该中断*/
void Serial_interrupt() interrupt 4 
{
//	a=SBUF;
	P2=SBUF;
	RI=0;//接收中断信号清零,表示将继续接收
//	flag=1;//进入中断的标志符号
}

//串行口连续发送char型数组,遇到终止号/0将停止
void Uart1Sends(uchar *str)
{
	while(*str!='\0')
	{
		SBUF=*str;
		while(!TI);//等待发送完成信号(TI=1)出现
		TI=0;
		str++;
	}
}

//延时函数大概是1s钟,不过延时大的话不准...
void DelaySec(int sec)
{
	uint i , j= 0;

	for(i=0; i<sec; i++)
	{
		for(j=0; j<65535; j++)
		{	
		}
	}
}

void main()
{
	uchar i = 0;
	SerialInti();
	while(1)
	{
		Uart1Sends(num);
		DelaySec(20);//延时20秒
		Uart1Sends("ATH\r\n");
		DelaySec(5);//延时5秒
	}
}


2,发送英文短信

/************************************************************
程序说明:
本程序运行后如果gprs模块找到服务商信号,就拨打指定电话。
1.将自己的51单片机的串口1连接到GSM 232上
2.找到程序中前面的#define处,根据说明修改好自己的单片机配置,编译程序
2.下载程序
3.等待发送成功
*************************************************************/
#include <REG51.H>
#define uchar unsigned char
#define uint unsigned int
//以下是板子上LED的配置,把Px_x改成自己对应的脚。
//以下是你的51单片机的晶振大小
#define FOSC_110592M
//#define FOSC_12M
//以下是开机后发送到手机的内容,发送的号码在程序中修改。
uchar sms_text[] = "abc123";
   
//注意,无论接收到信号还是发送完信号,都会进中断服务程序的
/*初始化程序(必须使用,否则无法收发),次程序将会使用定时器1*/
void SerialInti()//初始化程序(必须使用,否则无法收发)
{
	TMOD=0x20;//定时器1操作模式2:8位自动重载定时器

#ifdef FOSC_12M		   //在这里根据晶振大小设置不同的数值初始化串口
	TH1=0xf3;//装入初值,波特率2400
	TL1=0xf3;	
#else 	
	TH1=0xfd;//装入初值,波特率9600
	TL1=0xfd;
#endif //end of SOC_12M
	
	TR1=1;//打开定时器
	SM0=0;//设置串行通讯工作模式,(10为一部发送,波特率可变,由定时器1的溢出率控制)
	SM1=1;//(同上)在此模式下,定时器溢出一次就发送一个位的数据
	REN=1;//串行接收允许位(要先设置sm0sm1再开串行允许)
	EA=1;//开总中断
	ES=1;//开串行口中断	
}

/*串行通讯中断,收发完成将进入该中断*/
void Serial_interrupt() interrupt 4 
{
//	a=SBUF;
	P2=SBUF;
	RI=0;//接收中断信号清零,表示将继续接收
//	flag=1;//进入中断的标志符号
}

void Uart1Send(uchar c)
{
	SBUF=c;
	while(!TI);//等待发送完成信号(TI=1)出现
	TI=0;	
}
//串行口连续发送char型数组,遇到终止号/0将停止
void Uart1Sends(uchar *str)
{
	while(*str!='\0')
	{
		SBUF=*str;
		while(!TI);//等待发送完成信号(TI=1)出现
		TI=0;
		str++;
	}
}

//延时函数大概是1s钟,不过延时大的话不准...
void DelaySec(int sec)
{
	uint i , j= 0;

	for(i=0; i<sec; i++)
	{
		for(j=0; j<65535; j++)
		{	
		}
	}
}

void main()
{
	uchar i = 0;
	SerialInti();
	while(1)
	{

		Uart1Sends("AT+CSCS=\"GSM\"\r\n");
		DelaySec(3);//延时3秒
		Uart1Sends("AT+CMGF=1\r\n");
		DelaySec(3);//延时3秒
		Uart1Sends("AT+CMGS=\"13878963728\"\r\n");//此处修改为对方的电话号
		DelaySec(5);//延时3秒
		Uart1Sends(sms_text);//修改短信内容
		Uart1Send(0x1a);
		DelaySec(15);//延时20秒
	}
}



3,收到短信做出判断

<pre name="code" class="cpp">/*收到短信后  通过串口反馈   +CMTI: "SM",1

Uart1Sends("AT+CMGD=1,4\r\n");	 这条命令会反馈一个含有“,1”的反馈*/

#include <REG52.H>
#include <string.H>
#define uchar unsigned char
#define uint unsigned int

sbit led1 = P1^0;
sbit led2 = P1^1;
sbit led3 = P1^2;
sbit led4 = P1^3;
sbit led5 = P1^4;

//以下是GSM模块返回数据
uchar rec_data[90];

uchar rec_num;

//注意,无论接收到信号还是发送完信号,都会进中断服务程序的


void SerialInti()//初始化程序
{
	TMOD=0x20;//定时器1操作模式2:8位自动重载定时器

	#ifdef FOSC_12M		   //在这里根据晶振大小设置不同的数值初始化串口
	TH1=0xf3;//装入初值,波特率2400
	TL1=0xf3;	
	#else 	
	TH1=0xfd;//装入初值,波特率9600
	TL1=0xfd;
	#endif //end of SOC_12M
	
	TR1=1;//打开定时器
	SM0=0;//设置串行通讯工作模式,(10为一部发送,波特率可变,由定时器1的溢出率控制)
	SM1=1;//(同上)在此模式下,定时器溢出一次就发送一个位的数据
	REN=1;//串行接收允许位(要先设置sm0sm1再开串行允许)
	EA=1;//开总中断
	ES=1;//开串行口中断	
}

/*串行通讯中断,收发完成将进入该中断*///如:+CMTI:"SM",2
void Serial_interrupt() interrupt 4 
{

	uchar temp;
	temp=SBUF;
	rec_data[rec_num++]=temp;
	if(rec_num>=90)
		rec_num=0;
	RI=0;//接收中断信号清零,表示将继续接收

}

void Uart1Sends(uchar *str)
{
	while(*str!='\0')
	{
		SBUF=*str;
		while(!TI);//等待发送完成信号(TI=1)出现
		TI=0;
		str++;
	}
}

uchar hand(uchar *ptr)
{
	if(strstr(rec_data,ptr)!=NULL)
		return 1;
	else
		return 0;
}

void clear_rec_data()
{
	uchar i;
	for(i=0;i<strlen(rec_data);i++)
	{
		rec_data[i]='0';
	
	}
	rec_num=0;


}
//延时函数大概是1s钟,不过延时大的话不准...
void DelaySec(int sec)
{
	uint i , j= 0;

	for(i=0; i<sec; i++)
	{
		for(j=0; j<65535; j++)
		{	
		}
	}
}

void delayMs(uint ms)
{
	uint i,j;
	for(i = ms;i >0;i --)
		for(j = 110;j > 0;j--);
}

void main()
{
	uchar i = 0;
	SerialInti();

	Uart1Sends("ATI\r\n"); //握手

	delayMs(200);

	Uart1Sends("AT+CMGD=1,4\r\n"); //删除全部短信     经测试,该命令有效果

	delayMs(2000);

	clear_rec_data();//删除存储的GSM模块返回的数据,以便于以后继续判断

	


	while(1)
	{
		//Uart1Sends("AT+CMGD=1,4\r\n");这条命令会反馈一个含有“,1”的反馈

		if(hand(",1"))
		{
			clear_rec_data();//串口返回的数据 并判断完后就清楚数据
			Uart1Sends("AT+CMGR=1\r\n");//	发送读取短信命令 ,读取到短信后存储到数组中
			delayMs(600);
	

			if(hand("on"))
			{
				led1 = 0;
				delayMs(200);
				Uart1Sends("AT+CMGD=1,4\r\n");//判断符合条件后,删除全部短信
				delayMs(2000);
				clear_rec_data();	//清楚数组
			}

			if(hand("off"))
			{
				led1 = 1;
				delayMs(200);
				Uart1Sends("AT+CMGD=1,4\r\n");
				delayMs(2000);
				clear_rec_data();
			}
			
		}

	}

}


 
 


转载于:https://www.cnblogs.com/wansho/p/5104349.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值