局域网屏幕监控
下面是程序执行结果
程序中使用从 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);}
hostkvm怎么样?hostkvm是一家国内老牌主机商家,商家主要销售KVM架构的VPS,目前有美国、日本、韩国、中国香港等地的服务,站长目前还持有他家香港CN2线路的套餐,已经用了一年多了,除了前段时间香港被整段攻击以外,一直非常稳定,是做站的不二选择,目前商家针对香港云地和韩国机房的套餐进行7折优惠,其他套餐为8折,商家支持paypal和支付宝付款。点击进入:hostkvm官方网站地址hos...
WebHorizon是一家去年成立的国外VPS主机商,印度注册,提供虚拟主机和VPS产品,其中VPS包括OpenVZ和KVM架构,有独立IP也有共享IP,数据中心包括美国、波兰、日本、新加坡等(共享IP主机可选机房更多)。目前商家对日本VPS提供一个8折优惠码,优惠后最低款OpenVZ套餐年付10.56美元起。OpenVZCPU:1core内存:256MB硬盘:5G NVMe流量:200GB/1G...
对于一般的用户来说,我们使用宝塔面板免费版本功能还是足够的,如果我们有需要付费插件和专业版的功能,且需要的插件比较多,实际上且长期使用的话,还是购买付费专业版或者企业版本划算一些。昨天也有在文章中分享年中促销活动。如今我们是否会发现,我们在安装宝塔面板后是必须强制我们登录账户的,否则一直有弹出登录界面,我们还是注册一个账户比较好。反正免费注册宝塔账户还有代金券赠送。 新注册宝塔账户送代金券我们注册...