• 句柄5


    IP Address Control
      ===================
      
      IPM_CLEARADDRESS 清除 IP 地址控件(IP Address control)的内容
      IPM_GETADDRESS IP 地址控件 获得 存储在 它中的 IP 地址 信息/
      IPM_ISBLANK 决定 IP 地址控件 是否可以为 空值。既 127.0.0.1 之类的地址 空。
      IPM_SETADDRESS IP 地址控件中设置 IP 地址。
      IPM_SETFOCUS IP 地址控件中,当需要输入 IP 地址时, 使之获得 键盘输入 焦点
      IPM_SETRANGE 设置 输入IP 地址的有效范围
      =====================
      Media Control Interface (MCI)
      =============================
      MM_MCINOTIFY 告诉 窗体 MCI 命令 完成的状态. 这个 状态包括 success, failure, 或 其它事件
      
      Menus
      =============================
      WM_COMMAND 当 用户 选择 菜单中的 项目后,将向 窗体 发送此消息. 窗体 受到 此消息后,再 决定 下一个 行为
      
      WM_INITMENU 当 菜单 准备 显示 前,向 窗体发送 此消息, 窗体 将 初始化 菜单 项.
      
      WM_SYSCOMMAND 窗体 发送 用户点击 系统菜单 消息. 窗体将 响应 这个消息 ,决定 下个 行为.
      ================
      Windows
      =====================
      
      WM_CLOSE 发送 让窗体关闭的消息,有些窗体会 在此时 弹出个 关闭对话框。
      
      WM_GETTEXT 返回 窗体 标题栏 (caption 属性)。 需要先 用WM_GETTEXTLENGTH 获得 字符串长度
      
      WM_GETTEXTLENGTH 见上!
      
      WM_HELP 发送此 消息后,将 显示 指定的 HELP 文件
      WM_SETTEXT 设置 窗体 标题栏 。
      ==============================
      List Boxes
      ===============
      
      LB_ADDSTRING 在条目中添加 字符串
      
      LB_DELETESTRING 删除一个 条目. 条目 序号是从 0 开始的.
      
      LB_GETCOUNT 得到 条目总数.
      
      LB_GETCURSEL 得到 单选 的list box 的 选项条目的 序号
      
      LB_GETSEL 判断 list 的 条目 是否被选上, 如果 选上了,则返回 >0 的值.否则 返回 0 ,表示 用户没选择条目
      
      LB_GETSELCOUNT 获得 可多选 的list , 被用户选择的条目的个数.
      
      LB_GETSELITEMS 返回 可多选的list 的 被选条目的 序号. 可返回 数组.
      
      LB_GETTEXT 得到 list中的 一个 条目的 text
      LB_GETTEXTLEN 得到 list中的 一个 条目的 text 值的长度
      LB_INSERTSTRING list 中,插入 一个条目。如果成功,将返回 插入后,此条目的序号。
      LB_RESETCONTENT 清空 所有的 list 中的 条目。
      LB_SETCURSEL 对单选 的list box, 设定 用户 选择条目的 具体值
      LB_SETSEL 对多选 的list box, 设定 用户 选择条目的 具体值
      =======================================================
      Mouse
      ==================
      WM_LBUTTONDBLCLK 当鼠标在一个窗体范围内时,告诉此窗体 鼠标左键 已双击 。返回值 0
      
      WM_LBUTTONDOWN 当鼠标在一个窗体范围内时,告诉此窗体 鼠标左键 已点击,返回值 0
      WM_LBUTTONUP 当鼠标在一个窗体范围内时,告诉此窗体 鼠标左键 已释放,返回值 0
      
      WM_MBUTTONDBLCLK 当鼠标在一个窗体范围内时,告诉此窗体 鼠标中键 已双击 。返回值 0
      WM_MBUTTONDOWN 当鼠标在一个窗体范围内时,告诉此窗体 鼠标中键 已点击,返回值 0
      WM_MBUTTONUP 当鼠标在一个窗体范围内时,告诉此窗体 鼠标中键 已释放,返回值 0
      最近越来越觉得,windows果然是很不安全啊,,,想要学windows平台的编程,就要学mfc,在win上,mfc简直无所不能。。。
      
      Trackback: [url=http://tb.blog.csdn.net/TrackBack.aspx?PostId=2185728]http://tb.blog.csdn.net/TrackBack.aspx?PostId=2185728[/url]

     

    SendMessageA
    说明:       调用一个窗口的窗口函数,将一条消息发给那个窗口。除非消息处理完毕,否则该函数不会返回SendMessage所包含4个参数:    
    1.       hwnd       32
    位的窗口句柄窗口可以是任何类型的屏幕对象,因为Win32能够维护大多数可视对象的句柄
    2.       wMsg      
    用于区别其他消息的常量值,这些常量可以是Windows单元中预定义的常量,也可以是自定义的常量
    3.      
    wParam       通常是一个与消息有关的常量值,也可能是窗口或控件的句柄
    4.       lParam      
    通常是一个指向内存中数据的指针。由于WParmlParamPointer都是32位的,因此,它们之间可以相互转换
    wMsg
    函数    
    WM_Create       创建一个窗口
    WM_DESTROY       当一个窗口被破坏时发送
    WM_MOVE       移动一个窗口
    WM_SIZE       改变一个窗口的大小
    WM_ACTIVATE       一个窗口被激活或失去激活状态
    WM_SETFOCUS       一个窗口获得焦点
    WM_KILLFOCUS       一个窗口失去焦点
    WM_ENABLE       一个窗口改变成Enable状态
    WM_SETREDRAW       设置窗口是否能重画
    WM_SETTEXT       应用程序发送此消息来设置一个窗口的文本
    WM_GETTEXT       应用程序发送此消息来复制对应窗口的文本到缓冲区
    WM_GETTEXTLENGTH       得到与一个窗口有关的文本的长度(不包含空字符)
    WM_PAINT       要求一个窗口重画自己
    WM_CLOSE       当一个窗口或应用程序要关闭时发送一个信号
    WM_QUERYENDSESSION       用户选择结束对话框或程序自己调用ExitWindows函数
    WM_QUIT       用来结束程序运行
    WM_QUERYOPEN       用户窗口恢复以前的大小位置时,把此消息发送给某个图标
    WM_ERASEBKGND       当窗口背景必须被擦除时(例在窗口改变大小时)
    WM_SYSCOLORCHANGE       当系统颜色改变时,发送此消息给所有顶级窗口
    WM_QUERYENDSESSION       消息后,此消息发送给应用程序,通知它对话是否结束
    WM_SHOWWINDOW       当隐藏或显示窗口是发送此消息给这个窗口
    WM_ACTIVATEAPP       发此消息给应用程序哪个窗口是激活的,哪个是非激活的    
    WM_FONTCHANGE       当系统的字体资源库变化时发送此消息给所有顶级窗口
    WM_TIMECHANGE       当系统的时间变化时发送此消息给所有顶级窗口
    WM_CANCELMODE       发送此消息来取消某种正在进行的摸态(操作)
    WM_SETCURSOR       如果鼠标引起光标在某个窗口中移动
    WM_ENDSESSION       当系统进程发出且鼠标输入没有被捕获时,就发消息给某个窗口
    WM_MOUSEACTIVATE       当光标在某个非激活的窗口中而用户正按着鼠标的某个键发送此消息给当前窗口
    WM_CHILDACTIVATE       送此消息给MDI子窗口当用户点击此窗口的标题栏,或当窗口被激活,移动,改变大小
    WM_QUEUESYNC     此消息由基于计算机的训练程序发送,通过       WH_JOURNALPALYBACKhook程序分离出用户输入消息
    WM_GETMINMAXINFO       此消息发送给窗口当它将要改变大小或位置    
    WM_PAINTICON       发送给最小化窗口当它图标将要被重画
    WM_ICONERASEBKGND       此消息发送给某个最小化窗口,仅当它在画图标前它的背景必须被重画
    WM_NEXTDLGCT发送此消息给一个对话框程序去更改焦点位置
    WM_SPOOLERSTATUS       每当打印管理列队增加或减少一条作业时发出此消息    
    WM_DRAWITEM       buttoncomboboxlistboxmenu的可视外观改变时发送
    WM_MEASUREITEM       button,       combobox,       listbox,       listview       control,       or       menuitem       被创建时
    WM_VKEYTOITEM       此消息有一个LBS_WANTKEYBOARDINPUT风格的发出给它的所有者来响应WM_KEYDOWN消息    
    WM_CHARTOITEM       此消息由一个LBS_WANTKEYBOARDINPUT风格的列表框发送给他的所有者来响应WM_CHAR消息    
    WM_SETFONT       当绘制文本时程序发送此消息得到控件要用的颜色
    WM_GETFONT       应用程序发送此消息得到当前控件绘制文本的字体
    WM_SETHOTKEY       应用程序发送此消息让一个窗口与一个热键相关连
    WM_GETHOTKEY       应用程序发送此消息来判断热键与某个窗口是否有关联
    WM_QUERYDRAGICON       此消息发送给最小化窗口,当此窗口将要被拖放而它的类中没有定义图标,应用程序能返回一个图标或光标的句柄,当用户拖放图标时系统显示这个图标或光标
    WM_COMPAREITEM       发送此消息来判定comboboxlistbox新增加的项的相对位置
    WM_COMPACTING       显示内存已经很少了
    WM_WINDOWPOSCHANGING       发送此消息给那个窗口的大小和位置将要被改变时,来调用setwindowpos函数或其它窗口管理函数
    WM_WINDOWPOSCHANGED       发送此消息给那个窗口的大小和位置已经被改变时,来调用setwindowpos函数或其它窗口管理函数
    WM_POWER       当系统将要进入暂停状态时发送此消息
    WM_COPYDATA       当一个应用程序传递数据给另一个应用程序时发送此消息
    WM_CANCELJOURNA       当某个用户取消程序日志激活状态,提交此消息给程序
    WM_NOTIFY       当某个控件的某个事件已经发生或这个控件需要得到一些信息时,发送此消息给它的父窗口    
    WM_INPUTLANGCHANGEREQUEST       当用户选择某种输入语言,或输入语言的热键改变
    WM_INPUTLANGCHANGE       当平台现场已经被改变后发送此消息给受影响的最顶级窗口
    WM_TCARD       当程序已经初始化windows帮助例程时发送此消息给应用程序
    WM_HELP       此消息显示用户按下了F1,如果某个菜单是激活的,就发送此消息个此窗口关联的菜单,否则就发送给有焦点的窗口,如果当前都没有焦点,就把此消息发送给当前激活的窗口
    WM_USERCHANGED       当用户已经登入或退出后发送此消息给所有的窗口,当用户登入或退出时系统更新用户的具体设置信息,在用户更新设置时系统马上发送此消息
    WM_NOTIFYFORMAT       公用控件,自定义控件和他们的父窗口通过此消息来判断控件是使用ANSI还是UNICODE结构

       function     EnumChildWindowsProc(hwnd,     lparam:     Integer):     Boolean;  
       var  
           buffer:     array[0..255]     of     char;  
       begin  
           Result     :=     True;  
           GetClassName(hwnd,buffer,256);  
           if     StrPas(Buffer)='Edit'     then  
           begin  
               SendMessage(hwnd,WM_GETTEXT,256,lparam);  
               Result:=False;  
           end;  
       end;  
        
       procedure     TForm1.Button1Click(Sender:     TObject);  
       var  
           hwnd:     Integer;  
           buffer:     array[0..255]     of     char;  
       Begin  
           hwnd     :=     FindWindow('CabinetWClass',nil);  
           if     hwnd<>     0     then  
           begin  
               EnumChildWindows(hwnd,@EnumChildWindowsProc,Longint(@buffer[0]));  
               Caption     :=     StrPas(buffer);  
           end;  
       end;  

    //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

    我在程序a中写:

    procedure MyWndProc(var Msg: TMessage);

     

    procedure TForm1.MyWndProc(var Msg: TMessage);

    begin

     if (msg.Msg=WM_USER 101) then    

     begin

            showmessage('user101');

     end

     else

     begin

        inherited WndProc(msg);

        //oldproc(msg);

     end;

     

    end;

     

    WindowProc:=MyWndProc;

     

    当点按钮发送:

    SendMessage(self.Handle ,WM_USER 101,101,0);

    那肯定没问题,但SendMessage(HWND_BROADCAST,WM_USER 101,101,0);是不行的,因为WindowProc:=MyWndProc;是本窗口的,我想HWND_BROADCAST时,也能接收到,WindowProc:=MyWndProc要改为什么??

    其实我的目的是程序a发送消息SendMessage(HWND_BROADCAST,WM_USER 101,101,0);独立的另一程序b来接收消息的,所以我用HWND_BROADCAST来在a程序中做测试,用application.OnMessage=我没试验成功呀,onmessage好像对键盘值到是起作用的。请高手帮忙。

    贴子来源飞诺网(http://bbs.firnow.com) 详细出处参考:http://bbs.firnow.com/dview42t42039.html

    简单点就是我a程序向window发出一个消息wm_user 101,

    b程序捕获来自window的消息wm_user 101

    “那就把上面那段代码写到b中就行了啊~”不行的。

    贴子来源飞诺网(http://bbs.firnow.com) 详细出处参考:http://bbs.firnow.com/dview42t42039.html

    需要使用RegisterWindowMessage来注册那个消息, 给你一个例子:

     

    type

     TForm1 = class(TForm)

        Button1: TButton;

        Memo1: TMemo;

        procedure Button1Click(Sender: TObject);

        procedure FormCreate(Sender: TObject);

        procedure FormDestroy(Sender: TObject);

     private

        iMsg    : Integer;

        OldProc : TWndMethod;

        procedure MyMessage(var Msg: TMessage);

     end;

     

    var

     Form1: TForm1;

     

    implementation

     

    {$R *.dfm}

     

    procedure TForm1.FormCreate(Sender: TObject);

    begin

     OldProc := Self.WindowProc;

     Self.WindowProc := MyMessage;

     iMsg := RegisterWindowMessage('MyMessage');

    end;

     

    procedure TForm1.FormDestroy(Sender: TObject);

    begin

     Self.WindowProc := OldProc;

    end;

     

    procedure TForm1.MyMessage(var Msg: TMessage);

    begin

     if msg.Msg = iMsg then

        Memo1.Lines.Add('!!!!')

     else

        OldProc(Msg);

    end;

     

    procedure TForm1.Button1Click(Sender: TObject);

    begin

     SendMessage (HWND_BROADCAST, iMsg, 0, 0);

    end;

     

    end.

     

    贴子来源飞诺网(http://bbs.firnow.com) 详细出处参考:http://bbs.firnow.com/dview42t42039.html

    /////////////////////////////////////////////////////////////////////

  • 相关阅读:
    vi/vim
    Linux相关知识
    Pikachu实验环境搭建
    DVWA-XSS(Reflected)(反射型跨站脚本攻击)
    DVWA-SQL Injection(Blind)(SQL盲注)
    DVWA—File Upload(文件上传)
    DVWA—Command Injection(命令注入)
    DVWA—Command Injection(命令注入)中出现乱码
    DVWA—Brute Force(暴力破解)
    sqli-labs闯关之61-65关
  • 原文地址:https://www.cnblogs.com/hssbsw/p/1963969.html
Copyright © 2020-2023  润新知