- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
Here是一种混淆技术,其中条件跳转被跳转表取代。每个数组只包含一个有效的函数指针,它们根据一个 crc 值被调用。我只保留了一个函数指针数组
#include <stdio.h>
#include <inttypes.h>
typedef void (*crc_check_fn)(uint32_t *);
static void crc_nib2 (uint32_t *crc) { printf("OK\n"); }
crc_check_fn b1[16] = { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, crc_nib2, 0, 0, 0 };
int main(){
uint32_t crc = 0xFFF7FB7C;
int index = crc & 0x0F;
(*b1[index])(&crc);
}
我有几个问题:
能否将这个数组定位到二进制的汇编中?我不太懂汇编,所以检查它我无法分辨。
我假设上一个问题的答案是肯定的,因为原始帖子建议初始化 b1
像 { ..., crc_nib2-8, crc_nib2, crc_ni2+8, ... };
。这样更安全吗?难道不能说这些是无效指针吗?难道不是实现大量真实虚拟函数的更好选择吗?
用gcc -S
编译我得到了
b1:...
.quad 0
.quad crc_nib2 .quad 0
...
在二进制文件上运行 objdump -d
会生成一个没有上述行的程序集。为什么程序集不同?我没有剥离符号。
最佳答案
- Can this array located in the assembly of the binary? I do not know well assembly, so checking it I was unable to tell this.
是的,可能吧。使用 GCC,我将它放在程序集中。可以想象它会被放置在 BSS(零初始化内存)中,然后在 main
之前初始化以包含单个非 NULL 指针。
- I assume the answer to the previous question is yes, because the original post recommends initializng
b1
like{ ..., crc_nib2-8,
. Is this safer? Isn't it possible to tell that these are invalid pointers? Shouldn't be a better option to implement a lot of real dummy functions?
crc_nib2, crc_ni2+8, ... };
首先,这实际上不是很安全。解决这个问题所需的所有信息都可用。如果我们知道这已经完成,就可以很容易地找出 crc_nib2
是一个有效的函数指针,而另一个是。也可以得出 crc_ni2+8
可能不是有效指针的结论。这是通过知道一个函数的开始通常看起来非常相似并且可以以一定程度的准确度自动识别来完成的。如果有可用的符号表,它会变得更加简单。
如果你想让可执行文件真正防篡改,你必须确保您不能篡改检查可执行文件完整性的代码。如果检查是在可执行文件本身中完成的,那么它可能毫无意义,因为您(如果您可以在一个地方进行修改)即使在其他地方修改后也可以修改检查以使它们通过。
Compiling with
gcc -S
I gotb1: ...
.quad 0
.quad crc_nib2 .quad 0
...
是的,我也是,但问题是什么?
请注意,objdump -d
只是反汇编可执行文件的可执行部分中的所有内容,并跳过其余部分。这是因为通常其他(数据)部分中的数据类型因此“反汇编”没有太多有趣之处,只有对该数据进行 hexdump 才有意义。
关于c - 在程序集中定位数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33565833/
我必须从我的网站中删除()一些iem,然后将它们追加()回来,但是当我追加它们时,它们出现在不同的地方,而我希望它们完全显示在它们以前的同一个地方是。 有什么解决办法吗? 这是一个沙箱,请随意更新(注
一个。图片 (960x7)b. div(宽度:960,填充:10) 我想定位 (a),使其距顶部 50 像素,居中。我想将 (b) 放置在 (a) 的正下方,没有空格。 我的 CSS 如下: @cha
放置某物的正确方法是什么?我有一个在中心显示博客文章的 div。 "" rel="bookmark"> BY LOUIS MOORE ON " pubdate>
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭1
我已经成功地使用了 position:fixed 设置 CSS/CSS3 并且工作得很好! 我几天前看到了这个,想知道他们是如何实现向下滚动时发生的效果的,菜单栏在滚动前处于一个位置,然后转到顶部并自
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎与 help center 中定义的范围内的编程无关。 . 关闭 7 年前。 Improv
接口定义 能够对于文字、段落乃至任何元素的精准定位 并做出增删改查,都是在开发一款富文本编辑器时一项最基本也是最重要的功能之一。让我们先来看看Slate中对于如何在文档树中定位元素是怎么定义的
例如,使用 WPF 在选项卡控件的最左上角定位三个 tabitem 和在最右上角定位一个 tabitem 的正确方法是什么? 我尝试通过更改边距将第四个 tabitem 向右移动,但这并没有产生好的结
我正在尝试使用 Javascript 创建一个跟随鼠标在页面上移动的东西。我希望它是米老鼠,我希望他的眼睛跟随鼠标移动他的眼球...这是我到目前为止的代码(从网络上的各个地方收集,因此归功于编写该部分
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 这个问题似乎与 help center 中定义的范围内的编程无关。 . 已关闭 9 年前。 Improve
我试图将两个按钮放置在左上角。但它们始终位于顶部中心。 我已经尝试过这个: jp = new JPanel(); jp.setLayout(new GridBagLayout()); GridBagC
我在使用 JQuery 向下滑动功能时遇到问题。我可以让它正常工作,但是我向下滑动的元素的位置会根据视口(viewport)的大小而变化。我想做的是将它与它滑动的元素联系起来。 This JSfidd
我正在尝试创建一个棋盘,并将其放置在屏幕中间,但到目前为止我无法将它直接放在中间。我不想将位置硬编码到屏幕上,因为我要处理不同的屏幕尺寸。 var winsize = cc.director.
我正在尝试从 mysql 中的 2 个字符串点之间提取数据,我的示例脚本是 'otherdata&p1=textneeded&otherdata' 我需要拉出“textneeded”位,“P1=”是起
如何在 JavaFX 中设置按钮的位置?我的代码: bZero = new Button(); bZero.setPrefSize(45, 20); mainPane.getChildren().ad
我有一个 iPhone 应用程序,我可以在其中显示一系列图像。当用户点击图像时,我需要将该图像带到第一个位置,表明它是所选图像。我可以通过子类化实现 uiscrollview 中的点击。但是我无法将
在下图中,它显示了一个image、textbox 和一个css menu image 我的 CSS 菜单非常完美。我终于按照我需要的方式得到了它。我的问题是我需要导航栏中央的文本框,然后我需要我的图像
我必须创建一个看起来像这样的 div id为2的div应该出现在图片的右下角,图片的大小不固定id=2的div应该应用什么css id =1 的 div 没有定义位置,所以使用默认值,图像也是
如何将我的文本和图像对齐在同一行? 每当我使用 padding 或 margins 时,它就会崩溃到我正在使用的圆形图像中。 #alignPhoto { padding-right: 50px;
简单的问题,如何定位具有整个页面引用的元素? 在我的例子中,我在标题中得到了一个 float 图像,然后是 2 组标题。当我使用时: text-align: center; 它使用图像宽度端和页面其余
我是一名优秀的程序员,十分优秀!