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

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

?? smstoolsfun.cpp

?? 基于普通手機的短信編程源碼
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
#include <vcl.h>
#include <dirent.h>
#include <dir.h>
#include <stdio.h>
#include <stdlib.h>
#include <winbase.h>
#include <time.h>
#include <stdio.h>
#include "smsPdu.h"
#include "sms_Unit1.h"

HANDLE hComm1;  //接收句柄
HANDLE hComm;   //發送句柄

//---------------------------------------------------------------------------
// 7-bit編碼
// pSrc: 源字符串指針
// pDst: 目標編碼串指針
// nSrcLength: 源字符串長度
// 返回: 目標編碼串長度
int gsmEncode7bit(const char* pSrc, unsigned char* pDst, int nSrcLength)
{
    int nSrc;        // 源字符串的計數值
    int nDst;        // 目標編碼串的計數值
    int nChar;       // 當前正在處理的組內字符字節的序號,范圍是0-7
    unsigned char nLeft;    // 上一字節殘余的數據
    
    // 計數值初始化
    nSrc = 0;
    nDst = 0;
    
    // 將源串每8個字節分為一組,壓縮成7個字節
    // 循環該處理過程,直至源串被處理完
    // 如果分組不到8字節,也能正確處理
    while(nSrc<nSrcLength)
    {
        // 取源字符串的計數值的最低3位
        nChar = nSrc & 7;
    
        // 處理源串的每個字節
        if(nChar == 0)
        {
            // 組內第一個字節,只是保存起來,待處理下一個字節時使用
            nLeft = *pSrc;
        }
        else
        {
            // 組內其它字節,將其右邊部分與殘余數據相加,得到一個目標編碼字節
            *pDst = (*pSrc << (8-nChar)) | nLeft;
    
            // 將該字節剩下的左邊部分,作為殘余數據保存起來
            nLeft = *pSrc >> nChar;
            // 修改目標串的指針和計數值 pDst++;
            nDst++; 
        } 
        
        // 修改源串的指針和計數值
        pSrc++; nSrc++;
    }
    
    // 返回目標串長度
    return nDst; 
}


//-----------------------------------------------------------------------------
// 7-bit解碼
// pSrc: 源編碼串指針
// pDst: 目標字符串指針
// nSrcLength: 源編碼串長度
// 返回: 目標字符串長度
int gsmDecode7bit(const unsigned char* pSrc, char* pDst, int nSrcLength)
{
    int nSrc;        // 源字符串的計數值
    int nDst;        // 目標解碼串的計數值
    int nByte;       // 當前正在處理的組內字節的序號,范圍是0-6
    unsigned char nLeft;    // 上一字節殘余的數據
    
    // 計數值初始化
    nSrc = 0;
    nDst = 0;
    
    // 組內字節序號和殘余數據初始化
    nByte = 0;
    nLeft = 0;
    
    // 將源數據每7個字節分為一組,解壓縮成8個字節
    // 循環該處理過程,直至源數據被處理完
    // 如果分組不到7字節,也能正確處理
    while(nSrc<nSrcLength)
    {
        // 將源字節右邊部分與殘余數據相加,去掉最高位,得到一個目標解碼字節
        *pDst = ((*pSrc << nByte) | nLeft) & 0x7f;
        // 將該字節剩下的左邊部分,作為殘余數據保存起來
        nLeft = *pSrc >> (7-nByte);
    
        // 修改目標串的指針和計數值
        pDst++;
        nDst++;
    
        // 修改字節計數值
        nByte++;
    
        // 到了一組的最后一個字節
        if(nByte == 7)
        {
            // 額外得到一個目標解碼字節
            *pDst = nLeft;
    
            // 修改目標串的指針和計數值
            pDst++;
            nDst++;
    
            // 組內字節序號和殘余數據初始化
            nByte = 0;
            nLeft = 0;
        }
    
        // 修改源串的指針和計數值
        pSrc++;
        nSrc++;
    }
    
    *pDst = 0;
    
    // 返回目標串長度
    return nDst;
}
//-----------------------------------------------------------------------------

