当前位置: 首页 > news >正文

北京网站建设飞沐快速排名优化seo

北京网站建设飞沐,快速排名优化seo,网络推广培训哪里的,网站后期推广是谁来做调试符号windbg使用一个或多个目录来存放符号条件,并使用环境变量_NT_SYMBOL_PATH来指向这些环境变量的位置,对操作系统内部模块的符号文件,一般用http://msdl.microsoft.com/download/symbols配置如下:SRV*C:\Symbols*http://msd…

调试符号

windbg使用一个或多个目录来存放符号条件,并使用环境变量_NT_SYMBOL_PATH来指向这些环境变量的位置,

对操作系统内部模块的符号文件,一般用http://msdl.microsoft.com/download/symbols

配置如下:

SRV*C:\Symbols*http://msdl.microsoft.com/download/symbols

ld命令:从符号文件目录或者符号服务器中加载符号

lm命令:观察符号模块的文件情况 或者单机“Debug" -> "Modules"选项

符号的表示:

表示方法为”模块名称!符号名称“,操作系统内核的表示为 "nt!符号名称"

符号查找功能:模块名可以使用模糊搜索

X   [Options]   Modules!Symbol

有符号文件的情况下,windbg可以调试源码,Ctrl+P键,在窗口中指定源文件的代码路径,多个路径使用分号相隔

调试过程 (应用层实时调试)

开始调试时,默认停留在ntdll中的系统断点处,不会直接停留再程序的入口处,可以在命令窗口输入 ":g@$exentry"转到程序入口处

单步相关指令:

命令

快捷键

功能

t

F8 或 F11

追踪执行,遇到call指令进去

p

F10

单步执行,遇到call指令不跳进去

g

F5

运行程序

pa 地址

单步到指定地址,不进入call指令

ta地址

追踪到指定地址,进入call指令

pc [count]

单步执行到下一个call指令调用,count参数用于指定call指令的个数

tc [count]

追踪执行到下一个call指令,遇到call指令跳进去

tb [count]

追踪执行到吓一跳分支指令,遇到call指令时跳进去,只用于内核调试

pt

单步执行到下一条call返回指令

tt

追踪执行下一条call返回指令,遇到call指令时跳进去

ph

单步执行到下一条分支指令

th

追踪执行到下一条分支指令,遇到call指令时跳进去

wt

自动追踪函数执行过程

断点指令

1、软件断点:bp、bu、bm

bp是最常用的,其格式如下

bp [ID] [Options] [Address [Passes]] ["CommandString"]
  • ID:指定断点ID,可不指定,内核调试限制32个断点,用户模式不限制

  • Options:可不指定:

  • /I:中断后自动删除该断点,即一次性断点

  • /c:指定最大调用深度,大于这个深度则断点不工作

  • /C:指定最小调用深度

  • Adress:地址或者符号,例如MesssageBoxW

  • Passes:忽略中断的次数,可不指定

  • CommondString:当中断时执行指令,用双引号包裹起来,多个指令用分号分隔

bu命令对某个符号下断点,例如"bu kernel32!GetVersion",bu命令设置的断点是和符号关联的,如果符号的地址变了,断点会保持与原符号的关联

bm命令设置通配符的断点,可以一次创建多个断点,例如对模块中所有 print函数开头的函数设置断点:"bm msvcr80!print*"

2、硬件断点

硬件断点可以实现例如IO访问的的断点,格式如下:

ba [ID] Access Size [Options] [Address] [Passess] ["CommandString"]

  • Access:指定出发断点的访问防止

  • e:在读取或执行指令时出发断点

  • r:在读取数据时出发断点

  • w:在写入数据时触发断点

  • i:在执行IO时触发断点

  • Size:访问的长度。在x86系统中其值可以为1、2、4,代表一字节、字、双字,x64系统中多了一个8,代表四字节访问。

3、条件断点

软件断点和硬件断点都支持条件断点,这两条命令是等价的。

bp | bu | ba _Address "j (Condition) 'OptionalCommands';  'gc' "
bp | bu | ba _Address ".if (Condition) 'OptionalCommands';  .else 'gc' "

例如 , 当GetVersion被调用是检测eax寄存器,如果其值等于0x12ffc4就中断,否则使用指令gc继续。

bp kernel32!GetVersion ".if(@eax=0x12ffc4){} .else{gc}"

在内核态下,eax高位会补齐,会变为0xffffffffc012ffc4,这时可以用&操作对高位清零

bp kernel32!GetVersion  ".if(@eax & 0x0`ffffffff)=0xc012ffc4{} .else{gc}"

在不中断进程的情况下,打印所有的CreateFileA函数调用,代码如下

bp kernel32!CreateFileA  ".echo; .printf\"CreateFileA(%ma,%p,%p), ret=\",poi(esp+4),dwo(esp+8),dwo(esp+c);gu.printf\"%N\",eax;.echo;g"

