局域网屏幕监控
下面是程序执行结果
程序中使用从 CSocket 继承来的 CTCPCl ientSocket 和CTCPServerSocket来相互通信。并由客户端使用OnStart( )建立连接通信地址选用回环地址127.0.0.1来进行测试如果要监控特定主机须输入该机ip地址void CScreenDlg::OnStart()
{cl ientsocket.Create();run =false;bool ret=clientsocket.Connect("127.0.0.1",1033); //连接到1033端口if (!ret)return;this->SetTimer(0,1000,NULL); //设置时间间隔是1秒
}
服务器端进行监听
BOOL CServerDlg::OnInitDialog()
{
CDialog::OnInitDialog();
//Add"About..."menu item to system menu.
//IDM_ABOUTBOX must be in thesystemcommand range.
ASSERT((IDM_ABOUTBOX&0xFFF0)==IDM_ABOUTBOX);
ASSERT(IDM_ABOUTBOX<0xF000);
CMenu*pSysMenu =GetSystemMenu(FALSE);if (pSysMenu !=NULL)
{
CString strAboutMenu;strAboutMenu.LoadString(IDS_ABOUTBOX);if (!strAboutMenu.IsEmpty())
{pSysMenu->AppendMenu(MF_SEPARATOR);pSysMenu->AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu);}
}
//Setthe iconforthis dialog. Theframework doesthis automatical ly
SetIcon(m_hIcon,TRUE); //Set big icon
SetIcon(m_hIcon,FALSE); //Set smal l icon
//TODO:Add extra initialization herebool ret=false;serversoc ket.SetServerEvent(this);ret= serversocket.Create(1033); //打开1033端口ret= serversocket.Listen(); //进行监听return TRUE; //return TRUE unless you setthefocus to a control}
建立连接后服务器端使用GetScreen获取数据
并转换成2进制信息void CServerDlg::GetScreen()
{
CDC dc,bmpdc;int width,height;dc.CreateDC("DISPLAY",NULL,NULL,NULL);
CBitmap bm;width =GetSystemMetrics(SM_CXSCREEN);height=GetSystemMetrics(SM_CYSCREEN);
bm.CreateCompatibleBitmap(&dc,width,height);bmpdc.CreateCompatibleDC(&dc);bmpdc.SelectObject(&bm);bmpdc.BitBlt(0,0,width,height,&dc,0,0,SRCCOPY);bm.GetBitmap(&bitmap);size= bitmap.bmWidthBytes *bitmap.bmHeight;bmpdata= new char[size];
BITMAPIN FOHEADER bih;bih.biBitCount=bitmap.bmBitsPixel;bih.biClrImportant=0;bih.biClrUsed=0;bih.biCompression=0;bih.biHeight=bitmap.bmHeight;bih.biPlanes=1;bih.biSize=sizeof(BITMAPINFOHEADER);bih.biSizeImage=size;bih.biWidth=bitmap.bmWidth;bih.biXPelsPerMeter=0;bih.biYPelsPerMeter=0;
GetDIBits(dc,bm,0,bih.biHeight,bmpdata,(BITMAPINFO*)&bih,DIB_RGB_COLORS);}
发送图片数据:void CServerDlg::SendBitData(CSocket *socket)
{char*data=bmpdata;int sendlen=0;int len =0;do //发送图像数据
{sendlen = socket->Send(data,size);len += sendlen;data+= sendlen;
}while(len<size);delete bmpdata;bmpdata=NULL;size= 0;
}
发送图片结构void CServerDlg::SendBitmap(CSocket *socket)
{
GetScreen();socket->Send(&bitmap,sizeof(BITMAP));
}
客户端使用GetScreen( )来接送二进制数据void CScreenDlg::GetScreen()
{char*buffer= "M"; //获取图像结构信息cl ientsocket.Send(buffer,strlen(buffer));cl ientsocket.Receive(&bitmap,sizeof(BITMAP));size= bitmap.bmWidthBytes *bitmap.bmHeight;bmpdata= new char[size]; //处理图像的劢态数组char*data= bmpdata;int len,receivelen;len = receivelen =0;buffer="D"; //获取图像数据cl ientsocket.Send(buffer,strlen(buffer));do
{receivelen =clientsocket.Receive(data,size);len += receivelen;data+= receivelen;
}while(len<size);
DrawScreen();delete bmpdata;bmpdata=NULL;size= 0;
}
使DrawScreen( )来在窗口中绘制接收到的图形void CScreenDlg::DrawScreen()
{
CDC*dc=m_drawscreen.GetDC();
BITMAPIN FOHEADER bih;bih.biBitCount=bitmap.bmBitsPixel;bih.biClrImportant=0; //绘制图片相应参数bih.biClrUsed=0;bih.biCompression=0;bih.biHeight=bitmap.bmHeight;bih.biPlanes=1;bih.biSize=sizeof(BITMAPINFOHEADER);bih.biSizeImage=size;bih.biWidth=bitmap.bmWidth;bih.biXPelsPerMeter=0;bih.biYPelsPerMeter=0;
CBitmap bm;bm.CreateBitmapIndirect(&bitmap);
CDC bmpdc;bmpdc.CreateCompatibleDC(dc);
SetDIBits(bmpdc.m_hDC,bm,0,bitmap.bmHeight,bmpdata,(BITMAPINFO*)&bih,DIB_RGB_CO LO RS);bmpdc.SelectObject(&bm);
CRect rect;m_drawscreen.GetClientRect(&rect);dc->StretchBlt(0,0,rect.Width(),rect.Height(),&bmpdc,0,0,bitmap.bmWidth,bitmap.bmHeight,SRCCOPY);
}
当关闭窗口时会调用OnStopf来做处理void CScreenDlg::OnStop()
{this->Kil lTimer(0); //结束计时cl ientsocket.ShutDown(2);cl ientsocket.Close(); //关闭套接字
}
另外继承自CSocket的CTCPClentSocket和CTCPServerSocket分别定义了用亍接收的OnAccept( )用亍发送的OnRecieve( )用亍关闭套接字的
OnClose( )
OnAccept:void CTCPServerSocket::OnAccept(int nErrorCode){
CSocket::OnAccept(nErrorCode);cl ientsocket= new CTCPClientSocket(this);this->Accept(*clientsocket);
POSITION pos=ClientList.GetHeadPosition();Cl ientList.InsertBefore(pos,cl ientsocket);if (serverevent !=N ULL)cl ientsocket->SetClientEvent(serverevent);if (serverevent !=N ULL)serverevent->OnAccept(this,nErrorCode);}
OnRecieve:void CTCPClientSocket::OnReceive(int nErrorCode){
CSocket::OnReceive(nErrorCode);if (clientevent !=NULL)cl ientevent->OnReceive(this,nErrorCode);}
v5.net一直做独立服务器这块儿的,自从推出云服务器(VPS)以来站长一直还没有关注过,在网友的提醒下弄了个6G内存、2核、100G SSD的美国云服务器来写测评,主机测评给大家趟雷,让你知道v5.net的美国云服务器效果怎么样。本次测评数据仅供参考,有兴趣的还是亲自测试吧! 官方网站:https://v5.net/cloud.html 从显示来看CPU是e5-2660(2.2GHz主频),...
CloudCone 商家产品还是比较有特点的,支持随时的删除机器按时间计费模式,类似什么熟悉的Vultr、Linode、DO等服务商,但是也有不足之处就在于机房太少。商家的活动也是经常有的,比如这次中国春节期间商家也是有提供活动,比如有限定指定时间段之前注册的用户可以享受年付优惠VPS主机,比如年付13.5美元。1、CloudCone新年礼物限定款仅限2019年注册优惠购买,活动开始时间:1月31...
特网云官網特网云服务器在硬件级别上实现云主机之间的完全隔离;采用高端服务器进行部署,同时采用集中的管理与监控,确保业务稳定可靠,搭建纯SSD架构的高性能企业级云服务器,同时采用Intel Haswell CPU、高频DDR4内存、高速Sas3 SSD闪存作为底层硬件配置,分钟级响应速度,特网云采用自带硬防节点,部分节点享免费20G防御,可实现300G防御峰值,有效防御DDoS、CC等恶意攻击,保障...