20145307《信息安全系统设计基础》期中总结

20145307《信息安全系统设计基础》期中总结

知识点总结

常用的Linux命令

Linux中命令格式为:command [options] [arguments] []表示是可选的,即组成结构为:命令 [选项] [参数]

man命令

man命令是Linux下的帮助指令,通过man指令可以查看Linux中的指令帮助、配置文件帮助和编程帮助等信息。

常用选项:

-a:在所有的man帮助手册中搜索

-k:根据关键字搜索联机帮助,是一种模糊搜索

-f:关键字精确搜索,等价于whatis指令,显示给定关键字的简短描述信息

-P:指定内容时使用分页程序

-M:指定man手册搜索的路径

参数:

数字:指定从哪本man手册中搜索帮助

关键字:指定要搜索帮助的关键字

man -k:常用来搜索,结合管道使用。例句如下:man -k k1 | grep k2 | grep 2

cheat命令

在linux上,man命令几乎是万能的,但它却不是最高效的。由于它给出的帮助信息很长,在短时间内不好理解,所以在这种情况下,用cheat命令更方便,cheat命令简单来说,就是告诉你一个命令如何使用。它没有提供其他额外多余的信息,只通过使用实例告诉你一个命令如何使用。

grep命令

grep命令是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来。grep全称是Global Regular Expression Print,表示全局正则表达式版本,它的使用权限是所有用户。

命令格式:grep [options]

[options]主要参数:

-c:只输出匹配行的计数

-I:不区分大小写(只适用于单字符)

-h:查询多文件时不显示文件名

-l:查询多文件时只输出包含匹配字符的文件名

-n:显示匹配行及行号

-s:不显示不存在或无匹配文本的错误信息

-v:显示不包含匹配文本的所有行

如果想查找某个宏,我们已知宏保存在include文件夹中,所以可以使用下列语句:grep -nr XXX /usr/include

find命令

find命令用来在指定目录下查找文件。任何位于参数之前的字符串都将被视为欲查找的目录名。如果使用该命令时,不设置任何参数,则find命令将在当前目录下查找子目录与文件。并且将查找到的子目录和文件全部进行显示。

命令格式:find pathname -options [-print -exec -ok ...]

参数:

pathname:find命令所查找的目录路径。例如用.来表示当前目录,用/来表示系统根目录

print:find命令将匹配的文件输出到标准输出

exec:find命令对匹配的文件执行该参数所给出的shell命令,相应命令的形式为'command' { } ;,注意{ }和;之间的空格

ok:和-exec的作用相同,只不过以一种更为安全的模式来执行该参数所给出的shell命令,在执行每一个命令之前,都会给出提示,让用户来确定是否执行

常用选项: -name:按照文件名查找文件

-perm:按照文件权限来查找文件

mtime -n +n:按照文件的更改时间来查找文件, - n表示文件更改时间距现在n天以内,+ n表示文件更改时间距现在n天以前

-newer file1 ! file2:查找更改时间比文件file1新但比文件file2旧的文件

-type:查找某一类型的文件,诸如:b - 块设备文件,d - 目录,c - 字符设备文件,p - 管道文件,l - 符号链接文件,f - 普通文件

-size n:[c] 查找文件长度为n块的文件,带有c时表示文件长度以字节计

-depth:在查找文件时,首先查找当前目录中的文件,然后再在其子目录中查找举例:查找当前目录下大小大于50M的文件,查找大小大于10K的文件

locate命令

locate命令其实是find -name的另一种写法,但是要比后者快得多,原因在于它不搜索具体目录,而是搜索一个数据库(/var/lib/locatedb),这个数据库中含有本地所有文件信息。Linux系统自动创建这个数据库,并且每天自动更新一次,所以使用locate命令查不到最新变动过的文件。为了避免这种情况,可以在使用locate之前,先使用updatedb命令,手动更新数据库。

命令格式:locate [选择参数] [样式]

命令参数:

-e:将排除在寻找的范围之外

-1:如果是1则启动安全模式,在安全模式下,使用者不会看到权限无法看到的档案。这会使速度减慢,因为 locate必须至实际的档案系统中取得档案的权限资料

-f:将特定的档案系统排除在外,例如我们没有到必要把proc档案系统中的档案放在资料库中

-q:安静模式,不会显示任何错误讯息

-n:至多显示 n个输出

-r:使用正规运算式 做寻找的条件

-o:指定资料库存的名称

-d:指定资料库的路径

-h:显示辅助讯息

-V:显示程式的版本讯息

whereis命令

whereis命令是定位可执行文件、源代码文件、帮助文件在文件系统中的位置。这些文件的属性应属于原始代码,二进制文件,或是帮助文件。whereis程序还具有搜索源代码、指定备用搜索路径和搜索不寻常项的能力。whereis命令只能用于程序名的搜索,而且只搜索二进制文件(参数-b)、man说明文件(参数-m)和源代码文件(参数-s)。如果省略参数,则返回所有信息。

命令格式:whereis [-bmsu] [BMS 目录名 -f ] 文件名

主要参数:

-b:定位可执行文件