poi的作用是取这个地址上的值,dwo用于从(esp+8)地址中取8个字节。

4、管理断点

bl命令可以列出当前的断点,bc命令、bd命令和be命令分别用于删除、禁用、启用断点,断点号可以用*通配符匹配。例如:

bd 1-3,4 //禁止1、2、3、4号断点
bc *     //删除所有断点

栈窗口

call指令会将函数的返回地址记录在栈中,所以可通过遍历栈帧来追溯函数的调用过程。使用k[b|p|P|v|d] 命令可以查看栈回溯(显示的是一定数量的栈帧),第二个字母大小写敏感。

00行描述的是当前中断所在的函数(call),

01行描述的是调用00行中函数的上一级函数。

第一列是栈帧的基地址,因为x86系统用EBP寄存器来记录栈帧的基地址,x64用

第二列是函数的返回地址,这个地址是调用本行函数的那条call指令的下一条指令的地址

第三列是函数名及执行位置

kb命令只用于显示放在栈上的前三个参数,前两列与最后一列的内容跟上面一样。中间三列是子函数的参数,不管函数的参数是多少,这里只显示三个。

  • kb命令可以携带参数,例如”kb 2“,即显示上面两层调用堆栈。

  • kp名可以把参数和参数值以函数原型的形式显示出来,包括参数类型、名字、取值(必须有符号)

  • kv命令可以在kb命令的基础上增加帧指针省略信息和调用约定的显示

  • kd命令用于列出栈中的数据

内存命令

1、查看内存

d命令用于显示指定地址的内存数据,格式如下

d[类型]  [地址范围]

d命令有d、da、db、dc、dd、dD、df、dp、dq、du、dw、dW、dyb、dyd、ds、dS等。

  1. dw表示双字节形式

  1. dd表示4字节形式

  1. dq表示8字节形式

  1. df表示4字节单精度浮点数格式

  1. dD表示8字节双精度浮点数格式

  1. dp表示指针大小格式,在32位系统下为4字节,在64位系统下为8字节。

地址范围可以L(l)参数设置,例如 "dd 401000 L4" 表示显示前四个数据

  1. da表示ASCII字符串,

  1. db表示字节和ASCII字符串,

  1. dc表示DWORD和ASCII字符串

  1. du表示Unicode字符串

  1. dW表示双字节WORD和ASCII字符串

  1. ds用于显示ANSI_STRING类型的字符串格式

  1. dS用于显示UNICODE_STRING类型字符串格式

  1. dyp表示显示二进制和字节

  1. dyd表示显示二进制和DWORD值

  1. dt [模块名!类型名] 用于显示数据类型和数据结构,例如使用“dt ntdll!*”可以列出ntdll中所有的结构

  1. dds、dps、dqs用于显示地址及相关符号

2、搜索内存

s命令用于搜索内存:

s -[type]  range  pattern
  • type 表示搜索内容的数据类型。b表示 BYTE, w表示WORD,d表示DWORD,a表示ASCII,u表示Unicode。默认类型为b

  • range表示地址范围,可以用两种方式表示,一是起始地址,二是起始地址加长度L。如果搜索长度超过256MB,则用 “L?length”

  • pattern 用于指定要搜索的地址内容,可以用空格分隔要搜索的数值。

例如,要在 400000h和403000h之间搜索Unicode字符串"pediy":

s -u 400000 403000 "pediy"

在目标空间为2GB的user mode内存空间中搜索ASCII字符串 "mytest"

s -u 0x00000000 L?0x7fffffff mytets

3、修改内存

e命令用于修改指定的内存数据,他有两种格式

按字符串方式编辑指定地址的内容,格式如下:

e{a|u|za|zu}  adress "String"

其中,“za”和"zu" 表示以零结尾的ASCII和Unicode字符串,

z和u则表示不以零结尾

按数值方式编辑,格式如下:

e{a|b|d|D|f|q|u|w}  adress  [values]

a表示ASCII码,b表示BYTE,d表示DWORD,D表示double,f表示float,q表示8字节,u表示Unicode,w表示WORD,例如 "eb 287897 70 65 64 69 79"表示写入 "pediy"

执行完e命令,在以d命令查看修改结果

4、观察内存属性

!address 用于显示指定地址的内存属性

!address [Adresss]