// 8bit編碼
// pSrc: 源字符串指針
// pDst: 目標編碼串指針
// nSrcLength: 源字符串長度
// 返回: 目標編碼串長度
int gsmEncode8bit(const char* pSrc, unsigned char* pDst, int nSrcLength)
{
	// 簡單復制
	memcpy(pDst, pSrc, nSrcLength);

	return nSrcLength;
}
//---------------------------------------------------------------------------
// 8bit解碼
// pSrc: 源編碼串指針
// pDst: 目標字符串指針
// nSrcLength: 源編碼串長度
// 返回: 目標字符串長度
int gsmDecode8bit(const unsigned char* pSrc, char* pDst, int nSrcLength)
{
	// 簡單復制
	memcpy(pDst, pSrc, nSrcLength);

	// 輸出字符串加個結束符
	*pDst = '\0';

	return nSrcLength;
}
//-----------------------------------------------------------------------------
// UCS2編碼
// pSrc: 源字符串指針
// pDst: 目標編碼串指針
// nSrcLength: 源字符串長度
// 返回: 目標編碼串長度
int gsmEncodeUcs2(const char* pSrc, unsigned char* pDst, int nSrcLength)
{
    int nDstLength;        // UNICODE寬字符數目
    WCHAR wchar[128];      // UNICODE串緩沖區
    
    // 字符串-->UNICODE串
    nDstLength = ::MultiByteToWideChar(CP_ACP, 0, pSrc, nSrcLength, wchar, 128);
    
    // 高低字節對調,輸出
    for(int i=0; i<nDstLength; i++)
    {
        // 先輸出高位字節
        *pDst++ = wchar[i] >> 8;
        // 后輸出低位字節
        *pDst++ = wchar[i] & 0xff;
    }
    
    // 返回目標編碼串長度
    return nDstLength * 2;
}

//----------------------------------------------------------------------------
// UCS2解碼
// pSrc: 源編碼串指針
// pDst: 目標字符串指針
// nSrcLength: 源編碼串長度
// 返回: 目標字符串長度
int gsmDecodeUcs2(const unsigned char* pSrc, char* pDst, int nSrcLength)
{
    int nDstLength;        // UNICODE寬字符數目
    WCHAR wchar[128];      // UNICODE串緩沖區
    
    // 高低字節對調,拼成UNICODE
    for(int i=0; i<nSrcLength/2; i++)
    {
        // 先高位字節
        wchar[i] = *pSrc++ << 8;
    
        // 后低位字節
        wchar[i] |= *pSrc++;
    }
    
    // UNICODE串-->字符串
    nDstLength = ::WideCharToMultiByte(CP_ACP, 0, wchar, nSrcLength/2, pDst, 160, NULL, NULL);
    
    // 輸出字符串加個結束符    
    pDst[nDstLength] = '\0';    
    
    // 返回目標字符串長度
    return nDstLength;
}


//---------------------------------------------------------------------------
// 可打印字符串轉換為字節數據
// 如:"C8329BFD0E01" --> {0xC8, 0x32, 0x9B, 0xFD, 0x0E, 0x01}
// pSrc: 源字符串指針
// pDst: 目標數據指針
// nSrcLength: 源字符串長度
// 返回: 目標數據長度
int gsmString2Bytes(const char* pSrc, unsigned char* pDst, int nSrcLength)
{
    for(int i=0; i<nSrcLength; i+=2)
    {
        // 輸出高4位
        if(*pSrc>='0' && *pSrc<='9')
        {
            *pDst = (*pSrc - '0') << 4;
        }
        else
        {
            *pDst = (*pSrc - 'A' + 10) << 4;
        }
    
        pSrc++;
    
        // 輸出低4位
        if(*pSrc>='0' && *pSrc<='9')
        {
            *pDst |= *pSrc - '0';
        }
        else
        {
            *pDst |= *pSrc - 'A' + 10;
        }
        pSrc++;
        pDst++;
    }
    
    // 返回目標數據長度
    return(nSrcLength / 2);
}


//----------------------------------------------------------------------------
// 字節數據轉換為可打印字符串
// 如:{0xC8, 0x32, 0x9B, 0xFD, 0x0E, 0x01} --> "C8329BFD0E01"
// pSrc: 源數據指針
// pDst: 目標字符串指針
// nSrcLength: 源數據長度
// 返回: 目標字符串長度
int gsmBytes2String(const unsigned char* pSrc, char* pDst, int nSrcLength)
{
    const char tab[]="0123456789ABCDEF";    // 0x0-0xf的字符查找表
    
    for(int i=0; i<nSrcLength; i++)
    {
        // 輸出低4位
        *pDst++ = tab[*pSrc >> 4];
    
        // 輸出高4位
        *pDst++ = tab[*pSrc & 0x0f];
    
        pSrc++;
    }
    
    // 輸出字符串加個結束符
    *pDst = '\0';
    
    // 返回目標字符串長度
    return nSrcLength * 2;
}
//-----------------------------------------------------------------------------


