首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    linux 什么是SO文件

    下面的内容大多都是连接中的,穿插我自己的笔记 牵扯到ELF格式,gcc编译选项待补,简单实用的说明一下,对Linux下的so文件有个实际性的认识。 1.so文件是什么?...也是ELF格式文件,共享库(动态库),类似于DLL。节约资源,加快速度,代码升级简化。 知道这么多就够了,实用主义。等有了印象再研究原理。 2.怎么生成以及使用一个so动态库文件?...-c,-o不是指.c文件.o文件!!...-soname:   soname的关键功能是它提供了兼容性的标准:   当要升级系统中的一个库时,并且新库的soname老库的soname一样,用旧库链接生成的程序使用新库依然能正常运行。...这个特性使得在Linux下,升级使得共享库的程序定位错误变得十分容易。

    5.7K20

    dll 劫持应用

    2021年1月,网上公开了 SUNBURST 后门植入的分析,后续又有安全研究者对植入细节进一步的优化,根据这些内容我展开了对 dll 劫持的学习研究。...根据 dll 的类型,我们可以将劫持大致可以分为两种方式: 1.自定义dll 有些应用程序使用了自定义 dll,这个 dll 是该应用程序特有的,只会被该程序加载使用。...1.替换系统dll,可以用普通用户修改文件为拥有者,然后再设置读写权限,就可以修改替换文件了 2.不能劫持 ntdll.dll / kernel32.dll 等非常底层的 dll,因为这些 dll 实现了程序装载... msvcrt.dll,除了上文公共 dll 劫持,还有其他更好的办法吗?...本文从 dll 劫持的基础出发,逐步讲解演示 dll 劫持,对 dll 劫持的部分场景利用进行说明,最后模仿了 SUNBURST 后门植入的方法实现了对 C 编译器的"供应链攻击"。

    77630

    python dll注入监听_DLL注入API拦截

    读《Windows核心编程》笔记一 DLL注入API拦截 在Windows中,每个进程相互独立,都有自己的私有的地址空间,程序中使用的指针都是进程自己地址空间的一个内存地址,无法创建也没法使用其他进程的指针...程序运行是由dll/exe等文件加载并执行的,运行过程中也可以动态的加载其他的DLL。...假如,我们可以使应用程序在加载dll时加载我们自己写的DLL,那么我们就可以在我们的DLL中做任何我们想做的事情,可以访问进程的任何私有地址空间。...添加好DLL后,把键值LoadAppInit_DLLs也改为1.这样就大功告成了,每当新的进程启动的时候,会去加载系统的User32.dll,User32.dll在处理DLL_PROCESS_DETACH...3.使用远程线程来注入DLL DLL注入技术唯一的目标就是让别的程序加载我们的DLL,这样我们就可以在我们自己的DLL中做任何我们想做的事情。

    1.2K10

    lib文件dll文件的区别_dll2lib

    如果有dll文件,那么lib一般是一些索引信息,记录了dll中函数的入口位置,dll中是函数的具体内容;如果只有lib文件,那么这个lib文件是静态编译出来的,索引实现都在其中。...动态链接的情况下,有两个文件:一个是LIB文件,一个是DLL文件。LIB包含被DLL导出的函数名称位置,DLL包含实际的函数和数据,应用程序使用LIB文件链接到DLL文件。...在应用程序的可执行文件中,存放的不是被调用的函数代码,而是DLL中相应函数代码的地址,从而节省了内存资源。DLLLIB文件必须随应用程序一起发行,否则应用程序会产生错误。....dll文件,真正的可执行文件,开发成功后的应用程序在发布时,只需要有.exe文件.dll文件,并不需要.lib文件.h头文件。...012306.png 构建项目(build)/生成解决方案,在项目的debug目录下面会生成很多的文件,其中包括有.dll.lib。

    2.8K10

    套接字中SO_REUSEPORTSO_REUSEADDR的区别

    BSD SO_REUSEADDR 如果在一个socket绑定到某一地址端口之前设置了其SO_REUSEADDR的属性,那么除非本socket与产生了尝试与另一个socket绑定到完全相同的源地址源端口组合的冲突...事实上,在multicast情况下,SO_REUSEADDRSO_REUSEPORT的作用完全相同。...LinuxLinux3.9之前,只有SO_REUSEADDR选项存在。这个选项的作用基本上同BSD系统下相同。但其仍有两个重要的区别。 ...所以两个UDP socket如果都设置了SO_REUSEADDR的话,它们就可以被绑定在一组完全相同的地址端口对上。  Linux3.9加入了SO_REUSEPORT选项。...Android Android的核心部分是略微修改过的Linux kernel,所以所有适用于Linux的操作也适用于android。

    3.5K20

    通过ffi在Node.js中调用动态链接库(.so.dll文件)

    notice: 本人的node使用环境是64bit的Linux系统。...Linux下pythonbrew一键搞定,Windows下还得去改环境变量。...需要将C源码build成动态链接库以供调用,在Linux下将C源码build成.so文件,在windows下build成.dll文件。本文只阐述.so文件的调用方法,调用.dll差别不大。...在Linux下如果使用C++编写的addon来调用.so文件,需要将.so文件为系统共享。 具体方法可以参看ldconfig命令,这是一个Linux下的动态链接库管理命令。...ldconfig命令的主要用途是在默认搜寻目录(/lib/usr/lib)以及动态库配置文件/etc/ld.so.conf内所列的目录下,搜索出可共享的动态链接库(格式如lib.so),进而创建出动态装入程序

    6.2K02

    .a.so库文件是什么?

    我们在编译开源代码后,通常会生成.a.so这两个库文件,这两个文件有什么区别?又如何使用?...在 Linux 中,.a .so 文件都是库文件,但它们有一些区别: 静态库文件(.a): 静态库文件是编译后的目标文件的归档文件,其中包含了多个目标文件(通常是 .o 文件)的集合。...共享库文件(.so): 共享库文件是编译后的目标文件的动态链接库文件,其中包含了可重用的函数和数据的集合。这些函数和数据在程序运行时会被动态加载到内存中。...1.2、共享库文件的使用: 在编译时,通过 -l 选项指定要链接的共享库文件,例如 -lmylib 表示链接 libmylib.so 共享库文件。 在运行时,程序需要知道共享库文件的位置。

    76200

    linux编译curl库的动态库so

    转载请注明出处:帘卷西风的专栏(http://blog.csdn.net/ljxfblog)  curl库是一个很强大的http开源库,c++里面能够很方便的http服务器交互。...最近项目开始内测,开始接登录充值的SDK,选择了使用curl库来第三方http服务器交互。...在windows下还是很容易使用,如何使用的案例比比皆是,而且很容易就找到已经编译好的动态库进行测试,但是最后在linux下部署的时候,发现不好找已经编译好的so库文件,最后没办法只好自理更生。...我是使用腾讯的SDK里面附带的curl库的源码(ps,腾讯SDK的示例代码貌似没在linux测试过,我编译后使用他们的代码,发现很容易崩溃,需要修改才能运行,但是windows正常)。...然后为了能够方便的移植我们的程序,把include/lib下面的头文件so库文件拷贝到自己的工程目录就能使用curl库了。

    6.4K10

    实战 | DLL劫持思路研究

    Windows操作系统通过“DLL路径搜索目录顺序”“Know DLLs注册表项”的机制来确定应用程序所要调用的DLL的路径,之后,应用程序就将DLL载入了自己的内存空间,执行相应的函数功能。...LoadLibraryLoadLibraryEx一个是本地加载,一个是远程加载,如果DLL不在调用的同一目录下,就可以使用LoadLibrary(L"DLL绝对路径")加载。...C++的编译器通常会对函数名变量名进行改编,这在链接的时候会出现一个严重的问题,假如dll是C++写的,可执行文件是C写的。...的名称要记住,等下会替换 点击生成就会在目录下生成一个.cpp文件 打开看一下有一个入口函数 新建一个vs dll项目,然后将.cpp的代码复制进去,并加上<stdlib.h...,然后转发的地方改为即时调用 生成一个vs dll项目,把生成的libuv.cpp代码copy到项目里面,然后加上#include "pch.h"#include 在入口函数的地方添加上我们的恶意代码

    2K20

    通过ffi在node.js中调用动态链接库(.so.dll文件)

    notice: 本人的node使用环境是64bit的Linux系统。...Linux下pythonbrew一键搞定,Windows下还得去改环境变量。...需要将C源码build成动态链接库以供调用,在Linux下将C源码build成.so文件,在windows下build成.dll文件。本文只阐述.so文件的调用方法,调用.dll差别不大。...在Linux下如果使用C++编写的addon来调用.so文件,需要将.so文件为系统共享。具体方法可以参看ldconfig命令,这是一个Linux下的动态链接库管理命令。...ldconfig命令的主要用途是在默认搜寻目录(/lib/usr/lib)以及动态库配置文件/etc/ld.so.conf内所列的目录下,搜索出可共享的动态链接库(格式如lib.so),进而创建出动态装入程序

    6.4K10
    领券