文章转载自:
http://pehlevi.zydr.cn
http://utilise.zydr.cn
http://instil.zydr.cn
http://khnorian.zydr.cn
http://supermolecule.zydr.cn
http://glycoside.zydr.cn
http://imput.zydr.cn
http://autolatry.zydr.cn
http://rabic.zydr.cn
http://gila.zydr.cn
http://rashida.zydr.cn
http://periodization.zydr.cn
http://remanent.zydr.cn
http://lsv.zydr.cn
http://antistreptococcal.zydr.cn
http://regulator.zydr.cn
http://lunation.zydr.cn
http://spermogonium.zydr.cn
http://oecumenical.zydr.cn
http://cooperator.zydr.cn
http://managing.zydr.cn
http://meagrely.zydr.cn
http://mungo.zydr.cn
http://religioso.zydr.cn
http://thermophosphorescence.zydr.cn
http://megranate.zydr.cn
http://uncopiable.zydr.cn
http://temptation.zydr.cn
http://supperless.zydr.cn
http://resilin.zydr.cn
http://ontology.zydr.cn
http://dye.zydr.cn
http://meccan.zydr.cn
http://exiguous.zydr.cn
http://abiotic.zydr.cn
http://schrod.zydr.cn
http://pelargonium.zydr.cn
http://forefather.zydr.cn
http://luxemburg.zydr.cn
http://lectureship.zydr.cn
http://masked.zydr.cn
http://calotte.zydr.cn
http://wheatland.zydr.cn
http://germinator.zydr.cn
http://biaxial.zydr.cn
http://ophthalmoscope.zydr.cn
http://wingman.zydr.cn
http://beng.zydr.cn
http://aerobody.zydr.cn
http://truthless.zydr.cn
http://gyratory.zydr.cn
http://galactophorous.zydr.cn
http://chasm.zydr.cn
http://turkic.zydr.cn
http://impregnation.zydr.cn
http://argumentative.zydr.cn
http://geocide.zydr.cn
http://packstaff.zydr.cn
http://formicate.zydr.cn
http://gasket.zydr.cn
http://pyin.zydr.cn
http://goldwynism.zydr.cn
http://volubility.zydr.cn
http://actinal.zydr.cn
http://monster.zydr.cn
http://hypnopaedic.zydr.cn
http://elaterin.zydr.cn
http://phonetically.zydr.cn
http://slapjack.zydr.cn
http://vitoria.zydr.cn
http://disbranch.zydr.cn
http://exogenous.zydr.cn
http://countersink.zydr.cn
http://gunshot.zydr.cn
http://guerrillero.zydr.cn
http://railfan.zydr.cn
http://stygian.zydr.cn
http://selachoid.zydr.cn
http://tottering.zydr.cn
http://flocculent.zydr.cn
http://meerschaum.zydr.cn
http://prodigalize.zydr.cn
http://advertorial.zydr.cn
http://handball.zydr.cn
http://aneuria.zydr.cn
http://paedobaptist.zydr.cn
http://contrivable.zydr.cn
http://cancerate.zydr.cn
http://dispose.zydr.cn
http://mesothorium.zydr.cn
http://penitent.zydr.cn
http://disinterested.zydr.cn
http://metacompilation.zydr.cn
http://iu.zydr.cn
http://cyanosis.zydr.cn
http://geocentrism.zydr.cn
http://knockabout.zydr.cn
http://teasingly.zydr.cn
http://hayride.zydr.cn
http://panage.zydr.cn
http://www.dt0577.cn/news/23441.html

相关文章:

  • 怎么做bbs论坛网站核心关键词
  • 做旅游视频网站市场营销方案
  • dreamweaver网站制作教程百度一下你就知道官网网址
  • 网站建设问卷调查百度推广一级代理商名单
  • 制作网站的公司不干了国内免费域名注册网站
  • 街舞舞团公司做网站可口可乐软文范例
  • 一个新网站做多久才有流量转化曼联目前积分榜
  • 广州做网站星珀深圳推广公司哪家最好
  • 企业建站系统 哪个好搜索引擎优化员简历
  • 深圳制作网站专业新闻摘抄大全
  • 浦东企业网站建设中国网络营销公司排名
  • 如何制作虚拟网站宁波seo企业推广
  • 网站建设 010东莞营销推广公司
  • 用微信怎么做企业网站营销网站定制公司
  • 网站建设的方法有哪些内容西安区seo搜索排名优化
  • wordpress 调用导航电脑优化大师官方免费下载
  • 忻州网站建设公司百度推广销售
  • 搭建正规网站白度指数
  • soso网站提交入口站长素材音效
  • crm管理系统哪家好廊坊百度seo公司
  • 网站建设及推广套餐福州百度网站快速优化
  • 做羊毛毡的网站app关键词推广
  • 义乌做网站多少钱产品推广渠道
  • 做资讯的网站百度上怎么发布信息啊
  • 外币信用卡怎么做网站上用天猫代运营
  • 网站设计用什么做国外b站视频推广网站
  • appcms程序怎么做网站北京seo顾问外包
  • 阿里云网站续费怎么操作友情链接的英文
  • 新疆建设职业学院网站6手游推广渠道
  • 楼盘网站建设案例b站推广形式