C# SendMessage用法(调用windows API)

2024-06-11 20:58

本文主要是介绍C# SendMessage用法(调用windows API),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

函数功能:该函数将指定的消息发送到一个或多个窗口。此函数为指定的窗口调用窗口程序,直到窗口程序处理完消息再返回。而函数PostMessage不同,将一个消息寄送到一个线程的消息队列后立即返回。

    函数原型:LRESULT SendMessage(HWND hWnd,UINT Msg,WPARAM wParam,LPARAM IParam);

    参数:

    hWnd:其窗口程序将接收消息的窗口的句柄。如果此参数为HWND_BROADCAST,则消息将被发送到系统中所有顶层窗口,包括无效或不可见的非自身拥有的窗口、被覆盖的窗口和弹出式窗口,但消息不被发送到子窗口。

    Msg:指定被发送的消息。

    wParam:指定附加的消息指定信息。

    IParam:指定附加的消息指定信息。

    返回值:返回值指定消息处理的结果,依赖于所发送的消息。

    备注:需要用HWND_BROADCAST通信的应用程序应当使用函数RegisterWindowMessage来为应用程序间的通信取得一个唯一的消息。

    如果指定的窗口是由调用线程创建的,则窗口程序立即作为子程序调用。如果指定的窗口是由不同线程创建的,则系统切换到该线程并调用恰当的窗口程序。线程间的消息只有在线程执行消息检索代码时才被处理。发送线程被阻塞直到接收线程处理完消息为止。

 

以上是对SendMessage的基本介绍,其用法很多,主要是在于其参数的使用和数据转换:

 

 SendMessage是一个在user32.dll中声明的API函数,在C#中导入如下:

using System.Runtime.InteropServices;
[DllImport("user32.dll", EntryPoint="SendMessageA")]
public static extern int SendMessage (IntPtr hwnd, int wMsg, IntPtr wParam, IntPtr lParam);

 

本文描述其参数 lParam 的用法,主要是数据类型之间的转化

● 一种最简单的处理方式是声明多个SendMessage函数(overload),用所需的数据类型直接替换IntPtr。例如:

复制代码

//声明:
[DllImport("user32.dll", EntryPoint="SendMessageA")]
private static extern int SendMessage (IntPtr hwnd, int wMsg, IntPtr wParam,  string lParam);
[DllImport("user32.dll", EntryPoint="SendMessageA")]
private static extern int SendMessage (IntPtr hwnd, int wMsg, IntPtr wParam,  ref Rectangle lParam);
//调用:
string s = "hello, floodzhu";
SendMessage(this.textBox1.Handle, WM_SETTEXT, IntPtr.Zero, s);Rectangle rect = new Rectangle();
SendMessage(this.richTextBox1.Handle, EM_GETRECT, (IntPtr)0, ref rect);

复制代码

● 对要求返回字符串的类型(out string)可以用 StringBuilder 代替,此时不需要 out/ref。例如:

复制代码

[DllImport("user32.dll", EntryPoint="SendMessageA")]
private static extern int SendMessage (IntPtr hwnd, int wMsg, int wParam, StringBuilder lParam);
private void button1_Click(object sender, System.EventArgs e)
{const int buffer_size = 1024;StringBuilder buffer = new StringBuilder(buffer_size);SendMessage(this.textBox1.Handle, WM_GETTEXT, buffer_size, buffer);//MessageBox.Show(buffer.ToString());
}

复制代码

 

● 如果想用 InPtr 类型统一处理的话,可以借助于 Marshal 或者 GCHandle 的相关方法。例如:

复制代码

[DllImport("user32.dll", EntryPoint="SendMessageA")]
private static extern int SendMessage (IntPtr hwnd, int wMsg, IntPtr wParam, IntPtr lParam);private void button2_Click(object sender, System.EventArgs e)
{Rectangle rect = new Rectangle();IntPtr buffer = Marshal.AllocHGlobal(Marshal.SizeOf(typeof(Rectangle)));Marshal.StructureToPtr(rect, buffer ,true);SendMessage(this.richTextBox1.Handle, EM_GETRECT, (IntPtr)0, buffer);rect = (Rectangle)Marshal.PtrToStructure(buffer, typeof(Rectangle));Marshal.FreeHGlobal(buffer);
}

复制代码

 

或者

复制代码

