首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

64位WinAPI STARTUPINFO (QB64)的字节打包

64位WinAPI STARTUPINFO (QB64)是一个用于在64位Windows操作系统上创建和配置新进程的结构体。它包含了启动一个新进程所需的各种信息,例如要执行的可执行文件、命令行参数、进程的窗口和I/O的配置等。

STARTUPINFO结构体的字节打包表示指的是将其按字节进行编组以进行传输或存储。在QB64中,字节打包可以通过使用TYPE语句和相关字段来实现。以下是一个示例代码:

代码语言:txt
复制
TYPE STARTUPINFO_PACKED
    cb AS _UNSIGNED LONG ' 结构体大小
    lpReserved AS _STRING * 128 ' 保留字段
    lpDesktop AS _STRING * 128 ' 指定用于新进程的窗口站和桌面
    lpTitle AS _STRING * 128 ' 指定窗口标题
    dwX AS _UNSIGNED LONG ' 窗口的初始水平位置
    dwY AS _UNSIGNED LONG ' 窗口的初始垂直位置
    dwXSize AS _UNSIGNED LONG ' 窗口的宽度
    dwYSize AS _UNSIGNED LONG ' 窗口的高度
    dwXCountChars AS _UNSIGNED LONG ' 控制台屏幕缓冲区的宽度(以字符为单位)
    dwYCountChars AS _UNSIGNED LONG ' 控制台屏幕缓冲区的高度(以字符为单位)
    dwFillAttribute AS _UNSIGNED LONG ' 控制台屏幕缓冲区字符的初始属性
    dwFlags AS _UNSIGNED LONG ' 进程的创建标志
    wShowWindow AS _UNSIGNED LONG ' 指定进程主窗口的初始显示状态
    cbReserved2 AS _UNSIGNED LONG ' 保留字段
    lpReserved2 AS _BYTE PTR ' 保留字段
    hStdInput AS _UNSIGNED LONG_PTR ' 标准输入设备的句柄
    hStdOutput AS _UNSIGNED LONG_PTR ' 标准输出设备的句柄
    hStdError AS _UNSIGNED LONG_PTR ' 标准错误设备的句柄
END TYPE

DIM si AS STARTUPINFO_PACKED
DIM lpApplicationName AS _STRING * 256 ' 可执行文件路径
DIM lpCommandLine AS _STRING * 1024 ' 命令行参数

' 初始化STARTUPINFO结构体
si.cb = SIZEOF(si)
lpApplicationName = "C:\path\to\executable.exe"
lpCommandLine = "command line arguments"

' 调用WinAPI函数创建新进程
CreateProcess(lpApplicationName, lpCommandLine, ..., si, ...)

该代码片段展示了如何使用QB64中的字节打包技术来创建一个STARTUPINFO结构体,并使用CreateProcess函数启动一个新进程。

64位WinAPI STARTUPINFO结构体的字段包含了许多用于配置新进程的信息。例如,lpDesktop字段可以指定新进程的窗口站和桌面,dwX和dwY字段可以设置新进程窗口的初始位置,dwXSize和dwYSize字段可以设置新进程窗口的大小等。通过设置这些字段,可以根据应用程序的需求来配置新进程。

