首页
社区
课程
招聘
[求助]问大家一个很傻的问题!
发表于: 2005-12-30 18:32 3965

[求助]问大家一个很傻的问题!

2005-12-30 18:32
3965
004010C1   > 8A83 1A214000  MOV AL,BYTE PTR DS:[EBX+40211A] ;从文件里取出字符与AL比较
004010C7   . 3C 00          CMP AL,0
004010C9   . 74 08          JE SHORT DueList2.004010D3            ;  等于时转移
004010CB   . 3C 01          CMP AL,1 ;想在这里实现跳转,可是实再是想不出有什么字符的十六进制值会比1小的。
004010CD   . 75 01          JNZ SHORT DueList2.004010D0           ;  不等时转移
004010CF   . 46             INC ESI
004010D0   > 43             INC EBX
004010D1   .^EB EE          JMP SHORT DueList2.004010C1
004010D3   > 83FE 02        CMP ESI,2                             ;  小于时转移

从一个文件里读取字符与al比较,想实现跳转,可是没找出会1或0小的字符,
程序是把文件里读出来的数字当成字符的,
空格= HEX 20   1= hEX 31

帮一下我这个傻子吧!
就是有没有字符的十六进制值会比1或0小呢?????

[注意]传递专业知识、拓宽行业人脉——看雪讲师团队等你加入!

收藏
免费 0
支持
分享
最新回复 (8)
雪    币: 243
活跃值: (190)
能力值: ( LV9,RANK:210 )
在线值:
发帖
回帖
粉丝
2
1是SOH (start of heading)
0是NULL