private void button2_Click(object sender, System.EventArgs e)
{Rectangle rect = new Rectangle();GCHandle gch = GCHandle.Alloc(rect);SendMessage(this.richTextBox1.Handle, EM_GETRECT, (IntPtr)0, (IntPtr)gch);rect = (Rectangle)Marshal.PtrToStructure((IntPtr)gch, typeof(Rectangle));gch.Free();
}

复制代码

 

● 模拟按钮点击。第三个参数是可选参数,有时需要有时不需要,比如该例中就不需要。

复制代码

const int BM_CLICK = 0xF5;
IntPtr maindHwnd = FindWindow(null, "QQ用户登录"); //获得QQ登陆框的句柄
if (maindHwnd != IntPtr.Zero)
{IntPtr childHwnd = FindWindowEx(maindHwnd, IntPtr.Zero, null, "登录");   //获得按钮的句柄if (childHwnd != IntPtr.Zero){SendMessage(childHwnd, BM_CLICK, 0, 0);     //发送点击按钮的消息}else{MessageBox.Show("没有找到子窗口");}
}
else
{MessageBox.Show("没有找到窗口");
} 

复制代码

 

 

wMsg参数常量值:

复制代码

 //创建一个窗口   
const int WM_CREATE = 0x01;   
//当一个窗口被破坏时发送   
const int WM_DESTROY = 0x02;   
//移动一个窗口   
const int WM_MOVE = 0x03;   
//改变一个窗口的大小   
const int WM_SIZE = 0x05;   
//一个窗口被激活或失去激活状态   
const int WM_ACTIVATE = 0x06;   
//一个窗口获得焦点   
const int WM_SETFOCUS = 0x07;   
//一个窗口失去焦点   
const int WM_KILLFOCUS = 0x08;   
//一个窗口改变成Enable状态   
const int WM_ENABLE = 0x0A;   
//设置窗口是否能重画   
const int WM_SETREDRAW = 0x0B;   
//应用程序发送此消息来设置一个窗口的文本   
const int WM_SETTEXT = 0x0C;   
//应用程序发送此消息来复制对应窗口的文本到缓冲区   
const int WM_GETTEXT = 0x0D;   
//得到与一个窗口有关的文本的长度(不包含空字符)   
const int WM_GETTEXTLENGTH = 0x0E;   
//要求一个窗口重画自己   
const int WM_PAINT = 0x0F;   
//当一个窗口或应用程序要关闭时发送一个信号   
const int WM_CLOSE = 0x10;   
//当用户选择结束对话框或程序自己调用ExitWindows函数   
const int WM_QUERYENDSESSION = 0x11;   
//用来结束程序运行   
const int WM_QUIT = 0x12;   
//当用户窗口恢复以前的大小位置时,把此消息发送给某个图标   
const int WM_QUERYOPEN = 0x13;   
//当窗口背景必须被擦除时(例在窗口改变大小时)   
const int WM_ERASEBKGND = 0x14;   
//当系统颜色改变时,发送此消息给所有顶级窗口   
const int WM_SYSCOLORCHANGE = 0x15;   
//当系统进程发出WM_QUERYENDSESSION消息后,此消息发送给应用程序,通知它对话是否结束   
const int WM_ENDSESSION = 0x16;   
//当隐藏或显示窗口是发送此消息给这个窗口   
const int WM_SHOWWINDOW = 0x18;   
//发此消息给应用程序哪个窗口是激活的,哪个是非激活的   
const int WM_ACTIVATEAPP = 0x1C;   
//当系统的字体资源库变化时发送此消息给所有顶级窗口   
const int WM_FONTCHANGE = 0x1D;   
//当系统的时间变化时发送此消息给所有顶级窗口   
const int WM_TIMECHANGE = 0x1E;   
//发送此消息来取消某种正在进行的摸态(操作)   
const int WM_CANCELMODE = 0x1F;   
//如果鼠标引起光标在某个窗口中移动且鼠标输入没有被捕获时,就发消息给某个窗口   
const int WM_SETCURSOR = 0x20;   
//当光标在某个非激活的窗口中而用户正按着鼠标的某个键发送此消息给//当前窗口   
const int WM_MOUSEACTIVATE = 0x21;   
//发送此消息给MDI子窗口//当用户点击此窗口的标题栏,或//当窗口被激活,移动,改变大小   
const int WM_CHILDACTIVATE = 0x22;   
//此消息由基于计算机的训练程序发送,通过WH_JOURNALPALYBACK的hook程序分离出用户输入消息   
const int WM_QUEUESYNC = 0x23;   
//此消息发送给窗口当它将要改变大小或位置   
const int WM_GETMINMAXINFO = 0x24;   
//发送给最小化窗口当它图标将要被重画   
const int WM_PAINTICON = 0x26;   
//此消息发送给某个最小化窗口,仅//当它在画图标前它的背景必须被重画   
const int WM_ICONERASEBKGND = 0x27;   
//发送此消息给一个对话框程序去更改焦点位置   
const int WM_NEXTDLGCTL = 0x28;   
//每当打印管理列队增加或减少一条作业时发出此消息    
const int WM_SPOOLERSTATUS = 0x2A;   
//当button,combobox,listbox,menu的可视外观改变时发送   
const int WM_DRAWITEM = 0x2B;   
//当button, combo box, list box, list view control, or menu item 被创建时   
const int WM_MEASUREITEM = 0x2C;   
//此消息有一个LBS_WANTKEYBOARDINPUT风格的发出给它的所有者来响应WM_KEYDOWN消息    
const int WM_VKEYTOITEM = 0x2E;   
//此消息由一个LBS_WANTKEYBOARDINPUT风格的列表框发送给他的所有者来响应WM_CHAR消息    
const int WM_CHARTOITEM = 0x2F;   
//当绘制文本时程序发送此消息得到控件要用的颜色   
const int WM_SETFONT = 0x30;   
//应用程序发送此消息得到当前控件绘制文本的字体   
const int WM_GETFONT = 0x31;   
//应用程序发送此消息让一个窗口与一个热键相关连    
const int WM_SETHOTKEY = 0x32;   
//应用程序发送此消息来判断热键与某个窗口是否有关联   
const int WM_GETHOTKEY = 0x33;   
//此消息发送给最小化窗口,当此窗口将要被拖放而它的类中没有定义图标,应用程序能返回一个图标或光标的句柄,当用户拖放图标时系统显示这个图标或光标   
const int WM_QUERYDRAGICON = 0x37;   
//发送此消息来判定combobox或listbox新增加的项的相对位置   
const int WM_COMPAREITEM = 0x39;   
//显示内存已经很少了   
const int WM_COMPACTING = 0x41;   
//发送此消息给那个窗口的大小和位置将要被改变时,来调用setwindowpos函数或其它窗口管理函数   
const int WM_WINDOWPOSCHANGING = 0x46;   
//发送此消息给那个窗口的大小和位置已经被改变时,来调用setwindowpos函数或其它窗口管理函数   
const int WM_WINDOWPOSCHANGED = 0x47;   
//当系统将要进入暂停状态时发送此消息   
const int WM_POWER = 0x48;   
//当一个应用程序传递数据给另一个应用程序时发送此消息   
const int WM_COPYDATA = 0x4A;   
//当某个用户取消程序日志激活状态,提交此消息给程序   
const int WM_CANCELJOURNA = 0x4B;   
//当某个控件的某个事件已经发生或这个控件需要得到一些信息时,发送此消息给它的父窗口    
const int WM_NOTIFY = 0x4E;   
//当用户选择某种输入语言,或输入语言的热键改变   
const int WM_INPUTLANGCHANGEREQUEST = 0x50;   
//当平台现场已经被改变后发送此消息给受影响的最顶级窗口   
const int WM_INPUTLANGCHANGE = 0x51;   
//当程序已经初始化windows帮助例程时发送此消息给应用程序   
const int WM_TCARD = 0x52;   
//此消息显示用户按下了F1,如果某个菜单是激活的,就发送此消息个此窗口关联的菜单,否则就发送给有焦点的窗口,如果//当前都没有焦点,就把此消息发送给//当前激活的窗口   
const int WM_HELP = 0x53;   
//当用户已经登入或退出后发送此消息给所有的窗口,//当用户登入或退出时系统更新用户的具体设置信息,在用户更新设置时系统马上发送此消息   
const int WM_USERCHANGED = 0x54;   
//公用控件,自定义控件和他们的父窗口通过此消息来判断控件是使用ANSI还是UNICODE结构   
const int WM_NOTIFYFORMAT = 0x55;   
//当用户某个窗口中点击了一下右键就发送此消息给这个窗口   
//const int WM_CONTEXTMENU = ??;   
//当调用SETWINDOWLONG函数将要改变一个或多个 窗口的风格时发送此消息给那个窗口   
const int WM_STYLECHANGING = 0x7C;   
//当调用SETWINDOWLONG函数一个或多个 窗口的风格后发送此消息给那个窗口   
const int WM_STYLECHANGED = 0x7D;   
//当显示器的分辨率改变后发送此消息给所有的窗口   
const int WM_DISPLAYCHANGE = 0x7E;   
//此消息发送给某个窗口来返回与某个窗口有关连的大图标或小图标的句柄   
const int WM_GETICON = 0x7F;   
//程序发送此消息让一个新的大图标或小图标与某个窗口关联   
const int WM_SETICON = 0x80;   
//当某个窗口第一次被创建时,此消息在WM_CREATE消息发送前发送   
const int WM_NCCREATE = 0x81;   
//此消息通知某个窗口,非客户区正在销毁    
const int WM_NCDESTROY = 0x82;   
//当某个窗口的客户区域必须被核算时发送此消息   
const int WM_NCCALCSIZE = 0x83;   
//移动鼠标,按住或释放鼠标时发生   
const int WM_NCHITTEST = 0x84;   
//程序发送此消息给某个窗口当它(窗口)的框架必须被绘制时   
const int WM_NCPAINT = 0x85;   
//此消息发送给某个窗口仅当它的非客户区需要被改变来显示是激活还是非激活状态   
const int WM_NCACTIVATE = 0x86;   
//发送此消息给某个与对话框程序关联的控件,widdows控制方位键和TAB键使输入进入此控件通过应   
const int WM_GETDLGCODE = 0x87;   
//当光标在一个窗口的非客户区内移动时发送此消息给这个窗口 非客户区为:窗体的标题栏及窗 的边框体   
const int WM_NCMOUSEMOVE = 0xA0;   
//当光标在一个窗口的非客户区同时按下鼠标左键时提交此消息   
const int WM_NCLBUTTONDOWN = 0xA1;   
//当用户释放鼠标左键同时光标某个窗口在非客户区十发送此消息    
const int WM_NCLBUTTONUP = 0xA2;   
//当用户双击鼠标左键同时光标某个窗口在非客户区十发送此消息   
const int WM_NCLBUTTONDBLCLK = 0xA3;   
//当用户按下鼠标右键同时光标又在窗口的非客户区时发送此消息   
const int WM_NCRBUTTONDOWN = 0xA4;   
//当用户释放鼠标右键同时光标又在窗口的非客户区时发送此消息   
const int WM_NCRBUTTONUP = 0xA5;   
//当用户双击鼠标右键同时光标某个窗口在非客户区十发送此消息   
const int WM_NCRBUTTONDBLCLK = 0xA6;   
//当用户按下鼠标中键同时光标又在窗口的非客户区时发送此消息   
const int WM_NCMBUTTONDOWN = 0xA7;   
//当用户释放鼠标中键同时光标又在窗口的非客户区时发送此消息   
const int WM_NCMBUTTONUP = 0xA8;   
//当用户双击鼠标中键同时光标又在窗口的非客户区时发送此消息   
const int WM_NCMBUTTONDBLCLK = 0xA9;   
//WM_KEYDOWN 按下一个键   
const int WM_KEYDOWN = 0x0100;   
//释放一个键   
const int WM_KEYUP = 0x0101;   
//按下某键,并已发出WM_KEYDOWN, WM_KEYUP消息   
const int WM_CHAR = 0x102;   
//当用translatemessage函数翻译WM_KEYUP消息时发送此消息给拥有焦点的窗口   
const int WM_DEADCHAR = 0x103;   
//当用户按住ALT键同时按下其它键时提交此消息给拥有焦点的窗口   
const int WM_SYSKEYDOWN = 0x104;   
//当用户释放一个键同时ALT 键还按着时提交此消息给拥有焦点的窗口   
const int WM_SYSKEYUP = 0x105;   
//当WM_SYSKEYDOWN消息被TRANSLATEMESSAGE函数翻译后提交此消息给拥有焦点的窗口   
const int WM_SYSCHAR = 0x106;   
//当WM_SYSKEYDOWN消息被TRANSLATEMESSAGE函数翻译后发送此消息给拥有焦点的窗口   
const int WM_SYSDEADCHAR = 0x107;   
//在一个对话框程序被显示前发送此消息给它,通常用此消息初始化控件和执行其它任务   
const int WM_INITDIALOG = 0x110;   
//当用户选择一条菜单命令项或当某个控件发送一条消息给它的父窗口,一个快捷键被翻译   
const int WM_COMMAND = 0x111;   
//当用户选择窗口菜单的一条命令或//当用户选择最大化或最小化时那个窗口会收到此消息   
const int WM_SYSCOMMAND = 0x112;   
//发生了定时器事件   
const int WM_TIMER = 0x113;   
//当一个窗口标准水平滚动条产生一个滚动事件时发送此消息给那个窗口,也发送给拥有它的控件   
const int WM_HSCROLL = 0x114;   
//当一个窗口标准垂直滚动条产生一个滚动事件时发送此消息给那个窗口也,发送给拥有它的控件   
const int WM_VSCROLL = 0x115;   
//当一个菜单将要被激活时发送此消息,它发生在用户菜单条中的某项或按下某个菜单键,它允许程序在显示前更改菜单   
const int WM_INITMENU = 0x116;   
//当一个下拉菜单或子菜单将要被激活时发送此消息,它允许程序在它显示前更改菜单,而不要改变全部   
const int WM_INITMENUPOPUP = 0x117;   
//当用户选择一条菜单项时发送此消息给菜单的所有者(一般是窗口)   
const int WM_MENUSELECT = 0x11F;   
//当菜单已被激活用户按下了某个键(不同于加速键),发送此消息给菜单的所有者   
const int WM_MENUCHAR = 0x120;   
//当一个模态对话框或菜单进入空载状态时发送此消息给它的所有者,一个模态对话框或菜单进入空载状态就是在处理完一条或几条先前的消息后没有消息它的列队中等待   
const int WM_ENTERIDLE = 0x121;   
//在windows绘制消息框前发送此消息给消息框的所有者窗口,通过响应这条消息,所有者窗口可以通过使用给定的相关显示设备的句柄来设置消息框的文本和背景颜色   
const int WM_CTLCOLORMSGBOX = 0x132;   
//当一个编辑型控件将要被绘制时发送此消息给它的父窗口通过响应这条消息,所有者窗口可以通过使用给定的相关显示设备的句柄来设置编辑框的文本和背景颜色   
const int WM_CTLCOLOREDIT = 0x133;   //当一个列表框控件将要被绘制前发送此消息给它的父窗口通过响应这条消息,所有者窗口可以通过使用给定的相关显示设备的句柄来设置列表框的文本和背景颜色   
const int WM_CTLCOLORLISTBOX = 0x134;   
//当一个按钮控件将要被绘制时发送此消息给它的父窗口通过响应这条消息,所有者窗口可以通过使用给定的相关显示设备的句柄来设置按纽的文本和背景颜色   
const int WM_CTLCOLORBTN = 0x135;   
//当一个对话框控件将要被绘制前发送此消息给它的父窗口通过响应这条消息,所有者窗口可以通过使用给定的相关显示设备的句柄来设置对话框的文本背景颜色   
const int WM_CTLCOLORDLG = 0x136;   
//当一个滚动条控件将要被绘制时发送此消息给它的父窗口通过响应这条消息,所有者窗口可以通过使用给定的相关显示设备的句柄来设置滚动条的背景颜色   
const int WM_CTLCOLORSCROLLBAR = 0x137;   
//当一个静态控件将要被绘制时发送此消息给它的父窗口通过响应这条消息,所有者窗口可以 通过使用给定的相关显示设备的句柄来设置静态控件的文本和背景颜色   
const int WM_CTLCOLORSTATIC = 0x138;   
//当鼠标轮子转动时发送此消息个当前有焦点的控件   
const int WM_MOUSEWHEEL = 0x20A;   
//双击鼠标中键   
const int WM_MBUTTONDBLCLK = 0x209;   
//释放鼠标中键   
const int WM_MBUTTONUP = 0x208;   
//移动鼠标时发生,同WM_MOUSEFIRST   
const int WM_MOUSEMOVE = 0x200;   
//按下鼠标左键   
const int WM_LBUTTONDOWN = 0x201;   
//释放鼠标左键   
const int WM_LBUTTONUP = 0x202;   
//双击鼠标左键   
const int WM_LBUTTONDBLCLK = 0x203;   
//按下鼠标右键   
const int WM_RBUTTONDOWN = 0x204;   
//释放鼠标右键   
const int WM_RBUTTONUP = 0x205;   
//双击鼠标右键   
const int WM_RBUTTONDBLCLK = 0x206;   
//按下鼠标中键   
const int WM_MBUTTONDOWN = 0x207;   const int WM_USER = 0x0400;   
const int MK_LBUTTON = 0x0001;   
const int MK_RBUTTON = 0x0002;   
const int MK_SHIFT = 0x0004;   
const int MK_CONTROL = 0x0008;   
const int MK_MBUTTON = 0x0010;   
const int MK_XBUTTON1 = 0x0020;   
const int MK_XBUTTON2 = 0x0040;

