idapython: importing "site" failed报错的解决方案

0x00 背景

突然有一天IDA6.8 打开提示idapython错误:
报错信息如下:
在这里插入图片描述

0x01 问题原因

ida官网有对该问题的解释:

This issue is usually caused by presence of non-standard python27.dll
in the PATH which uses its own set of modules (you should edit PATH in
this case). However, it may happen if your Python installation is
broken in some way. Reinstalling Python manually may fix it.

大致原因是:你主机的环境变量path包含了非标准的python27.dll导致的,当然,也可能是某次安装时意外终端导致的。手动重新安装python可能会修复这个问题。

0x02 问题修复

官方也好心的给出了详细的修复方法:

  1. 查看python27.dll的位置
    c:\>where python27.dll
    C:\Windows\System32\python27.dll
  1. 查看注册表中 HKEY_LOCAL_MACHINE\SOFTWARE\Python\PythonCore\2.7\InstallPath 的值是python2.7的安装路径
  2. 增加一个环境变量,key为PYTHONHOME,value为python的安装路径。
    在这里插入图片描述
  3. 如果idapython被正常加载,但还是存在这个错误,请打印下sys.path,确定是否符合预期
Python>import sys
Python>sys.path
['C:\\Windows\\system32\\python27.zip', 'C:\\Python27-x64\\Lib', 'C:\\Python27-x64\\DLLs', 'C:\\Python27-x64\\Lib\\lib-tk', 'C:\\Program Files\\IDA 7.0\\python', 'C:\\Python27-x64', 'C:\\Python27-x64\\lib\\site-packages', 'C:\\Program Files\\IDA 7.0\\python\\lib\\python2.7\\lib-dynload\\ida_32', 'C:\\Program Files\\IDA 7.0\\python']
  1. 跟踪IDAPython模块的加载过程。在IDA运行前设置环境变量 PYTHONVERBOSE=1,path路径将被打印出来(或者在IDA运行命令中加入-L 生成日志文件)。

0x03 问题解决

使用第三个步骤,创建一个环境变量 PYTHONHOME 即可解决我目前的问题。

比较坑的是某些博客,写到创建环境变量%PYTHONHOME%,这是什么鬼?

在环境变量中,%path%中百分号的意思,就是表示path是一个已定义的一个环境变量的调用,相当于linux中的$path。第一次定义变量是,不会使用%%。

0x04 参考文献

https://www.hexblog.com/?p=1132

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值