1. 借助语言优势解决问题;
2. 简化开发难度,偷懒;
在我这,我用它的主要目的在于加入扫描框架的依赖,毕竟lua的学习成本挺高的,如果正好这个安全人员不懂lua,只懂python咋整?能不成让他学习lua么?成本是一个方面,更多的是怎么快起来。一个团队,在快节奏下才能成长起来。
正好手上有一台机器,别人给我用来测试玩的,我就拿来做些调试和环境的测试。还没到生产环境,就遇到不少的坑,当时在线上环境也有测试,陪着运维的小哥一起搞,不断的测试和调整,折腾到很晚才搞成功,这里记录下过程。
默认的情况下,python.h应该在这个位置,但是测试的结果说找不到。内心是崩溃的,我在mac下是正常的。
用find命令找当前系统中的python.h的版本,发现只有2.6的,但是我按照了python2.7,这个版本完全错乱了。
心想,坑啊~~ 为了解决问题,少不得需要重新编译之类的屁事,当然,我们也干了这事,最后发现仍然不行,参考的例子(知乎上的指引,坑b)如下:
首先,你需要先把所有的python环境卸载,然后安装同步的环境,比如python2.7.12,devel也是python2.7.12,还有就是libs也必须是,不然弄不了,另外,编译安装默认不靠谱,最好就是rpm的方式来。包我留下,有需要的玩。
这是我的解决方案,当前完美解决我的问题,另外,推荐大家按照这个方式来搞,特别在centos环境下,这个比较坑爹。
可以的。C中内嵌Python
新建立一个工程,首先需要将工作目录设置到Python-3.1.1PCbuild中,以获取到动态库,至于静态库的包含,Include目录的指定,那自然也是少不了的。文件中需要包含Python.h文件,这也是必须的。
接口中
Py_Initialize()
Py_Finalize()
其他的根据需求,再引入相应的python builder 即可
下面是一个例子:首先是python的一个简单函数
class Hello:
def __init__(self, x):
self.a = x
def print(self, x=None):
print(x)
def xprint():
print("hello world")
if __name__ == "__main__":
xprint()
h = Hello(5)
h.print()1
下面是C语言
#include <python3.4m/Python.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main()
{
Py_Initialize()
// 将当前目录加入sys.path
PyRun_SimpleString("import sys")
PyRun_SimpleString("sys.path.append('./')")
// 导入hello.py模块
PyObject *pmodule = PyImport_ImportModule("hello")
// 获得函数xprint对象,并调用,输出“hello world\n”
PyObject *pfunc = PyObject_GetAttrString(pmodule, "xprint")
PyObject_CallFunction(pfunc, NULL)
// 获得类Hello并生成实例pinstance,并调用print成员函数,输出“5 6\n”
PyObject *pclass= PyObject_GetAttrString(pmodule, "Hello")
PyObject *arg = Py_BuildValue("(i)", 5)
PyObject *pinstance = PyObject_Call(pclass, arg, NULL)
PyObject_CallMethod(pinstance, "print", "i", 6)
Py_Finalize()
return 0
}
编译命令如下:
gcc pyapi.c -lpython3.4m -o pyapi