亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? sendun.cpp.bak

?? SP平臺聯通短信發送程序
?? BAK
?? 第 1 頁 / 共 2 頁
字號:
//此程序是中國聯通9020發送程序,實現功能:(號段的判斷)//1、單條發送一般的文本信息//2、發送免提短信//3、鈴聲圖片的發送:從MSGCONTENT中取出3位十進制轉換為二進制后發送出去//4、支持群發功能:當MsgFormat=99時,從指定文件中取出手機號碼,連接到目的手機號上,發送出去//5、有號段的判斷,但號段表中的數據只是本省的,故只能判斷本省。//  但在號段的判斷時考慮比較多,當接收方付費時,判斷接收方的省份,將接收方不是本省的插入到COM_SEND_OTHER中,//  且考慮了第三方付費的情況,將根據不同情況將信息發送出去。可能一條信息會被拆分成兩條:一條接收方,一條付費方//  ***所有的信息都會作一次嘗試性發送#include <stdio.h>#include <string.h>#include <time.h>#include <stdlib.h>#include <sys/types.h>#include <sys/stat.h>#include <unistd.h>#include <pthread.h>#include "../include/define.h"#include "mysql/mysql.h"#include "../include/sm_tools.h"#include "../include/sm_db.h"#include "../include/sgip.h"#include "send.h"#define MAX_COMMAND	10#define SELF_TYPE	"send_9020"void send_sm();int gbtounicode(char *msg,char *result);static int Send_Demo(SEND_STRUC sendstruc,char *demo);pthread_mutex_t mutex;//********************************************************SENDSTRUC *waitheader;SENDSTRUC *waittail;int waitnum;SENDSTRUC *okheader;SENDSTRUC *oktail;//********************************************************//初始化鏈表int initlist(){	waitheader = NULL;	waittail = NULL;	okheader = NULL;	oktail = NULL;	waitnum = 0;	return 0;}//從已處理的鏈表中取信息,以便將COM_SEND表中的FLAG置為相應的值int getoklist(SENDSTRUC **sendstruc){	SENDSTRUC *point;	pthread_mutex_lock(&mutex);		if(okheader == NULL)	{		pthread_mutex_unlock(&mutex);		return 0;	}	point = okheader;	okheader = okheader->next;		if(okheader == NULL)	{		oktail = NULL;	}	*sendstruc = point;		pthread_mutex_unlock(&mutex);	return 1;}//從等待鏈表中取信息后發送出去int getwaitlist(SENDSTRUC **sendstruc){	SENDSTRUC *point;		pthread_mutex_lock(&mutex);	if(waitheader == NULL)	{		pthread_mutex_unlock(&mutex);		return 0;	}	point = waitheader;	waitheader = waitheader->next;		if(waitheader == NULL)	{		waittail = NULL;	}		*sendstruc = point;	if(waitnum > 0)	{		waitnum --;	}		pthread_mutex_unlock(&mutex);	return 1;}//從COM_SEND表中取出信息添加到等待鏈表中,等待發送int addwaitlist(SENDSTRUC *sendstruc){	pthread_mutex_lock(&mutex);	if(waitheader == NULL)	{		waitheader = sendstruc;		waittail = sendstruc;	}	else	{		waittail->next = sendstruc;		waittail = waittail->next;	}	waittail -> next = NULL;		waitnum ++;	pthread_mutex_unlock(&mutex);	return 1;}//將發送完的記錄加入到OK鏈表中int addoklist(SENDSTRUC *sendstruc){	pthread_mutex_lock(&mutex);	if(okheader == NULL)	{		okheader = sendstruc;		oktail = sendstruc;	}	else	{		oktail->next = sendstruc;		oktail = oktail->next;	}	oktail -> next = NULL;	pthread_mutex_unlock(&mutex);	return 1;}//***********************************************************//***********************************************************#define INIFILE "../config/sm.ini"#define INIFILE_UN "../config/sms_130.ini"static int MAX_WAITLIST;static int THREAD_NUM;static char PROVINCE[10];static char FFSTRING[2000][500];static int FFSTR_NUM;char db_host[100],db_user[100],db_passwd[100],db_dbname[100];MYSQL *myconn;//變量的初始化int InitPara(){	myconn = NULL;	MAX_WAITLIST = GetProfileInt(INIFILE,"SEND","MAX_WAITLIST",100);	THREAD_NUM = GetProfileInt(INIFILE,"SEND","THREAD_NUM",6);	GetProfileString(INIFILE,"DB_LOCAL","HOST","localhost",db_host);	GetProfileString(INIFILE,"DB_LOCAL","LOGNAME","root",db_user);	GetProfileString(INIFILE,"DB_LOCAL","LOGPASS","",db_passwd);	GetProfileString(INIFILE,"DB_LOCAL","DBNAME","NW_SM_TEST",db_dbname);	GetProfileString(INIFILE,"HD","PROVINCE","",PROVINCE);		return 0;}int main(int argc,char * argv[]){	char buf[100];  int i,retval1;  pthread_t thread_id;  char sql[500];  MYSQL_ROW row;  MYSQL_RES *res = NULL;	InitPara();		//連接數據庫	myconn = dbconnect(db_host,db_user,db_passwd,db_dbname);	if(myconn == NULL)	{		puts("連接數據庫失敗,請查看日志文件!");		return 0;	}		puts(db_dbname);         		//初始化數據庫,將FLAG為90的置為0	if(DoSQL("UPDATE COM_SEND SET FLAG='0' WHERE ICPID='UN' AND FLAG='90'",&myconn)!=0)	{		writelog(SELF_TYPE,"初始化Send表出錯!");	}	//初始化鏈表	initlist();		//初始化API函數	if(InitSGIPAPI(INIFILE_UN) != 0)	{		puts("初始化CMPPAPI失敗!");		writelog(SELF_TYPE,"初始化CMPPAPI失敗!");		return 0;	}		//將非法字符調入內存	i=0;	sprintf(sql,"SELECT STR_FIND FROM WEB_WORDS");  retval1 = QuerySQL(sql,&myconn,&res);  if(retval1 != 0)  {  	  writelog(SELF_TYPE,"查詢指令出錯");  	  return 0;  }  if(res == NULL)  {  	return 0;  }	  while(row = mysql_fetch_row(res))  {  			     strcpy(FFSTRING[i],trim(row[0],' '));     //puts(FFSTRING[i]);     i=i+1;		  }  mysql_free_result(res);  FFSTR_NUM=i;  printf("非法字符數量%d",FFSTR_NUM);  //非法字符調入內存 end;	pthread_mutex_init(&mutex,NULL);	//創建發送進程	for(i=0;i<THREAD_NUM;i++)	{		pthread_create(&thread_id, NULL, (void* (*)(void*))send_sm, NULL);	}	if(DoThread() != 0)	{		puts("查詢信息出錯!");		return 0;	}		return 0;}//從COM_SEND表中取出記錄加入到等待列表中等待發送int DoThread(){	int retval;		while(1)	{		retval = ScanMsg();		if(retval <= 0)		{			sleep(2);			continue;		}		usleep(10);	}}int ScanMsg(){	char sql[500],day[20];	MYSQL_ROW row,row2;	MYSQL_RES *res = NULL,*res2 = NULL;		SENDSTRUC *com_buf;	SEND_STRUC sendstruc;		int retval,retval2,i,slen,j,flag1,flag2,retval1,pos,x,y,z,ffstrlen,ffstrtemplen,retval3;	char result[1001],temp[10],errmsg[100];	float feecode;	char msg[1001],ffstr[500],ffstrtemp[500],ffbuf[500];	memset(sql,0,sizeof(sql));	//處理發送過的數據,從發送完的鏈表中取出信息,將FLAG的值置為其發送后的返回值,并釋放所占空間	while(getoklist(&com_buf))	{		sprintf(sql,		        "UPDATE COM_SEND SET FLAG='%d',DEAL_DATE='%s' WHERE ID=%s", com_buf->flag,getnowdate(day),com_buf->id);		if(DoSQL(sql,&myconn) != 0)		{			free(com_buf);			writelog(SELF_TYPE,"更新數據庫出錯!");			return 0;		}		free(com_buf);	}	if(waitnum > MAX_WAITLIST)	{		return 0;	}		//從COM_SEND表中要發送的聯通用戶的記錄FLAG=0:未處理,FLAG=89:已處理,但發送時隊列滿,要重發	sprintf(sql,	       "SELECT ID,NEEDREPLY,MSGLEVEL,SERVICEID,MSGFORMAT,FEETYPE,FEECODE,VALIDTIME,ATTIME,SRCTERMID, DESTTERMID,MSGCONTENT,FEEUSERTYPE,FEETERMINALID, TPPID,TPUDHI,LINKID  FROM COM_SEND   WHERE ICPID='UN' AND (FLAG='0') ORDER BY STEP,ID  LIMIT 0,%d",MAX_COMMAND);	retval = QuerySQL(sql,&myconn,&res);	if(retval != 0)	{		writelog(SELF_TYPE,"查詢指令出錯COM_SEND,FLAG=0");		puts("com_send失敗");		return 0;			}	if(res == NULL)	{		return 0;	}	retval1 = 0;		while(row = mysql_fetch_row(res))	{		retval1 ++; 		com_buf = (SENDSTRUC *) malloc(sizeof(SENDSTRUC));		if(com_buf == NULL)		{			writelog(SELF_TYPE,"申請內存失敗!");			mysql_free_result(res);			return 0;		}				//對鏈表變量賦值		puts(com_buf->id);		strcpy(com_buf->id,row[0]);		com_buf->nNeedReply = atoi(row[1]);		com_buf->nMsgLevel = atoi(row[2]);		strcpy(com_buf->sServiceID,row[3]);		com_buf->nMsgFormat = atoi(row[4]);		strcpy(com_buf->sFeeType,row[5]);		feecode=atof(row[6])*100;		sprintf(com_buf->sFeeCode,"%06d",(int)feecode);		strcpy(com_buf->sValidTime,"");		strcpy(com_buf->sAtTime,"");		strcpy(com_buf->sSrcTermID,row[9]);		strcpy(com_buf->sDesTermID,row[10]);		strcpy(com_buf->sMsgContent,row[11]);		com_buf->nMsgLen = strlen(com_buf->sMsgContent);		strcpy(com_buf->sMsgID,com_buf->id);		com_buf->cFeeUserType = atoi(row[12]);		strcpy(com_buf->sFeeTerminalID,row[13]);		com_buf->cTpPid=atoi(row[14]);		com_buf->cTpUdhi=atoi(row[15]);    strcpy(com_buf->linkid,row[16]);    puts(com_buf->linkid);    puts(com_buf->sDesTermID);		//對特定用戶實行免費發送  		begin		20031013	xcy    sprintf(sql,"SELECT MSISDN FROM INFO_FREE_PHONE WHERE MSISDN='%s' AND FLAG='1'",com_buf->sDesTermID);    printf("%s\n",sql);	retval2 = QuerySQL(sql,&myconn,&res2);    if(retval2 != 0)    {       writelog(SELF_TYPE,"查詢指令出錯INFO_FREE_PHONE");       return 0;    }    if(res2 == NULL)    {       return 0;    }		    if (row2 = mysql_fetch_row(res2))    {    	if (strcmp(com_buf->sFeeType,"02")==0)    	{         strcpy(com_buf->sFeeType,"01");      }      else if (strcmp(com_buf->sFeeType,"03")==0 && com_buf->nNeedReply==2)      {      	mysql_free_result(res2);      	sprintf(sql,            		"UPDATE COM_SEND SET FLAG='1' WHERE ID=%s",com_buf->id);      	if(DoSQL(sql,&myconn) != 0)      	{      	   free(com_buf);      	   writelog(SELF_TYPE,"更新數據庫出錯!");      	   return 0;      	}             	free(com_buf);               	continue;      }    }    mysql_free_result(res2);        //對特定用戶實行免費發送  		end		20031013	xcy                		//對結構體變量賦值,用于插入COM_SEND_OTHER表				sendstruc.nNeedReply = atoi(row[1]);							sendstruc.nMsgLevel = atoi(row[2]);                             			strcpy(sendstruc.sServiceID,row[3]);                            			sendstruc.nMsgFormat = atoi(row[4]);                            			strcpy(sendstruc.sFeeType,row[5]);                              			sendstruc.sFeeCode=atof(row[6]);                			strcpy(sendstruc.sValidTime,"");		                			strcpy(sendstruc.sAtTime,"");		                        			strcpy(sendstruc.sSrcTermID,row[9]);                            			strcpy(sendstruc.sDesTermID,row[10]);                           			strcpy(msg,row[11]);                                            			trim(msg,' ');                             		//判斷發送內容的長度是否超過500,若超過了500,則不發送,直接置為1,并寫LOG	begin	2003.06.25	邢		if (strlen(msg)>500)		{			sprintf(sql,"UPDATE COM_SEND SET FLAG='1',DEAL_DATE='%s' WHERE ID=%s",				getnowdate(day),com_buf->id);							if(DoSQL(sql,&myconn) != 0)			{				free(com_buf);				writelog(SELF_TYPE,"更新數據庫出錯!");				mysql_free_result(res);				return 0;			}			sprintf(errmsg,"id:%s,srctermid:%s,serviceid:%s",com_buf->id,com_buf->sDesTermID,com_buf->sServiceID);			writelog(SELF_TYPE,errmsg);			free(com_buf);			continue;		}		//判斷發送內容的長度是否超過500,若超過了500,則不發送,直接置為1,并寫LOG	end	2003.06.25	邢		                     			strcpy(sendstruc.sMsgContent,msg);                              			sendstruc.cFeeUserType = atoi(row[12]);                          			strcpy(sendstruc.sFeeTerminalID,row[13]);		sendstruc.cTpPid=atoi(row[14]);				sendstruc.cTpUdhi=atoi(row[15]);	    strcpy(sendstruc.sMsgContent,row[16]);            /*當內容中含有非法字符時進行處理*/    strcpy(ffstr,"");    strcpy(ffbuf,"");		strcpy(ffstr,com_buf->sMsgContent);		ffstrlen=strlen(ffstr);		puts(ffstr);		printf("ffstr is %d",ffstrlen);		pos=0;			x=0;		while(pos<=ffstrlen)		{			//掃描字符串			y=0;				z=0;	      while(z<FFSTR_NUM)      {         strcpy(ffstrtemp,"");               strcpy(ffstrtemp,FFSTRING[z]);         ffstrtemplen=strlen(ffstrtemp);         if(strncmp(ffstr + pos,ffstrtemp,ffstrtemplen) == 0)			   {							ffbuf[x++]='*';						pos+=ffstrtemplen;						y=1;						break;			   }

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美疯狂性受xxxxx喷水图片| 成人在线综合网站| 欧美日韩大陆在线| 亚洲电影一级片| 在线不卡一区二区| 日韩国产欧美一区二区三区| 欧美色成人综合| 水野朝阳av一区二区三区| 91麻豆精品国产91久久久 | 天堂久久久久va久久久久| 欧美久久一二三四区| 免费观看日韩av| 国产三区在线成人av| 在线国产亚洲欧美| 麻豆国产精品一区二区三区| 久久蜜桃av一区精品变态类天堂| 成人av网站免费观看| 亚洲国产一区二区三区青草影视| 欧美高清一级片在线| 国产精品香蕉一区二区三区| 亚洲欧洲在线观看av| 欧美高清你懂得| 国产成人精品网址| 亚洲电影视频在线| 国产三级精品视频| 欧美视频一区二区在线观看| 国内外成人在线视频| 亚洲色图在线视频| 日韩欧美美女一区二区三区| 97久久超碰国产精品电影| 日本不卡的三区四区五区| 国产欧美日韩在线视频| 欧美日韩国产欧美日美国产精品| 国产一二三精品| 亚洲中国最大av网站| 久久综合999| 欧美日韩三级一区| 成人开心网精品视频| 美女视频免费一区| 亚洲精品国产成人久久av盗摄 | 国产日韩精品一区二区三区| 色噜噜夜夜夜综合网| 国产毛片精品视频| 视频一区欧美精品| 亚洲三级理论片| 国产午夜精品久久久久久免费视 | 国产日韩欧美激情| 欧美一级淫片007| 在线亚洲一区二区| 成人午夜电影久久影院| 另类综合日韩欧美亚洲| 亚洲国产精品久久一线不卡| 欧美国产精品中文字幕| 久久这里只有精品6| 91精品国产入口在线| 色婷婷综合久久久中文一区二区 | 亚洲精品ww久久久久久p站| 久久久精品国产免大香伊| 在线综合+亚洲+欧美中文字幕| 99久久久精品| 岛国av在线一区| 国内精品第一页| 蓝色福利精品导航| 久久精品久久综合| 日韩av在线免费观看不卡| 亚洲国产视频a| 亚洲综合区在线| 一区二区视频免费在线观看| 国产精品国产精品国产专区不片| 国产视频不卡一区| 欧美激情综合五月色丁香| 久久久久久久综合| 国产欧美精品国产国产专区| 久久蜜桃香蕉精品一区二区三区| 精品国产91亚洲一区二区三区婷婷| 91精品久久久久久久久99蜜臂| 欧美日本国产一区| 欧美一级专区免费大片| 日韩欧美在线一区二区三区| 欧美日韩亚洲高清一区二区| 欧美日韩中文字幕精品| 欧美日韩国产精品成人| 正在播放一区二区| 精品国产一区二区三区av性色| 欧美va亚洲va| 国产日韩影视精品| 中文字幕不卡的av| 亚洲婷婷国产精品电影人久久| 亚洲欧洲国产日韩| 亚洲综合免费观看高清完整版| 亚洲永久精品大片| 日本强好片久久久久久aaa| 久久精品国产99国产| 国产精品综合久久| 成人午夜精品一区二区三区| 91美女福利视频| 欧美精品自拍偷拍| 日韩欧美视频在线| 国产精品美女一区二区在线观看| 国产精品久久久久一区二区三区共| 亚洲女与黑人做爰| 午夜欧美电影在线观看| 免费观看在线色综合| 国产高清一区日本| 欧美视频一区二区在线观看| 欧美一区二区久久| 日本一区二区不卡视频| 亚洲制服丝袜在线| 国产一区二区在线看| 97精品久久久久中文字幕| 欧美电影影音先锋| 久久久精品天堂| 午夜精品久久久久影视| 国产精品一区二区免费不卡 | 国产91丝袜在线播放九色| 波多野结衣中文字幕一区 | 日韩欧美一二三四区| 国产亚洲精久久久久久| 亚洲综合男人的天堂| 国产一区二区不卡在线| 欧美亚洲高清一区| 久久精品视频在线看| 亚洲成a人v欧美综合天堂| 国产高清在线观看免费不卡| 欧美日韩亚洲高清一区二区| 日本一区二区视频在线| 热久久一区二区| 色噜噜狠狠色综合欧洲selulu| 日韩欧美在线一区二区三区| 樱花影视一区二区| 国产一区二区三区不卡在线观看| 在线视频国内自拍亚洲视频| 久久久精品黄色| 美女视频黄频大全不卡视频在线播放| 成人av集中营| 2014亚洲片线观看视频免费| 一区二区三区在线影院| 成人av在线资源网| 精品入口麻豆88视频| 亚洲午夜久久久久久久久久久| 国产精华液一区二区三区| 69久久99精品久久久久婷婷| 亚洲男人的天堂av| www.色综合.com| 久久综合999| 精品一区二区三区在线观看 | 国产一区视频在线看| 欧美日韩国产综合久久| 一区二区三区不卡在线观看| 国产成人精品三级麻豆| 精品国产91洋老外米糕| 免费观看日韩av| 欧美精品日韩一本| 午夜精品久久久久久久久久久 | 亚洲日本va午夜在线影院| 久草中文综合在线| 日韩美女在线视频| 美女在线观看视频一区二区| 欧美日韩亚州综合| 亚洲成人你懂的| 欧美日韩免费电影| 五月天一区二区三区| 欧美日韩性生活| 午夜激情久久久| 欧美日韩久久不卡| 天天色综合天天| 欧美肥妇free| 久久精品国产久精国产| 在线综合视频播放| 极品少妇xxxx偷拍精品少妇| 欧美电影免费观看完整版| 国产自产高清不卡| 久久久久久久久蜜桃| 成人午夜视频网站| 亚洲欧洲一区二区在线播放| 色噜噜久久综合| 日韩综合小视频| 日韩一级高清毛片| 国产精品一品视频| 中文字幕在线一区二区三区| 91老师国产黑色丝袜在线| 亚洲专区一二三| 日韩女优毛片在线| 国产乱码精品1区2区3区| 国产精品久线在线观看| 日本韩国视频一区二区| 亚洲国产人成综合网站| 欧美一级片免费看| 国产一区二区精品在线观看| 国产精品福利电影一区二区三区四区 | 久久99精品国产麻豆婷婷| 亚洲精品一区二区三区香蕉| 国产美女在线精品| 国产精品嫩草久久久久| 欧美性xxxxxxxx| 精品一区二区三区视频| 国产精品久久久久影院| 欧美精品一卡二卡| 国产精品亚洲一区二区三区妖精| 欧美国产日本视频|