XFTP辅助同步服务器小工具(VC++)

由于工作需要,经常会通过ftp工具上传一些文件到服务器,这个操作已经很烦人了,但更烦人的是还要再同步到其他服务器(当然有的公司是不需要手动同步的,省去了这个麻烦),也可以写一些shell脚本来解决,但大多从事前端工作的人,并不熟悉shell脚本语言,也没有太多机会去接触。所以在此为部门工作需要特别写了这个小工具,解决上传ftp后还要手动同步的问题。
现在我把实现主要流程与大家分享一下,自己也做一下记录。

工欲善其事,必先利其器

A 首先,准备上传后端服务器软件,我选择了XFTP,当然其它FTP工具也是一样的;

B 其次,再加上vs和它的自带工具spy++就万事大吉了。

实现思路

通过XFTP上传到后端服务器对应的目录下面,这时后端服务器与前端服务器基本目录结构是一致的,至少主要的频道目录是一致的,这就为我们后面同步到前端机群找到了最基本的理论依据。当使用者通过XFTP上传完要同步的文件后,通过事先启动的这个辅助小工具自动去定位出刚才文件所在目录结构,传给后台程序,后台程序通过辅助工具传送过来的目录结构,去把后端机的指定文件,调用shell语句同步到其它前端机。这样做后,就形成了一个这样操作过程:XFTP上传-->在辅助工具上点击同步-->后台程序自动取得辅助工具传送的路径同时同步到前端机,这样的话,原来很繁琐的过程,以后只需要一个同步按钮来实现了。

具体实现方法(去掉了许多无关主体实现的语句)


//获得桌面窗口
CWnd* pDesktopWnd = CWnd::GetDesktopWindow();

//获得第一个子窗口
CWnd* pWnd = pDesktopWnd->GetWindow(GW_CHILD);

while (pWnd != NULL)
{
//获得窗口标题
CString strWindowText= _T("");
::GetWindowText(pWnd->GetSafeHwnd(), strWindowText.GetBuffer(256), 256);
strWindowText.ReleaseBuffer();

if(strWindowText.Find("Xftp 1.3")!=-1)
{
fHwnd = pWnd->GetSafeHwnd();
break;
}

//继续下一个子窗口
pWnd = pWnd->GetWindow(GW_HWNDNEXT);
}

hWnd = fHwnd;
hWnd=::FindWindowEx(hWnd,0,"MDIClient",0);
hWnd=::FindWindowEx(hWnd,0,0,strFTP); //此处是变化的
hWnd=::FindWindowEx(hWnd,0,"AfxFrameOrView42",0);
hWnd=::FindWindowEx(hWnd,0,"ComboBoxEx32",0);
hWnd=::FindWindowEx(hWnd,0,"ComboBox",0);
hWnd=::FindWindowEx(hWnd,0,"Edit",0);

char buf[MAX_PATH];

//得到地址框
::SendMessage(hWnd,WM_GETTEXT,MAX_PATH,(LPARAM)buf);

hWnd = fHwnd;
hWnd=::FindWindowEx(hWnd,0,"MDIClient",0);
hWnd=::FindWindowEx(hWnd,0,0,"22.22.22.222"); //此处是变化的
hWnd=::FindWindowEx(hWnd,0,"AfxFrameOrView42",0);

int count;
int i;

BOOL bResult = FALSE;
HWND hWndNextChild = ::GetWindow(hWnd,GW_CHILD);

//遍历窗体
while (::IsWindow(hWndNextChild))
{
if (::GetParent(hWndNextChild) == hWnd)
{
//这里处理一下
char Class[MAX_PATH];
::GetClassName(hWndNextChild,Class,MAX_PATH);
if(!strcmp(Class,"SysListView32"))
{
if(::IsWindowVisible(hWndNextChild))//这一句很关键,因为一般的ftp都有2个列表窗体
{
count = 0;
count = (int)::SendMessage(hWndNextChild,LVM_GETITEMCOUNT,0,0);
if(count)
{
hListview = hWndNextChild;
bResult = TRUE;
}
}

}
}
hWndNextChild = ::GetWindow(hWndNextChild,GW_HWNDNEXT);
}
屏幕取词程序VC源码 nhw32.dll 主要引出两个函数: 1. DWORD WINAPI BL_SetFlag32(UINTnFlag, HWND hNotifyWnd, int MouseX, int MouseY) 功能: 启动或停止取词。 参数: nFlag [输入] 指定下列值之一: GETWORD_ENABLE: 开始取词。在重画被取单词区域前设置此标志。 nhw32.dll是通过 重画单词区域,截取TextOutA, TextOutW,ExtTextOutA, ExtTextOutW等Windows API函数的参数来取词的。 GETWORD_DISABLE: 停止取词。 hNotifyWnd [输入] 通知窗口句柄。当取到此时,向该通知窗口发送一登记消息: GWMSG_GETWORDOK。 MouseX [输入] 指定取词点的X坐标。 MouseY [输入] 指定取词点的Y坐标。 返回值: 可忽略。 2. DWORD WINAPI BL_GetText32(LPSTRlpszCurWord, int nBufferSize, LPRECT lpWordRect) 功能: 从内部缓冲区取出单词文本串。对英语文本,该函数最长取出一行内以 空格为界的三个英文单词串,遇空格,非英文字母及除‘-’外的标点符 号,则终止取词。对汉字文本,该函数最长取出一行汉字串,遇英语字 母,标点符号等非汉语字符,则终止取词。该函数不能同时取出英语和 汉语字符。 参数: lpszCurWord [输入] 目的缓冲区指针。 nBufferSize [输入] 目的缓冲区大小。 lpWordRect [输出] 指向 RECT 结构的指针。该结构定义了被取单词所在矩形区域。 返回值: 当前光标在全部词中的位置。 此外,WinNT/2000版nhw32.dll 还引出另两个函数: 1. BOOL WINAPI SetNHW32() 功能: Win NT/2000 环境下的初始化函数。一般在程序开始时,调用一次。 参数: 无。 返回值: 如果成功 TRUE ,失败 FALSE 。 2. BOOL WINAPI ResetNHW32() 功能: Win NT/2000 环境下的去初始化函数。一般在程序结束时调用。 参数: 无。 返回值: 如果成功 TRUE ,失败 FALSE
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值