//Socket报文发送c++升级版
#define _CRT_SECURE_NO_WARNINGS
#include<iostream>
using namespace std;
#include"des.h" //协议类
class SCK_HANDLE{
public:
SCK_HANDLE(){
memset(buf, , sizeof(buf));
buflen = ;
}
char buf[];
int buflen;
}; //框架类
class SocketFrame{
public:
virtual int cltSocketSend(unsigned char *buf/*in*/) = ;
virtual int cltSocketRev(unsigned char **buf/*out*/, int *buflen/*out*/) = ;
virtual ~SocketFrame(){}
}; //加密框架类
class Encrypt{
public:
//加密
virtual int DesEncSocket(char *plainstr/*in*/, int plainlen, char **cryptstr/*out*/, int *cryptlen) = ;
//解密
virtual int DesDecSocket(char *cryptstr/*in*/, int cryptlen, char **plainstr/*out*/, int *plainlen) = ;
}; //我自己的加密类
class MyEncrypt :public Encrypt{
public:
//加密
virtual int DesEncSocket(char *plainstr/*in*/, int plainlen, char **cryptstr/*out*/, int *cryptlen){
int ERRO_MSG = ;
if (plainstr == NULL || cryptstr == NULL || cryptlen==NULL)
{
ERRO_MSG = ;
cout << "加密参数列表为空!" << endl;
return ERRO_MSG;
}
//des密文比明文长,但是密文最多比明文多8个字节(所以我取10个足够)
*cryptstr = (char *)malloc((sizeof(char)*plainlen)+);
if (cryptstr==NULL)
{
ERRO_MSG = ;
cout << "加密函数分配输出内存失败!" << endl;
return ERRO_MSG;
}
int ret= DesEnc((unsigned char *)plainstr, plainlen, (unsigned char *)*cryptstr, cryptlen);
if (ret!=)
{
ERRO_MSG = ;
cout << "des加密函数执行失败!" << endl;
return ERRO_MSG;
}
return ERRO_MSG;
}
//解密
virtual int DesDecSocket(char *cryptstr/*in*/, int cryptlen, char **plainstr/*out*/, int *plainlen){
int ERRO_MSG = ;
if (plainstr == NULL || cryptstr == NULL || plainlen == NULL)
{
ERRO_MSG = ;
cout << "解密参数列表为空!" << endl;
return ERRO_MSG;
}
//分配内存空间(des密文只可能比明文长)
*plainstr = (char *)malloc((sizeof(char)*cryptlen));
if (plainstr==NULL)
{
ERRO_MSG = ;
cout << "分配输出内存失败!" << endl;
return ERRO_MSG;
}
int ret = DesDec((unsigned char *)cryptstr, cryptlen, (unsigned char *)*plainstr, plainlen);
if (ret != )
{
ERRO_MSG = ;
cout << "des解密函数执行失败!" << endl;
return ERRO_MSG;
}
return ERRO_MSG;
}
}; //第三方的类
class MySocket :public SocketFrame{
public:
MySocket(){
//分配内存,因为handle贯穿整个报文发送,所以不适合栈内存
handle = new SCK_HANDLE();
mye = new MyEncrypt();
}
MySocket(MySocket &msp/*in*/){
cout << "不允许使用拷贝够咱函数" << endl;
//以防不备
handle = new SCK_HANDLE();
handle->buflen = msp.handle->buflen;
strcpy(handle->buf, msp.handle->buf); }
//接收报文
virtual int cltSocketSend(unsigned char *buf/*in*/){
int ERRO_MSG = ;
if (buf==NULL)
{
ERRO_MSG = ;
cout << "接收报文的值为空!" << endl;
return ERRO_MSG;
}
if (handle==NULL)
{
ERRO_MSG = ;
cout << "报文对象没有初始化!" << endl;
return ERRO_MSG;
}
//报文加密
int tempt = strlen((const char *)buf) + ;
//准备密文接收缓存
unsigned char *tempstr = NULL;
int ret= mye->DesEncSocket((char *)buf, tempt, (char **)&tempstr, &tempt);
if (ret!=)
{
ERRO_MSG = ;
cout << "密文加密失败" << endl;
return ERRO_MSG;
}
//将密文放进报文结构体
strcpy(handle->buf, (const char*)tempstr);
//释放内存
if (tempstr!=NULL)
{
free(tempstr);
tempstr = NULL;
}
handle->buflen = tempt;
return ERRO_MSG;
}
//发送报文
virtual int cltSocketRev(unsigned char **buf/*out*/, int *buflen/*out*/){
int ERRO_MSG = ;
if (buf == NULL || buflen==NULL)
{
ERRO_MSG = ;
cout << "业务接受报文数组不存在或者业务接受报文长度变量不存在!" << endl;
return ERRO_MSG;
}
if (handle == NULL)
{
ERRO_MSG = ;
cout << "报文对象没有初始化!" << endl;
return ERRO_MSG;
}
//解密报文
int ret = mye->DesDecSocket(handle->buf, handle->buflen, (char **)buf, buflen);
if (ret!=)
{
ERRO_MSG = ;
cout << "报文对象密文解密失败!" << endl;
return ERRO_MSG;
}
return ERRO_MSG;
}
~MySocket(){
if (handle!=NULL)
{
delete handle;
handle = NULL;
}
if (mye!=NULL)
{
delete mye;
mye = NULL;
}
}
private:
SCK_HANDLE *handle;
MyEncrypt *mye;
}; //操作业务类
class ProtectSocket{
public:
void Setsp(SocketFrame &pin){
sp = &pin;
}
void ProtectA();
~ProtectSocket(){
}
private:
SocketFrame *sp;
}; void ProtectSocket::ProtectA(){
unsigned char newbuf1[] = "我是发送的报文:dddddddddddddd"; //发送报文
int ret = ;
ret = sp->cltSocketSend(newbuf1);
if (ret!=)
{
cout << "报文发送出错!" << endl;
}
unsigned char *newbuf2 = NULL;
int newlen2 = ;
//接受报文
ret = sp->cltSocketRev(&newbuf2, &newlen2);
if (ret!=)
{
cout << "报文接受出错!" << endl;
}
//释放内存
if (newbuf2!=NULL)
{
free(newbuf2);
newbuf2 = NULL;
}
} void main(){
//new 第三方类对象
SocketFrame *sp = new MySocket();
ProtectSocket *psc = new ProtectSocket();
psc->Setsp(*sp);
psc->ProtectA();
delete psc;
psc = NULL;
delete sp;
sp = NULL;
system("pause");
}

