热门标签 | HotTags
当前位置:  开发笔记 > 运维 > 正文

用LKM更改linux缺省安全等级

文章标题:用LKM更改linux缺省安全等级。Linux是中国IT实验室的一个技术频道。包含桌面应用,Linux系统管理,内核研究,嵌入式系统和开源等一些基本分类

  Linux缺省的安全等级是0,如果将其升到1,就可以一定程度上提高系统的安全性.安全等级
  为1的时候,它会禁止修改ex2fs系统中文件的immutable和append-only位,同时禁止装入
  /移除module.所以我们可以先用chattr +i 将大部分的可执行文件,动态连接库,
  一些重要的系统文件(inetd.conf,securetty,hosts.allow,hosts.deny,rc.d下的启
  动script...)加上immutable位,这样"黑客"就很难在你的机器上放置木马和留后门了.
  (即便他已经得到了root权限,当然通过直接硬盘读写仍然可以修改,但比较麻烦而且危险
  ).
  
  "黑客"们一旦进入系统获得root,首先会清除系统的记录文件.你可以给一些系统记录文件
  (wtmp,messages,syslog...)增加append-only位,使"黑客"不能轻易的修改它们.要抓
  他们就容易多了.:-)
  
  修改安全等级比较直接的办法是直接修改内核源码.将linux/kernel/sched.c中的
  securelevel设成1即可.不过如果要改变安全等级的话需要重新编译内核,我太懒,不想那
  么麻烦.:-)
  
  为什么不用module呢?我写了个很简单的lkm和一个client程序来完成安全等级的切换.
  
  方法: insmod lkm; clt -h;
  
  注意:普通用户也可以执行clt来切换安全等级,所以最好是在clt和lkm中加段密码检查,
  如果密码不对就不允许执行.:-)
  
  这两个程序在Redhat 5.2(2.0.36)下编译运行通过.对于2.2.x的内核,securelevel
  变成了securebits,简单的将它改到1,会连setuid()都被禁止了,这样普通用户就不能
  登陆了.如果谁对2.2.x比较熟悉,请不吝赐教,共同提高嘛.:)
  
  <在测试这些程序以前,请备份重要数据.本人不为运行此程序带来的任何损失负责.>
  
  (一旦securelevel=1,kernel将不允许装入modlue,所以你的kerneld可能不能正
  常工作,而且禁止你访问/dev/kmem,所以有些用到svgalib的程序也不能正常工作
  ,象zgv什么的。不过这本来就是安全隐患,所以不工作就不工作好了,呵呵)
  (关于chattr,lsaddr请man chattr和man lsattr)
  
  warning3@hotmail.com
  
  /**************************** lkm.c ********************************/
  
  /* Simple lkm to secure Linux.
  * This module can be used to change the securelevel of Linux.
  * Running the client will switch the securelevel.
  *
  * gcc -O3 -Wall -c lkm.c
  * insmod lkm
  *
  * It is tested in Redhat 5.2 (2.0.36).
  * (It should be modified if you want to run it in 2.2.x kernel).
  * It is really very simple,but we just for educational purposes.:-)
  *
  * warning3@hotmail.com
  */
  
  #define MODULE
  #define __KERNEL__
  
  #include
  #include
  #include
  #include
  #include
  #include
  #include
  #include
  #include
  #include
  #include
  #include
  #include
  #include
  #include
  
  #define __NR_secureswitch 250
  
  extern void *sys_call_table[];
  
  int sys_secureswitch(int secure)
  {
  if(secure==0) securelevel=0;
  if(secure==1) securelevel=1;
  return securelevel;
  }
  
  int init_module(void)
  {
  sys_call_table[__NR_secureswitch] = (void *)sys_secureswitch;
  return 0;
  }
  void cleanup_module(void)
  {
  sys_call_table[__NR_secureswitch] = NULL;
  return;
  }
  /************************ clt.c **************************/
  /*
  * This client can switch the secure level of Linux.
  *
  * gcc -O3 -Wall -o clt clt.c
  * Usage: clt -h/-l
  * -h switch to the high secure level.
  * -l switch to the low secure level.
  *
  * Most of codes are ripped from smiler@tasam.com,thanks smiler.:)
  * warning3@hotmail.com
  */
  #include
  #include
  #include
  #define __NR_secureswitch 250
  static inline _syscall1(int, secureswitch, int, command);
  int main(int argc,char **argv)
  
  {
  int ret,level = 0;
  if (argc <2)
  
  {
  fprintf(stderr,"Usage: %s [-h/-l]n",argv[0]);
  exit(-1);
  }
  if (argv[1][1] == h) level++;
  else if (argv[1][1] != l)
  {
  fprintf(stderr,"Usage: %s [-h/-l]n",argv[0]);
  exit(-1);
  }
  ret = secureswitch(level);
  if (ret <0)
  printf("Hmmm...It seemed that our lkm hasnt been loaded.;-)n");
  else {
  if (ret == 0) {
  puts("Now the secure level is changed to 0!n");
  } else {
  puts("Now the secure level is chagned to 1!n");
  }
  }
  return(1);
  }
  