判断以上作出相关操作,干嘛非要去找那个字符呢。。。
2005-12-30 18:50
0
雪    币: 243
活跃值: (190)
能力值: ( LV9,RANK:210 )
在线值:
发帖
回帖
粉丝
3
ascii编码

       Decimal   Octal   Hex    Binary        Value

       -------   -----   ---    ------     -----

         000      000    000   00000000      NUL    (Null char.)

         001      001    001   00000001      SOH    (Start of Header)

         002      002    002   00000010      STX    (Start of Text)

         003      003    003   00000011      ETX    (End of Text)

         004      004    004   00000100      EOT    (End of Transmission)

         005      005    005   00000101      ENQ    (Enquiry)

         006      006    006   00000110      ACK    (Acknowledgment)

         007      007    007   00000111      BEL    (Bell)

         008      010    008   00001000       BS    (Backspace)

         009      011    009   00001001       HT    (Horizontal Tab)

         010      012    00A   00001010       LF    (Line Feed)

         011      013    00B   00001011       VT    (Vertical Tab)

         012      014    00C   00001100       FF    (Form Feed)

         013      015    00D   00001101       CR    (Carriage Return)

         014      016    00E   00001110       SO    (Shift Out)

         015      017    00F   00001111       SI    (Shift In)

         016      020    010   00010000      DLE    (Data Link Escape)

         017      021    011   00010001      DC1 (XON) (Device Control 1)

         018      022    012   00010010      DC2       (Device Control 2)

         019      023    013   00010011      DC3 (XOFF)(Device Control 3)

         020      024    014   00010100      DC4       (Device Control 4)

         021      025    015   00010101      NAK    (Negative Acknowledgement)

         022      026    016   00010110      SYN    (Synchronous Idle)

         023      027    017   00010111      ETB    (End of Trans. Block)

         024      030    018   00011000      CAN    (Cancel)

         025      031    019   00011001       EM    (End of Medium)

         026      032    01A   00011010      SUB    (Substitute)

         027      033    01B   00011011      ESC    (Escape)

         028      034    01C   00011100       FS    (File Separator)

         029      035    01D   00011101       GS    (Group Separator)

         030      036    01E   00011110       RS    (Request to Send)(Record Separator)

         031      037    01F   00011111       US    (Unit Separator)

         032      040    020   00100000       SP    (Space)

         033      041    021   00100001        !    (exclamation mark)

         034      042    022   00100010        "    (double quote)

         035      043    023   00100011        #    (number sign)

         036      044    024   00100100        $    (dollar sign)

         037      045    025   00100101        %    (percent)

         038      046    026   00100110        &    (ampersand)

         039      047    027   00100111        \'    (single quote)

         040      050    028   00101000        (    (left/opening parenthesis)

         041      051    029   00101001        )    (right/closing parenthesis)

         042      052    02A   00101010        *    (asterisk)

         043      053    02B   00101011        +    (plus)

         044      054    02C   00101100        ,    (comma)

         045      055    02D   00101101        -    (minus or dash)

         046      056    02E   00101110        .    (dot)

         047      057    02F   00101111        /    (forward slash)

         048      060    030   00110000        0

         049      061    031   00110001        1

         050      062    032   00110010        2

         051      063    033   00110011        3

         052      064    034   00110100        4

         053      065    035   00110101        5

         054      066    036   00110110        6

         055      067    037   00110111        7

         056      070    038   00111000        8

         057      071    039   00111001        9

         058      072    03A   00111010        :    (colon)

         059      073    03B   00111011        ;    (semi-colon)

         060      074    03C   00111100        <    (less than)

         061      075    03D   00111101        =    (equal sign)

         062      076    03E   00111110        >    (greater than)

         063      077    03F   00111111        ?    (question mark)

         064      100    040   01000000        @    (AT symbol)

         065      101    041   01000001        A

         066      102    042   01000010        B

         067      103    043   01000011        C

         068      104    044   01000100        D

         069      105    045   01000101        E

         070      106    046   01000110        F

         071      107    047   01000111        G

         072      110    048   01001000        H

         073      111    049   01001001        I

         074      112    04A   01001010        J

         075      113    04B   01001011        K

         076      114    04C   01001100        L

         077      115    04D   01001101        M

         078      116    04E   01001110        N

         079      117    04F   01001111        O

         080      120    050   01010000        P

         081      121    051   01010001        Q

         082      122    052   01010010        R

         083      123    053   01010011        S

         084      124    054   01010100        T

         085      125    055   01010101        U

         086      126    056   01010110        V

         087      127    057   01010111        W

         088      130    058   01011000        X

         089      131    059   01011001        Y

         090      132    05A   01011010        Z

         091      133    05B   01011011        [    (left/opening bracket)

         092      134    05C   01011100        \\    (back slash)

         093      135    05D   01011101        ]    (right/closing bracket)

         094      136    05E   01011110        ^    (caret/cirumflex)

         095      137    05F   01011111        _    (underscore)

         096      140    060   01100000        `

         097      141    061   01100001        a

         098      142    062   01100010        b

         099      143    063   01100011        c

         100      144    064   01100100        d

         101      145    065   01100101        e

         102      146    066   01100110        f

         103      147    067   01100111        g

         104      150    068   01101000        h

         105      151    069   01101001        i

         106      152    06A   01101010        j

         107      153    06B   01101011        k

         108      154    06C   01101100        l

         109      155    06D   01101101        m

         110      156    06E   01101110        n

         111      157    06F   01101111        o

         112      160    070   01110000        p

         113      161    071   01110001        q

         114      162    072   01110010        r

         115      163    073   01110011        s

         116      164    074   01110100        t

         117      165    075   01110101        u

         118      166    076   01110110        v

         119      167    077   01110111        w

         120      170    078   01111000        x

         121      171    079   01111001        y

         122      172    07A   01111010        z

         123      173    07B   01111011        {    (left/opening brace)

         124      174    07C   01111100        |    (vertical bar)

         125      175    07D   01111101        }    (right/closing brace)

         126      176    07E   01111110        ~    (tilde)

         127      177    07F   01111111      DEL    (delete)

前32个控制字符的详细解释:

NUL (null)

SOH (start of heading)

STX (start of text)

ETX (end of text)

EOT (end of transmission) - Not the same as ETB

ENQ (enquiry)

ACK (acknowledge)

BEL (bell) - Caused teletype machines to ring a bell.  Causes a beep

             in many common terminals and terminal emulation programs.

BS  (backspace) - Moves the cursor (or print head) move backwards (left)

                  one space.

TAB (horizontal tab) - Moves the cursor (or print head) right to the next

                       tab stop.  The spacing of tab stops is dependent

                       on the output device, but is often either 8 or 10.

LF  (NL line feed, new line) - Moves the cursor (or print head) to a new

                               line.  On Unix systems, moves to a new line

                               AND all the way to the left.

VT  (vertical tab)

FF  (form feed) - Advances paper to the top of the next page (if the

                  output device is a printer).

CR  (carriage return) - Moves the cursor all the way to the left, but does

                        not advance to the next line.

SO  (shift out) -tches output device to alternate character set.

SI  (shift in)  -tches output device back to default character set.

DLE (data link escape)

DC1 (device control 1)

DC2 (device control 2)

DC3 (device control 3)

DC4 (device control 4)

NAK (negative acknowledge)

SYN (synchronous idle)

ETB (end of transmission block) - Not the same as EOT

CAN (cancel)

EM  (end of medium)

SUB (substitute)

ESC (escape)

FS  (file separator)

GS  (group separator)

RS  (record separator)

US  (unit separator)
2005-12-30 18:53
0
雪    币: 260
活跃值: (81)
能力值: ( LV4,RANK:50 )
在线值:
发帖
回帖
粉丝
4
这个不是字符的问题,你手工写入的东西,都当作字符了,你用十六进制工具写入才可以。
2005-12-30 18:54
0
雪    币: 243
活跃值: (190)
能力值: ( LV9,RANK:210 )
在线值:
发帖
回帖
粉丝
5
最初由 starluck 发布
004010C1 > 8A83 1A214000 MOV AL,BYTE PTR DS:[EBX+40211A] ;从文件里取出字符与AL比较
004010C7 . 3C 00 CMP AL,0
004010C9 . 74 08 JE SHORT DueList2.004010D3 ; 等于时转移
004010CB . 3C 01 CMP AL,1 ;想在这里实现跳转,可是实再是想不出有什么字符的十六进制值会比1小的。
004010CD . 75 01 JNZ SHORT DueList2.004010D0 ; 不等时转移
........


JNZ改JMP好了,先补一下基础
2005-12-30 18:55
0
雪    币: 212
活跃值: (40)
能力值: ( LV4,RANK:50 )
在线值:
发帖
回帖
粉丝
6
004010A8   . 50             PUSH EAX                              ; |hFile
004010A9   . E8 2F020000    CALL <JMP.&KERNEL32.ReadFile>         ; \ReadFile
004010AE   . 85C0           TEST EAX,EAX     :这样一搞eax=00000001了
004010B0   . 75 02          JNZ SHORT DueList2.004010B4
004010B2   . EB 43          JMP SHORT DueList2.004010F7
004010B4   > 33DB           XOR EBX,EBX
004010B6   . 33F6           XOR ESI,ESI
004010B8   . 833D 73214000 >CMP DWORD PTR DS:[402173],12          ;  字段长度不可小于12位
004010BF   . 7C 36          JL SHORT DueList2.004010F7
004010C1   > 8A83 1A214000  MOV AL,BYTE PTR DS:[EBX+40211A] ;读取文件里的字符。真是不知道,文件里用什么字符才能比0,1小,实现跳转了
004010C7   . 3C 00          CMP AL,0
004010C9   . 74 08          JE SHORT DueList2.004010D3            ;  等于时转移
004010CB   . 3C 01          CMP AL,1
004010CD   . 75 01          JNZ SHORT DueList2.004010D0           ;  不等时转移
004010CF   . 46             INC ESI
004010D0   > 43             INC EBX
004010D1   .^EB EE          JMP SHORT DueList2.004010C1
004010D3   > 83FE 02        CMP ESI,2                             ;  小于时转移
004010D6   . 7C 1F          JL SHORT DueList2.004010F7
2005-12-30 18:58
0
雪    币: 212
活跃值: (40)
能力值: ( LV4,RANK:50 )
在线值:
发帖
回帖
粉丝
7
暴破的话我就不用这么费劲了,就是想从头到尾把这个程序看个仔细,学一下算法。
2005-12-30 19:02
0
雪    币: 243
活跃值: (190)
能力值: ( LV9,RANK:210 )
在线值:
发帖
回帖
粉丝
8
无语
2005-12-30 19:03
0
雪    币: 212
活跃值: (40)
能力值: ( LV4,RANK:50 )
在线值:
发帖
回帖
粉丝
9
怎么了兄弟! 我不是只为破解,我只是学一点人家的算法。
暴破东西N次了没激情了
2005-12-30 19:06
0
游客
登录 | 注册 方可回帖
返回
//