C++ Scoket的升级版(多态的运用)的更多相关文章

  1. 线程间通信--生产者消费者 升级版JDK5

    import java.util.concurrent.locks.*; /*1.新的解锁,上锁操作,据说是jdk5.0升级版,以前的枷锁,解锁都是隐藏的,默认的,现在变成显式 2.新的异常处理方式  ...

  2. day 27 多态 接口 类方法 静态方法 hashlib 摘要算法模块

    # 多态的理解:# Python 天生自带多态# 鸭子类型 list 和 tuple 就是一对鸭子类型 很像但是没有继承关系## 而其他的类型 上传参数或者打印参数的时候 必须是指定的数据类型# -- ...

  3. 七:Java之封装、抽象、多态和继承

    本文章介绍了关于Java中的面向对象封装.抽象.继承.多态特点 Java面向对象主要有四大特性:封装.抽象.继承和多态. 一.封装 封装就是将抽象得到的数据和行为(或功能)相结合,形成一个有机的总体, ...

  4. day24:多态&魔术方法__new__&单态模式

    目录 1.多态 2.__new__魔术方法 2.1 关于魔术方法__new__ 2.2 基本语法 2.3 __new__ 触发时机快于构造方法 2.4 __new__ 和 __init__ 参数一一对 ...

  5. Learn day7 继承(单、多、菱形)\多态\魔术方法\装饰器\异常

    1.继承 1.1 单继承# ### 继承 """ (1) 单继承 (2) 多继承 至少2个类,子类和父类 一个类继承另外一个类,当前类是子类 (衍生类) 被继承的这个类是 ...

  6. Java中的多态

    1.多态:具有表现多种形态的能力的特征 父类: public abstract class Animal {public abstract void Say();} 子类: public class ...

  7. C# 工厂模式+虚方法(接口、抽象方法)实现多态

    面向对象语言的三大特征之一就是多态,听起来多态比较抽象,简而言之就是同一行为针对不同对象得到不同的结果,同一对象,在不同的环境下得到不同的状态. 实例说明: 业务需求:实现一个打开文件的控制台程序的d ...

  8. C#非常重要基础之多态

    前几天看了一位同志的博客,写的是关于他自己去支付宝面试的经历.过程大体是这样的:问答的时候,前面部分,作者都应答如流,说起自己经验如何之丰富,最后面试官问了作者一个问题:请简述多态的概念和作用.结果这 ...

  9. C++多态详解

    多态是面向对象的程序设计的关键技术.多态:调用同一个函数名,可以根据需要但实现不同的功能.多态体现在两个方面,我们以前学过的编译时的多态性(函数重载)和现在我们这一章将要学习的运行时的多态性(虚函数) ...

随机推荐

  1. 虚拟机集群出现“Device eth0 does not seem to be present, delaying initialization” failed

    问题再现: 解决办法: 1:编辑/etc/sysconfig/network-scripts/ifcfg-eth0配置文件,将ifcfg-eth0的配置文件里里面以前的关于MAC地址这一行删除掉.另外 ...

  2. IO/序列化/JSON

    一.读写文件 1.open:打开文件 open(path, mode, encoding='xxx', errors='ignore') mode取值:rU 或 Ua 以读方式打开, 同时提供通用换行 ...

  3. php使用curl请求数据(采集数据)

    <?php $url = "http://www.baidu.com/s?wd=刘俊涛的博客"; $header = array( 'User-Agent: Mozilla/ ...

  4. nginx 反向代理做域名转发简单配置

    这里用的是nginx for windows 首先进入nginx配置文件,做以下配置: server { listen 80; server_name abc.com; location / { pr ...

  5. Webbrowser控件判断网页加载完毕的简单方法

    一般情况下,当ReadyState属性变成READYSTATE_COMPLETE时,Webbrowser控件会通过触发DocumentCompleted事件来指示网页加载完毕.但当加载的网页包含fra ...

  6. Nuget使用规范

  7. SQL外键约束

    1.查询表已有的外键 select name from sys.foreign_key_columns f join sys.objects o on f.constraint_object_id=o ...

  8. java之TCP(Socket,serverSocket)实例

    import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import ...

  9. Hibernate JPA实体继承的映射(二) @MappedSuperclass

    基于代码复用和模型分离的思想,在项目开发中使用JPA的@MappedSuperclass注解将实体类的多个属性分别封装到不同的非实体类中. 1.@MappedSuperclass注解只能标准在类上:@ ...

  10. Lintcode---线段树修改

    对于一棵 最大线段树, 每个节点包含一个额外的 max 属性,用于存储该节点所代表区间的最大值. 设计一个 modify 的方法,接受三个参数 root. index 和 value.该方法将 roo ...