复制代码

这篇关于C# SendMessage用法(调用windows API)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1052262

相关文章

2. c#从不同cs的文件调用函数

1.文件目录如下: 2. Program.cs文件的主函数如下 using System;using System.Collections.Generic;using System.Linq;using System.Threading.Tasks;using System.Windows.Forms;namespace datasAnalysis{internal static

如何在页面调用utility bar并传递参数至lwc组件

1.在app的utility item中添加lwc组件: 2.调用utility bar api的方式有两种: 方法一,通过lwc调用: import {LightningElement,api ,wire } from 'lwc';import { publish, MessageContext } from 'lightning/messageService';import Ca

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

用命令行的方式启动.netcore webapi

用命令行的方式启动.netcore web项目 进入指定的项目文件夹,比如我发布后的代码放在下面文件夹中 在此地址栏中输入“cmd”,打开命令提示符,进入到发布代码目录 命令行启动.netcore项目的命令为:  dotnet 项目启动文件.dll --urls="http://*:对外端口" --ip="本机ip" --port=项目内部端口 例: dotnet Imagine.M

bytes.split的用法和注意事项

当然,我很乐意详细介绍 bytes.Split 的用法和注意事项。这个函数是 Go 标准库中 bytes 包的一个重要组成部分,用于分割字节切片。 基本用法 bytes.Split 的函数签名如下: func Split(s, sep []byte) [][]byte s 是要分割的字节切片sep 是用作分隔符的字节切片返回值是一个二维字节切片,包含分割后的结果 基本使用示例: pa

在 Windows 上部署 gitblit

在 Windows 上部署 gitblit 在 Windows 上部署 gitblit 缘起gitblit 是什么安装JDK部署 gitblit 下载 gitblit 并解压配置登录注册为 windows 服务 修改 installService.cmd 文件运行 installService.cmd运行 gitblitw.exe查看 services.msc 缘起

Windows如何添加右键新建菜单

Windows如何添加右键新建菜单 文章目录 Windows如何添加右键新建菜单实验环境缘起以新建`.md`文件为例第一步第二步第三步 总结 实验环境 Windows7 缘起 因为我习惯用 Markdown 格式写文本,每次新建一个.txt后都要手动修改为.md,真的麻烦。如何在右键新建菜单中添加.md选项呢? 网上有很多方法,这些方法我都尝试了,要么太麻烦,要么不凑效

【LabVIEW学习篇 - 21】:DLL与API的调用

文章目录 DLL与API调用DLLAPIDLL的调用 DLL与API调用 LabVIEW虽然已经足够强大,但不同的语言在不同领域都有着自己的优势,为了强强联合,LabVIEW提供了强大的外部程序接口能力,包括DLL、CIN(C语言接口)、ActiveX、.NET、MATLAB等等。通过DLL可以使用户很方便地调用C、C++、C#、VB等编程语言写的程序以及windows自带的大

Windows下Nginx的安装及开机启动

1、将nginx-1.16.1.zip解压拷贝至D:\web\nginx目录下。 2、启动Nginx,两种方法: (1)直接双击nginx.exe,双击后一个黑色的弹窗一闪而过。 (2)打开cmd命令窗口,切换到nginx目录下,输入命令 nginx.exe 或者 start nginx ,回车即可。 3、检查nginx是否启动成功。 直接在浏览器地址栏输入网址 http://lo

如何更优雅地对接第三方API

如何更优雅地对接第三方API 本文所有示例完整代码地址:https://github.com/yu-linfeng/BlogRepositories/tree/master/repositories/third 我们在日常开发过程中,有不少场景会对接第三方的API,例如第三方账号登录,第三方服务等等。第三方服务会提供API或者SDK,我依稀记得早些年Maven还没那么广泛使用,通常要对接第三方