STARTUPINFO结构体在64位Windows操作系统中非常常见,并被广泛应用于各种场景,包括创建GUI应用程序、命令行工具等。腾讯云提供了各种云计算产品来支持开发人员在云上部署和运行应用程序,例如腾讯云服务器(https://cloud.tencent.com/product/cvm)和腾讯云容器服务(https://cloud.tencent.com/product/tke),这些产品可以帮助开发人员轻松地在云上创建和管理自己的应用程序。

希望这个答案能帮助到你!

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

DotNet4应用程序打包工具->升级版【三】宿主程序分析+全部源码下载

索引 DotNet4应用程序打包工具->升级版【三】宿主程序分析+全部源码下载 DotNet4应用程序打包工具->升级版【二】安装工具分析 DotNet4应用程序打包工具(把DotNet4安装程序打包进你应用程序...;WINAPI开发,无dotNet环境也可顺利执行)【一】整体思路 废话少说 入口函数 入口函数是所有逻辑集合体 int WinMain(HINSTANCE hInstance,HINSTANCE hPreInstance...if(dwResSize == dwWritten); { return 1; } return 0; } 成功释放之后 就执行这个程序 注意WaitForSingleObjectWINAPI...是等待进程退出 //创建进程 int CreateInstallProcess(LPCTSTR resourceName) { STARTUPINFO stinfo; ZeroMemory((void...*)&stinfo,sizeof(STARTUPINFO)); PROCESS_INFORMATION ProcessInfo; stinfo.cb = sizeof(STARTUPINFO);

36910
  • CreateProcess 创建带命令行参数进程时,报错或者提示内存位置无效可能一个原因

    另外,假如你使用常量ANSI字符串作为 CreateProcess参数,并不会发生Access Violation错误,我们在前面的章节已经提到过,许多WinAPI函数ANSI版本会将ANSI参数转换为...你如果想要一个动态长度命令行参数,可以参考下面的代码 STARTUPINFO si = { sizeof(si) }; PROCESS_INFORMATION pi; LPTSTR pszCmd...通过查询一篇文章发现:STARTUPINFO si = { sizeof(si) };很关键。 当你直接写STARTUPINFO si;此时si里面一些内容可能是随机。...如果你没有清空其内容,STARTUPINFO(EX)内容会是调用线程堆栈上一些数据。...将这些垃圾数据传递给CreateProcess可能导致无法预料结果,为了让CreateProcess正常工作,你必须将STARTUPINFO(EX)中没有用到域清0。

    2.3K50

    红队免杀必会:R3下常用HOOK技术

    解除HOOK的话就是将替换字节恢复。 Inline Hook流程 构造跳转指令。 在内存中找到欲Hook函数地址,并保存欲Hook位置处前5字节。...将构造跳转指令写入需Hook位置处。 当被Hook位置被执行时会转到自己流程执行。 如果要执行原来流程,那么取消Hook,也就是还原被修改字节。 执行原来流程。...,我们需要构造与被 HOOK 函数一样结构函数,同时为了保证原函数功能正常运行,再定义一个函数指针,在自己功能执行完成后,调用原来程序正常功能: typedef int (WINAPI*...在多态里有类特殊是虚函数(以virtual修饰), 32位系统下,对象里有4个字节保存虚表数组,其值为每一项虚函数地址。...这就给了我们一种新Hook思路,即将前两个字节改为短跳转指令(EB E9),使其跳到函数上边五字节处,这五个字节int3中断实际上就是一段空闲空间: 然后再将这五个字节改为长跳转指令(E9 xxxxxxxx

    2.1K10

    Windows Kernel Exploitation Notes(二)——HEVD Write-What-Where

    2704个字 17张图 预计阅读时间15分钟2.本文作者erfze 属于Gcow安全团队复眼小组 未经过许可禁止转载3.本篇文章是Windows Kernel Exploitation Notes系列文章第二篇...HEVD Write-What-Where4.本篇文章十分适合漏洞安全研究人员进行交流学习5.若文章中存在说得不清楚或者错误地方 欢迎师傅到公众号后台留言中指出 感激不尽 环境配置及基础知识见上一篇,...HalDispatchTable中HalQuerySystemInformation与HalSetSystemInformation是在内核初始化过程中确定: ?...; ZeroMemory(&StartupInfo, sizeof(StartupInfo)); CreateProcessA("C:\\Windows\\System32\\cmd.exe...; ZeroMemory(&StartupInfo, sizeof(StartupInfo)); CreateProcessA("C:\\Windows\\System32\\cmd.exe

    54330

    字节码插桩】Android 打包流程 | Android 中字节码操作方式 | AOP 面向切面编程 | APT 编译时技术

    文章目录 一、Android 中 Java 源码打包流程 1、Java 源码打包流程 2、字符串常量池 二、Android 中字节码操作方式 一、Android 中 Java 源码打包流程 --...中 Java 源码打包流程 : 参考 【Android 安装包优化】APK 打包流程 ( 文件结构 | 打包流程 | 安装流程 | 安卓虚拟机 ) 博客 ; ① 编译资源 R.java 源码 : 使用...Java 文件 ; ③ 编译 Java 源码 : 使用 javac 工具编译 Java 源码为 class 字节码文件 ; ④ 打包 Class 字节码 : 使用 dx 工具将 class 字节码文件打包成..., 确定有哪些字符 ; 二、Android 中字节码操作方式 ---- 操作字节 2 种方式 : AOP : Aspect Oriented Programming , 面向切面编程 ; APT....class 字节码文件打包为 .dex 文件过程中 ; APT 插桩时机是 .java 文件编译成 .class 字节码文件时 , 进行 , 编译时进行字节码插桩 ; ButterKnife ,

    1.2K10

    一个windows端服务拷贝文件到共享文件夹方法记录

    一个需求,需要实现拷贝一个本地文件到共享文件夹功能,思路是先开启网络共享文件夹访问,然后执行拷贝命令; 开启网络共享文件夹免密码访问,需要在cmd.exe命令窗口,使用net use命令,如: net.../8cDXf),system调用确实可以实现这个功能,但是会出现一个很讨厌黑色弹框,所以使用CreateProcess方法; 执行cmd.exe命令不弹出对话框方法: static void TcharToChar...(const TCHAR* tchar, char* _char) {   int iLength;   //获取字节长度     iLength = WideCharToMultiByte(CP_ACP..., tchar, iLength); } static void windows_system(const char* cmd) {   PROCESS_INFORMATION p_info;   STARTUPINFO...: DWORD WINAPI UploadThreadFunc(LPVOID p) {   char* file_path = (char*)p;   char temp_str[255] = "";

    80520
    领券