链接器工具错误 LNK2026 模块对于 SAFESEH 映像是不安全的

一、概述

       今天用VS 2013打开一个之前VS2010下的一个c/c++项目,生成的时候报错:“LNK2026 模块对于 SAFESEH 映像是不安全的”。网上搜了一下,发现了解决方案:打开项目属性,在连接器----命令行---额外选项中填入如下语句:/SAFESEH:NO  保存后重新生成即可。


至此,网上再无解释为什么要这么做。于是从错误LNK2026出发,在MSDN上搜了下,结果如下:

/SAFESEH 已指定,但某一模块与安全异常处理功能不兼容。 如果要将此模块用于 /SAFESEH,则需要使用 Visual C++ .NET 2003(或更高版本)编译器重新编译该模块。

大致意思是某一个模块需要重新编译才行,于是回头仔细看了下错误,发现出错的地方是引入的库有问题:


这些库都是官网上直接下载的,按理说应该不会有什么问题的。于是继续搜SAFESEH,搜到了下面这篇文章:http://blog.csdn.net/magictong/article/details/7517630

这篇文章讲解了SAFESEH的概念和原理性东西:

SEH大概就是Safe Exception Handler的意思。设计SafeSEH保护机制的目的,以为了防止那种攻击者通过覆盖堆栈上的异常处理函数句柄,从而控制程序执行流程的攻击。在VS 2003之后,这种机制已经是默认的了。并且作者明确说禁用SAFESEH是“疯狂的”。

引入的库是官网上现成的,虽然是开源的,可以自己重新编译生成,但实在是太麻烦了,目前也只是做做例子,也没有时间纠结这个安全问题,暂时就这样处理吧。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值