推荐阅读
  • 本文介绍了Python高级网络编程及TCP/IP协议簇的OSI七层模型。首先简单介绍了七层模型的各层及其封装解封装过程。然后讨论了程序开发中涉及到的网络通信内容,主要包括TCP协议、UDP协议和IPV4协议。最后还介绍了socket编程、聊天socket实现、远程执行命令、上传文件、socketserver及其源码分析等相关内容。 ... [详细]
  • Centos7.6安装Gitlab教程及注意事项
    本文介绍了在Centos7.6系统下安装Gitlab的详细教程,并提供了一些注意事项。教程包括查看系统版本、安装必要的软件包、配置防火墙等步骤。同时,还强调了使用阿里云服务器时的特殊配置需求,以及建议至少4GB的可用RAM来运行GitLab。 ... [详细]
  • 图解redis的持久化存储机制RDB和AOF的原理和优缺点
    本文通过图解的方式介绍了redis的持久化存储机制RDB和AOF的原理和优缺点。RDB是将redis内存中的数据保存为快照文件,恢复速度较快但不支持拉链式快照。AOF是将操作日志保存到磁盘,实时存储数据但恢复速度较慢。文章详细分析了两种机制的优缺点,帮助读者更好地理解redis的持久化存储策略。 ... [详细]
  • Skywalking系列博客1安装单机版 Skywalking的快速安装方法
    本文介绍了如何快速安装单机版的Skywalking,包括下载、环境需求和端口检查等步骤。同时提供了百度盘下载地址和查询端口是否被占用的命令。 ... [详细]
  • 本文详细介绍了云服务器API接口的概念和作用,以及如何使用API接口管理云上资源和开发应用程序。通过创建实例API、调整实例配置API、关闭实例API和退还实例API等功能,可以实现云服务器的创建、配置修改和销毁等操作。对于想要学习云服务器API接口的人来说,本文提供了详细的入门指南和使用方法。如果想进一步了解相关知识或阅读更多相关文章,请关注编程笔记行业资讯频道。 ... [详细]
  • 生成对抗式网络GAN及其衍生CGAN、DCGAN、WGAN、LSGAN、BEGAN介绍
    一、GAN原理介绍学习GAN的第一篇论文当然由是IanGoodfellow于2014年发表的GenerativeAdversarialNetworks(论文下载链接arxiv:[h ... [详细]
  • 信息安全等级保护是指对国家秘密信息、法人和其他组织及公民的专有信息以及公开信息和存储、传输、处理这些信息的信息系统分等级实行安全保护,对信息系统中使用的信息安全产品实 ... [详细]
  • 无线认证设置故障排除方法及注意事项
    本文介绍了解决无线认证设置故障的方法和注意事项,包括检查无线路由器工作状态、关闭手机休眠状态下的网络设置、重启路由器、更改认证类型、恢复出厂设置和手机网络设置等。通过这些方法,可以解决无线认证设置可能出现的问题,确保无线网络正常连接和上网。同时,还提供了一些注意事项,以便用户在进行无线认证设置时能够正确操作。 ... [详细]
  • t-io 2.0.0发布-法网天眼第一版的回顾和更新说明
    本文回顾了t-io 1.x版本的工程结构和性能数据,并介绍了t-io在码云上的成绩和用户反馈。同时,还提到了@openSeLi同学发布的t-io 30W长连接并发压力测试报告。最后,详细介绍了t-io 2.0.0版本的更新内容,包括更简洁的使用方式和内置的httpsession功能。 ... [详细]
  • 本文详细介绍了相机防抖的设置方法和使用技巧,包括索尼防抖设置、VR和Stabilizer档位的选择、机身菜单设置等。同时解释了相机防抖的原理,包括电子防抖和光学防抖的区别,以及它们对画质细节的影响。此外,还提到了一些运动相机的防抖方法,如大疆的Osmo Action的Rock Steady技术。通过本文,你将更好地理解相机防抖的重要性和使用技巧,提高拍摄体验。 ... [详细]
  • 本文详细介绍了华为4GLTE路由器B310的外置天线安装和设置方法。通过连接电源和网线,输入路由器的IP并登陆设置页面,选择手动设置和手动因特网设置,输入ISP提供商的用户名和密码,并设置MTU值。同时,还介绍了无线加密的设置方法。最后,将外网线连在路由器的WAN口即可使用。 ... [详细]
  • 本文讨论了前端工程化的准备工作,主要包括性能优化、安全防护和监控等方面需要注意的事项。通过系统的答案,帮助前端开发者更好地进行工程化的准备工作,提升网站的性能、安全性和监控能力。 ... [详细]
  • Java String与StringBuffer的区别及其应用场景
    本文主要介绍了Java中String和StringBuffer的区别,String是不可变的,而StringBuffer是可变的。StringBuffer在进行字符串处理时不生成新的对象,内存使用上要优于String类。因此,在需要频繁对字符串进行修改的情况下,使用StringBuffer更加适合。同时,文章还介绍了String和StringBuffer的应用场景。 ... [详细]
  • MyBatis错题分析解析及注意事项
    本文对MyBatis的错题进行了分析和解析,同时介绍了使用MyBatis时需要注意的一些事项,如resultMap的使用、SqlSession和SqlSessionFactory的获取方式、动态SQL中的else元素和when元素的使用、resource属性和url属性的配置方式、typeAliases的使用方法等。同时还指出了在属性名与查询字段名不一致时需要使用resultMap进行结果映射,而不能使用resultType。 ... [详细]
  • 本文介绍了Web学习历程记录中关于Tomcat的基本概念和配置。首先解释了Web静态Web资源和动态Web资源的概念,以及C/S架构和B/S架构的区别。然后介绍了常见的Web服务器,包括Weblogic、WebSphere和Tomcat。接着详细讲解了Tomcat的虚拟主机、web应用和虚拟路径映射的概念和配置过程。最后简要介绍了http协议的作用。本文内容详实,适合初学者了解Tomcat的基础知识。 ... [详细]
author-avatar
KJ慧兒H妹子Ed
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有