-m:定位帮助文件

-s:定位源代码文件

-u:搜索默认路径下除可执行文件、源代码文件、帮助文件以外的其它文件

-B:指定搜索可执行文件的路径

-M:指定搜索帮助文件的路径

-S:指定搜索源代码文件的路径

which命令

which指令会在PATH变量指定的路径中,搜索某个系统命令的位置,并且返回第一个搜索结果。which是根据使用者所配置的PATH变量内的目录去搜寻可运行档的,所以,不同的PATH配置内容所找到的命令是不一样的。

命令格式:which 可执行文件名称

命令参数:

-n:指定文件名长度,指定的长度必须大于或等于所有文件中最长的文件名

-p:与-n参数相同,但此处的包括了文件的路径

-w:指定输出时栏位的宽度

-V:显示版本信息

sort命令

将文本文件内容加以排序。可针对文本文件的内容,以行为单位来排序。

参数:

m:将几个排序好的文件进行合并。

n:依照数值的大小排序

Linux Bash中,ls . | sort 命令的功能是(显示当前目录内容并排序)

du命令

显示目录或文件的大小。du会显示指定的目录或文件所占用的磁盘空间。

参数:

a:显示目录中个别文件的大小。

b:显示目录或文件大小时,以byte为单位。

c: 除了显示个别目录或文件的大小外,同时也显示所有目录或文件的总和

ls命令

显示指定工作目录下之内容(列出目前工作目录所含之档案及子目录)。

参数:

a:显示所有档案及目录

A:同 -a ,但不列出 "." (目前目录) 及 ".." (父目录)

t:将档案依建立时间之先后次序列出

列出目前工作目录下所有档案及目录;目录于名称后加 "/", 可执行档于名称后加 "" : ls -AF

Linux Bash中,把ls命令显示当前目录的结果存入ls.txt的命令输出重定向命令是(ls > ls.txt)

Vim常用命令总结

插入:

i:在当前光标处进行编辑

a:在光标后插入编辑

退出:

q!:强制退出,不保存

:q:退出

:wq!:强制保存并退出

:wq:保存并退出

:w <文件路径>:另存为

删除:

x:删除游标所在的字符

dd:删除整行

行间跳转:

nG(n Shift+g):光标移动到第n行

复制与粘贴:

nyy:复制光标所在及其后的整行共n行

p:代表粘贴至光标后

功能设定:

:set autoindent(ai):设置自动缩进

:set cindent(cin):设置C语言风格缩进

:set nu:以显示行号

GCC编译过程

预处理:gcc –E hello.c –o hello.i ;gcc –E调用cpp 产生预处理过的C原始程序

编译:gcc –S hello.i –o hello.s ;gcc –S调用ccl 产生汇编语言原始程序

汇编:gcc –c hello.s –o hello.o ;gcc -c 调用as 产生目标文件

链 接:gcc hello.o –o hello ;gcc -o 调用ld 产生可执行文件

运行: ./hello

静态库

静态库是一系列的目标文件(.o文件)的归档文件((lib+name).a文 件);链接阶段,选择静态库,后缀名为“.a”;选择动态库,后缀名为“.so”。

静态链接库的生成:gcc -c 文件名.c ar rcsv libxxx.a xxx.o

静态库的使用:gcc -o 文件名 文件名.c -L. -lxxx//链接到静态库

注意:

-L:在库文件的搜索路径列表中添加dir目录

-l:在头文件的搜索路径列表中添加dir目录

共享库

共享库的生成:

`gcc -fPIC -c xxx.c``

`gcc -shared -o libxxx.so xxx.o

共享库的使用:gcc -o main main.c -L. -lxxx

注册共享库的方法:将库文件直接复制到/lib或者/usr/lib目录下: cp (lib+name).so /lib

GDB调试

进入gdb:

gcc -g xxx.c -o xxx

gdb xxx

查看源码:

(gdb) l:进行行号提示

(gdb) b n:在第n行设置断点

(gdb) r:运行代码,运行至断点处

(gdb) n:单步运行

(gdb) c:使程序继续往下运行,直到再次遇到断点或程序结束

(gdb) q:退出GDB

(gdb) watch n:在"n"设置了观察点,观察变量的变化情况

四种断点:

函数断点:b 函数名 条件表达式

行断点:b 行数或函数名 条件表达式

条件断点:b 行数或函数名 if表达式

临时断点:tbreak 行数或函数名 条件表达式

makefile

功能:识别文件代码是否更新,减少编译工作量

格式为:

目标体:依赖文件

[tab键]各目标体运行命令

目标体:由make创建,通常是目标文件或可执行文件

依赖文件:创建目标体所依赖的文件

运行命令:创建每个目标体时需要的运行命令,必须以tab键开头。

使用make的格式:make 目标体

收获

收获其实挺多的,还好,慢慢研究吧,还有最近研究的openssl,安装调试完了,求hash,md5,sha1的值已经回了,接下来研究X509的协议,以及综合的例子,加油,嘻嘻。

原文地址:https://www.cnblogs.com/Jclemo/p/6036248.html