使用WinHex搜索一个进程中的文本图解

当前打开有记事本;使用winhex来看一下内存搜索;能不能搜到记事本中的文本;

如下图,选择 Tools - Open Memory... 菜单;

列出进程;

提示只有64位版本才能显示模块或进程名;当前是按进程ID显示;

使用power shell查看一下记事本进程的ID;当前打开2个记事本,ID如下图;2488,7700;

powershell由进程名查看进程ID的方法:

利用管道 赋值给$id

$id  = Get-Process -name explorer* | Select-Object id | ForEach-Object -Process{$_.id}

$id

 

第一个记事本是2488,展开菜单,有三个内存查看选项;

双击 Primary memory;提示:只有注册版才能编辑内存,当前只能查看;

进入到2488号进程的主内存;Offset列是地址,然后是内存内容,然后是内存各种属性,如分配的尺寸、基址等;

第一个记事本包含一些文本,其中有"电话沟通了一下";

在查找对话框输入此段文本,然后搜索;

找不到;

再点击菜单 Find Hex Value,弹出如下对话框;

输入文本,点击 OK 搜索;弹出如下提示;

搜索十六进制值必须输入十六进制,要先转换为十六进制输入才行;

再搜索文本,把下拉选项改为Unicode,前面是ASCII;

再搜;还是搜不到;

根据相关资料有:

    缓冲区是UNICODE的。

    Winhex提供了搜索十六进制数值和文本字符的功能,在搜索文件字符时需要注意的是,要设置搜索的目标是ASCII字符还是Unicode字符;另外需要注意的是,Winhex对中文字符支持尚有不足,使用Winhex搜索汉字时很多时候无法找到并定位。

 

然后在第一个记事本输入一串英文:testbybo;

然后搜索这段文本;

这就找到了;如下图;地址 00398380 这一行;

查一下 电话沟通 这几个汉字的Unicode编码;如下:
    \u7535\u8bdd\u6c9f\u901a

输入这些Unicode编码,再搜;还是搜不到;

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值