吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 1231|回复: 7
收起左侧

[求助] Delphi怎么判断拖过来的程序是32位的 还是64位的?【不能让其运行!】

[复制链接]
冥界3大法王 发表于 2022-2-14 17:35
本帖最后由 冥界3大法王 于 2022-2-14 17:40 编辑

[Delphi] 纯文本查看 复制代码
5


运行后 看任务管理器有没有 (32位)
@贱男春 不能运行
拖过来之后得到了全路径
然后再带着参数自动化的运行32位 或  64位的IDA

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

ytfrdfiw 发表于 2022-2-14 17:55
膜拜一下delphi大神
 楼主| 冥界3大法王 发表于 2022-2-14 18:04
Pierce 发表于 2022-2-14 18:40
读PE头。_IMAGE_FILE_HEADER 结构里Machine可以判断到
揰掵佲 发表于 2022-2-14 20:05
有个比较简单的方法  (32位,我用易语言的)用 LoadLibraryA/W  能加载句柄的是32位  加载返回0的 是64位

免费评分

参与人数 2吾爱币 +3 热心值 +1 收起 理由
冥界3大法王 + 2 + 1 良心大大地,解决了,表示感谢!!!
liyitong + 1 欢迎分析讨论交流,吾爱破解论坛有你更精彩!

查看全部评分

xiaomm250 发表于 2022-2-15 08:54
用x64dbg打开程序,如果没提示,那就64位,如果有提示(提示你用x32dbg),那就是32位程序
 楼主| 冥界3大法王 发表于 2022-2-15 09:13
本帖最后由 冥界3大法王 于 2022-2-15 09:15 编辑
揰掵佲 发表于 2022-2-14 20:05
有个比较简单的方法  (32位,我用易语言的)用 LoadLibraryA/W  能加载句柄的是32位  加载返回0的 是64位

[Delphi] 纯文本查看 复制代码
unit Unit3;

interface

uses
  Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants,
  System.Classes, Vcl.Graphics, Vcl.Controls, Vcl.Forms, Vcl.Dialogs,
  Vcl.StdCtrls;

type
  TForm3 = class(TForm)
    Button1: TButton;
    procedure Button1Click(Sender: TObject);
  private    { Private declarations }
  public    { Public declarations }
  end;

var
  Form3: TForm3;

implementation

{$R *.dfm}

procedure TForm3.Button1Click(Sender: TObject);
var
  H: THandle;
begin
  H := LoadLibrary('X:\ConceptDraw.exe');
  if H <> 0 then
  begin
    ShowMessage('我是32位程序!');
  end
  else
  begin
    ShowMessage('我是64位程序!');
  end;
end;

end.
amonsonic 发表于 2022-4-2 12:45
用LoadLibary 会运行病毒代码, 比如activex启动的和很多钩子dll会在dll入口函数上写自动运行代码

正确的判断方式是:
ImageNtHeaders.OptionalHeader.Magic = IMAGE_NT_OPTIONAL_HDR64_MAGIC
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-11-25 13:13

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表