// 正常順序的字符串轉換為兩兩顛倒的字符串,若長度為奇數,補'F'湊成偶數
// 如:"8613851872468" --> "683158812764F8"
// pSrc: 源字符串指針
// pDst: 目標字符串指針
// nSrcLength: 源字符串長度
// 返回: 目標字符串長度
int gsmInvertNumbers(const char* pSrc, char* pDst, int nSrcLength)
{
    int nDstLength;   // 目標字符串長度
    char ch;          // 用于保存一個字符
    
    // 復制串長度
    nDstLength = nSrcLength;
    
    // 兩兩顛倒
    for(int i=0; i<nSrcLength;i+=2)
    {
        ch = *pSrc++;        // 保存先出現的字符
        *pDst++ = *pSrc++;   // 復制后出現的字符
        *pDst++ = ch;        // 復制先出現的字符
    }
    
    // 源串長度是奇數嗎?
    if(nSrcLength & 1)
    {
        *(pDst-2) = 'F';     // 補'F'
        nDstLength++;        // 目標串長度加1
    }
    
    // 輸出字符串加個結束符
    *pDst = '\0';
    
    // 返回目標字符串長度
    return nDstLength;
}


//-----------------------------------------------------------------------------
// 兩兩顛倒的字符串轉換為正常順序的字符串
// 如:"683158812764F8" --> "8613851872468"
// pSrc: 源字符串指針
// pDst: 目標字符串指針
// nSrcLength: 源字符串長度
// 返回: 目標字符串長度
int gsmSerializeNumbers(const char* pSrc, char* pDst, int nSrcLength)
{
    int nDstLength;   // 目標字符串長度
    char ch;          // 用于保存一個字符
    
    // 復制串長度
    nDstLength = nSrcLength;
    
    // 兩兩顛倒
    for(int i=0; i<nSrcLength;i+=2)
    {
        ch = *pSrc++;        // 保存先出現的字符
        *pDst++ = *pSrc++;   // 復制后出現的字符
        *pDst++ = ch;        // 復制先出現的字符
    }
    
    // 最后的字符是'F'嗎?
    if(*(pDst-1) == 'F')
    {
        pDst--;
        nDstLength--;        // 目標字符串長度減1
    }
    
    // 輸出字符串加個結束符
    *pDst = '\0';
    
    // 返回目標字符串長度
    return nDstLength;
}

//-----------------------------------------------------------------------------
// PDU編碼,用于編制、發送短消息
// pSrc: 源PDU參數指針
// pDst: 目標PDU串指針
// 返回: 目標PDU串長度
int gsmEncodePdu(const SM_PARAM* pSrc, char* pDst)
{
    int nLength;             // 內部用的串長度
    int nDstLength;          // 目標PDU串長度
    unsigned char buf[256];  // 內部用的緩沖區
    
    // SMSC地址信息段
    nLength = strlen(pSrc->SCA);    // SMSC地址字符串的長度    
    buf[0] = (char)((nLength & 1) == 0 ? nLength : nLength + 1) / 2 + 1;    // SMSC地址信息長度
    buf[1] = 0x91;        // 固定: 用國際格式號碼
    nDstLength = gsmBytes2String(buf, pDst, 2);        // 轉換2個字節到目標PDU串
    nDstLength += gsmInvertNumbers(pSrc->SCA, &pDst[nDstLength], nLength);    // 轉換SMSC到目標PDU串
    
    // TPDU段基本參數、目標地址等
    nLength = strlen(pSrc->TPA);    // TP-DA地址字符串的長度
    buf[0] = 0x11;            // 是發送短信(TP-MTI=01),TP-VP用相對格式(TP-VPF=10)
    buf[1] = 0;               // TP-MR=0
    buf[2] = (char)nLength;   // 目標地址數字個數(TP-DA地址字符串真實長度)
    buf[3] = 0x91;            // 固定: 用國際格式號碼
    nDstLength += gsmBytes2String(buf, &pDst[nDstLength], 4);  // 轉換4個字節到目標PDU串
    nDstLength += gsmInvertNumbers(pSrc->TPA, &pDst[nDstLength], nLength); // 轉換TP-DA到目標PDU串
    
    // TPDU段協議標識、編碼方式、用戶信息等
    nLength = strlen(pSrc->TP_UD);    // 用戶信息字符串的長度
    buf[0] = pSrc->TP_PID;        // 協議標識(TP-PID)
    buf[1] = pSrc->TP_DCS;        // 用戶信息編碼方式(TP-DCS)
    buf[2] = 0;            // 有效期(TP-VP)為5分鐘
    if(pSrc->TP_DCS == GSM_7BIT)    
    {
        // 7-bit編碼方式
        buf[3] = nLength;            // 編碼前長度
        nLength = gsmEncode7bit(pSrc->TP_UD, &buf[4], nLength+1) + 4;    // 轉換TP-DA到目標PDU串
    }
    else if(pSrc->TP_DCS == GSM_UCS2)
    {
        // UCS2編碼方式
        buf[3] = gsmEncodeUcs2(pSrc->TP_UD, &buf[4], nLength);    // 轉換TP-DA到目標PDU串
        nLength = buf[3] + 4;        // nLength等于該段數據長度
    }
    else
    {
        // 8-bit編碼方式
        buf[3] = gsmEncode8bit(pSrc->TP_UD, &buf[4], nLength);    // 轉換TP-DA到目標PDU串
        nLength = buf[3] + 4;        // nLength等于該段數據長度
    }
    nDstLength += gsmBytes2String(buf, &pDst[nDstLength], nLength);        // 轉換該段數據到目標PDU串
    
    // 返回目標字符串長度
    return nDstLength;
}


//-----------------------------------------------------------------------------
// PDU解碼,用于接收、閱讀短消息
// pSrc: 源PDU串指針
// pDst: 目標PDU參數指針
// 返回: 用戶信息串長度
int gsmDecodePdu(const char* pSrc, SM_PARAM* pDst)
{
    int nDstLength;          // 目標PDU串長度
    unsigned char tmp;       // 內部用的臨時字節變量
    unsigned char buf[256];  // 內部用的緩沖區
    
    // SMSC地址信息段
    gsmString2Bytes(pSrc, &tmp, 2);    // 取長度

    tmp = (tmp - 1) * 2;    // SMSC號碼串長度  ////////////////

    pSrc += 4;              // 指針后移
    gsmSerializeNumbers(pSrc, pDst->SCA, tmp);    // 轉換SMSC號碼到目標PDU串
    //pSrc += tmp;        // 指針后移
    pSrc +=14;             //////////////////////

    // TPDU段基本參數、回復地址等
    gsmString2Bytes(pSrc, &tmp, 2);    // 取基本參數
    pSrc += 2;        // 指針后移
    //if(tmp & 0x80)
    {

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
中文字幕中文字幕一区| 日韩成人午夜精品| 亚洲高清久久久| 国产精品香蕉一区二区三区| 91免费视频网| 国产亚洲欧美在线| 天天影视涩香欲综合网 | 国产成人精品www牛牛影视| 99re成人在线| 久久久一区二区| 日韩电影免费在线看| 日本黄色一区二区| 国产日韩综合av| 久久 天天综合| 日韩欧美一区二区在线视频| 一区二区三区欧美亚洲| 成人精品国产一区二区4080| 精品成人佐山爱一区二区| 亚洲高清三级视频| 91色视频在线| 日本一区二区成人| 久久成人18免费观看| 欧美日韩一区二区三区四区| 亚洲免费观看高清| 国产麻豆视频一区| 26uuu成人网一区二区三区| 亚洲永久精品国产| 粉嫩一区二区三区性色av| 精品国产乱码久久久久久浪潮| 亚洲图片欧美一区| 国产成人午夜精品5599 | 99国产精品久久久久久久久久久| 香蕉成人啪国产精品视频综合网| 久久精品视频免费观看| 欧美精品aⅴ在线视频| 亚洲丝袜制服诱惑| 丰满少妇在线播放bd日韩电影| 日本久久一区二区| 亚洲成年人影院| 欧洲另类一二三四区| 亚洲一区二区三区在线看| 不卡av免费在线观看| 亚洲图片欧美激情| 99精品久久只有精品| 亚洲精品少妇30p| 95精品视频在线| 亚洲一区二区三区四区在线| 99精品久久99久久久久| 中文子幕无线码一区tr| 成人午夜视频免费看| 日本一区二区久久| av色综合久久天堂av综合| 精品久久久久久久久久久久久久久久久 | 欧美aaaaa成人免费观看视频| 在线观看视频91| 视频一区二区三区中文字幕| 在线成人午夜影院| 国产一区二区三区综合| 久久天堂av综合合色蜜桃网| 粉嫩在线一区二区三区视频| 国产精品二区一区二区aⅴ污介绍| 99国产精品久久久久| 亚洲一区二区偷拍精品| 在线观看国产91| 免费成人你懂的| 亚洲精品在线网站| 97se亚洲国产综合自在线观| 亚洲一二三级电影| 欧美欧美午夜aⅴ在线观看| 国模娜娜一区二区三区| 国产精品久久久久国产精品日日| 欧美三级韩国三级日本三斤 | 亚洲色图20p| 欧美日韩在线播放三区四区| 国产精品一区在线观看乱码| 国产精品入口麻豆原神| 欧美精品电影在线播放| 亚洲一区二区三区小说| 在线观看免费亚洲| 国产很黄免费观看久久| 亚洲精品成人在线| 亚洲精品一区二区三区99| 成人听书哪个软件好| 肉丝袜脚交视频一区二区| 久久婷婷成人综合色| 在线视频一区二区三区| 久久99精品久久只有精品| 国产精品丝袜黑色高跟| 欧美三片在线视频观看| 粉嫩嫩av羞羞动漫久久久 | 欧洲精品中文字幕| 国产精品一区专区| 婷婷丁香激情综合| 中文字幕第一区综合| 91精品国产91久久久久久一区二区| 国产精品影视在线| 一区二区成人在线| 中文字幕欧美国产| 欧美mv和日韩mv的网站| 91原创在线视频| 成人午夜在线播放| 久久99精品久久久久久国产越南 | 777久久久精品| av电影在线观看一区| 久久精品国产久精国产爱| 五月激情六月综合| 中文字幕日本不卡| 国产精品三级av| 精品国产欧美一区二区| 亚洲精品在线免费观看视频| 91国在线观看| 欧美午夜电影在线播放| 国产成人免费在线| 国产精品 日产精品 欧美精品| 一区二区在线观看av| 亚洲精品中文字幕乱码三区| 久久亚洲精品小早川怜子| 日韩精品在线一区| 欧美日韩免费高清一区色橹橹 | 男女视频一区二区| 亚洲综合无码一区二区| 亚洲天堂福利av| 中文字幕在线视频一区| 国产精品对白交换视频| 亚洲国产精品高清| 中文字幕中文乱码欧美一区二区| 久久久精品蜜桃| 中文字幕不卡在线观看| 欧美国产日韩在线观看| 中文字幕制服丝袜成人av| 国产精品三级在线观看| 亚洲欧美日韩中文播放| 亚洲欧美激情在线| 午夜欧美2019年伦理| 国产精品福利一区二区| 亚洲最大色网站| 亚洲美女少妇撒尿| 日日夜夜免费精品| 日本aⅴ免费视频一区二区三区| 日本亚洲三级在线| 国产一区二区三区电影在线观看| 国产一区二区三区四区五区美女| 粉嫩欧美一区二区三区高清影视| 国产精品亚洲一区二区三区在线| 国产精品538一区二区在线| 国产精品中文字幕一区二区三区| 麻豆国产欧美一区二区三区| 蜜桃av一区二区三区| 精品一区二区三区免费毛片爱| 国产69精品久久99不卡| 97成人超碰视| 精品剧情在线观看| 国产欧美日韩不卡| 亚洲高清免费观看| 久久精品国产一区二区| 国产成人高清在线| 色哟哟国产精品| 337p亚洲精品色噜噜噜| 精品欧美黑人一区二区三区| 中文字幕一区二区三中文字幕| 中文字幕一区二区三区不卡| 日韩精彩视频在线观看| 极品少妇xxxx精品少妇偷拍| www.色综合.com| 欧美乱妇23p| 亚洲日本中文字幕区| 亚洲一区二区3| 国产一区二区h| 色综合久久综合网欧美综合网| 欧美理论在线播放| 国产无人区一区二区三区| 午夜av电影一区| 国产成人综合在线| 欧美大片一区二区三区| 自拍av一区二区三区| 精品一二三四区| 欧美亚洲自拍偷拍| 国产精品久久看| 一区二区三区国产豹纹内裤在线| 午夜精品福利视频网站 | 亚洲另类色综合网站| 欧美aaaaaa午夜精品| 高清不卡一区二区在线| 制服丝袜亚洲播放| 亚洲成人精品一区| 成年人国产精品| 国产精品丝袜久久久久久app| 日韩电影在线免费看| 欧美亚洲综合网| 亚洲视频图片小说| 99久久99久久免费精品蜜臀| 欧美一区二区三区在线视频| 亚洲人成小说网站色在线| 成人三级伦理片| 日韩精品在线网站| 国产做a爰片久久毛片| 在线电影一区二区三区| 肉色丝袜一区二区| 欧美伊人久久久久久午夜久久久久| 日韩理论电影院|