回想起来当初多想接触程序,可是听了几次课或者演讲,发现是如此难受。想到得到100分的心+萌芽的环境+某些莫名其妙的感情,总是让我特别沉重。其实当时只要会几个实用工具就可以了,可是我什么都听不懂,听不懂所以也不想用,bad luck+不肯打开自己,唉总之算了不提了。
今天接触了nse脚本,回头再看linux命令,发现它们其实很美丽,但是要去记住它们却也不是必要的,捡几个适合的用就ok了。总之带着一种感慨与悲怆,-----我不知道,我还能这样几次。
ls -l
文件属性 目录内的文件数 用户(owner) 所属的group 文件大小 日期 文件名
属性:d目录,l是link 接下来三个权限分别是owner,所属组,和非onwer用户的。
另外,若执行部分不是X而是S表示该程序执行时可以临时拥有owner权力(对应chmod 4的部分)
id命令可以显示当前用户
中文显示的问题:
andriod用的是utf-8,所以要用chcp 65001(不填就是当前的,默认936),然后字体选lucida,然后最小最大刷新下。
chmod:正常格式是chmod uo +rw file.txt实际使用中常常是这样的,chmod 0777 file.txt其实都一回事,要注意的是o代表other
关于>跟|:前者就是输出,后者用于参数,比如ls -l | more,more命令可以用来显示文件内容,它就是将输入原封不动的显示,超出屏幕的话暂停下。
cat:这是个联合的简写,win api中对其简写是concat。该命令不光是可以连接起多个文件,而且对于输出的格式还有所动作,具体可参考 cat /data > file.img这条命令,它与copy是不一样的,是以bit by bit的方式对该区的完全拷贝(包括文件结构)相当于完成了win下的系统备份
./ 就是执行脚本
查看cpu构架,就是读proc/cpuinfo文件
ASHMEM(共享同一段物理内存) 是进入内核漏洞的一个重要的大门,现成的工具是psneuter,就是一个临时提权工具.还有个wpthis是mmc解锁用的
厂商发布的工具:rsd lite 和NVFlash和ODIN这些工具没有源码,文档也少。所以不适合。
用户发布的工具:image文件,这种文件对当时的状态、权限、文件内容、结构都作出了完美的复制。有时候这种image是提权的唯一方法。等同于win下所谓的重装系统。此时就要用到Fastboot。
Recovery Mode,就像所有的情况一样,这种Recovery Mode其实也已经进入操作系统了,只不过它更精简些。默认情况下到sd卡找update.zip并检查其签字是与厂商的匹配,然后更新并重启。有些还提供其他可选项,如清理数据,复位设置。这部分代码存于与非文件系统或者与非内存,一般来说若要改变,只能通过flash命令,现在也有直接安装的方式。/system分区就在这里,所谓“恢复出厂”,其实也无法影响这里。
实现类似工作的工具有RomManager,另外某些设备会自动加载更新文件,但是名字是特定的比如G05IMG.zip
著名的更新文件有ClockworkMod 和 Amon Ra
sd卡或usb引导盘工具,Win32DiskImager
常用命令转载如下:
ls
-a, �Call 列出目录下的所有文件,包括以 . 开头的隐含文件
-A 同-a,但不列出“.”(表示当前目录)和“..”(表示当前目录的父目录)。
-c 配合 -lt:根据 ctime 排序及显示 ctime (文件状态最后更改的时间)配合 -l:显示 ctime 但根据名称排序否则:根据 ctime 排序
-C 每栏由上至下列出项目
�Ccolor[=WHEN] 控制是否使用色彩分辨文件。WHEN 可以是'never'、'always'或'auto'其中之一
-d, �Cdirectory 将目录象文件一样显示,而不是显示其下的文件。
-D, �Cdired 产生适合 Emacs 的 dired 模式使用的结果
-f 对输出的文件不进行排序,-aU 选项生效,-lst 选项失效
-g 类似 -l,但不列出所有者
-G, �Cno-group 不列出任何有关组的信息
-h, �Chuman-readable 以容易理解的格式列出文件大小 (例如 1K 234M 2G)
�Csi 类似 -h,但文件大小取 1000 的次方而不是 1024
-H, �Cdereference-command-line 使用命令列中的符号链接指示的真正目的地
�Cindicator-style=方式 指定在每个项目名称后加上指示符号<方式>:none (默认),classify (-F),file-type (-p)
-i, �Cinode 印出每个文件的 inode 号
-I, �Cignore=样式 不印出任何符合 shell 万用字符<样式>的项目
-k 即 �Cblock-size=1K,以 k 字节的形式表示文件的大小。
-l 除了文件名之外,还将文件的权限、所有者、文件大小等信息详细列出来。
-L, �Cdereference 当显示符号链接的文件信息时,显示符号链接所指示的对象而并非符号链接本身的信息
-m 所有项目以逗号分隔,并填满整行行宽
-o 类似 -l,显示文件的除组信息外的详细信息。
-r, �Creverse 依相反次序排列
-R, �Crecursive 同时列出所有子目录层
-s, �Csize 以块大小为单位列出所有文件的大小
-S 根据文件大小排序
�Csort=WORD 以下是可选用的 WORD 和它们代表的相应选项:
extension -X status -c
none -U time -t
size -S atime -u
time -t access -u
version -v use -u
-t 以文件修改时间排序
-u 配合 -lt:显示访问时间而且依访问时间排序
配合 -l:显示访问时间但根据名称排序
否则:根据访问时间排序
-U 不进行排序;依文件系统原有的次序列出项目
-v 根据版本进行排序
-w, �Cwidth=COLS 自行指定屏幕宽度而不使用目前的数值
-x 逐行列出项目而不是逐栏列出
-X 根据扩展名排序
-1 每行只列出一个文件
�Chelp 显示此帮助信息并离开
�Cversion 显示版本信息并离开
4. 常用范例:
例一:列出/home/peidachang文件夹下的所有文件和目录的详细资料
命令:ls -l -R /home/peidachang
在使用 ls 命令时要注意命令的格式:在命令提示符后,首先是命令的关键字,接下来是命令参数,在命令参数之前要有一短横线“-”,所有的命令参数都有特定的作用,自己可以根据需要选用一个或者多个参数,在命令参数的后面是命令的操作对象。在以上这条命令“ ls -l -R /home/peidachang”中,“ls” 是命令关键字,“-l -R”是参数,“ /home/peidachang”是命令的操作对象。在这条命令中,使用到了两个参数,分别为“l”和“R”,当然,你也可以把他们放在一起使用,如下所示:
命令:ls -lR /home/peidachang
这种形式和上面的命令形式执行的结果是完全一样的。另外,如果命令的操作对象位于当前目录中,可以直接对操作对象进行操作;如果不在当前目录则需要给出操作对象的完整路径,例如上面的例子中,我的当前文件夹是peidachang文件夹,我想对home文件夹下的peidachang文件进行操作,我可以直接输入 ls -lR peidachang,也可以用 ls -lR /home/peidachang。
例二:列出当前目录中所有以“t”开头的目录的详细内容,可以使用如下命令:
命令:ls -l t*
可以查看当前目录下文件名以“t”开头的所有文件的信息。其实,在命令格式中,方括号内的内容都是可以省略的,对于命令ls而言,如果省略命令参数和操作对象,直接输入“ ls ”,则将会列出当前工作目录的内容清单。
例三:只列出文件下的子目录
命令:ls -F /opt/soft |grep /$
列出 /opt/soft 文件下面的子目录
输出:
[root@localhost opt]# ls -F /opt/soft |grep /$
jdk1.6.0_16/
subversion-1.6.1/
tomcat6.0.32/
命令:ls -l /opt/soft | grep "^d"
列出 /opt/soft 文件下面的子目录详细情况
输出:
[root@localhost opt]# ls -l /opt/soft | grep "^d"
drwxr-xr-x 10 root root 4096 09-17 18:17 jdk1.6.0_16
drwxr-xr-x 16 1016 1016 4096 10-11 03:25 subversion-1.6.1
drwxr-xr-x 9 root root 4096 2011-11-01 tomcat6.0.32
例四:列出目前工作目录下所有名称是s 开头的档案,愈新的排愈后面,可以使用如下命令:
命令:ls -ltr s*
输出:
[root@localhost opt]# ls -ltr s*
src:
总计 0
script:
总计 0
soft:
总计 350644
drwxr-xr-x 9 root root 4096 2011-11-01 tomcat6.0.32
-rwxr-xr-x 1 root root 81871260 09-17 18:15 jdk-6u16-linux-x64.bin
drwxr-xr-x 10 root root 4096 09-17 18:17 jdk1.6.0_16
-rw-r--r-- 1 root root 205831281 09-17 18:33 apache-tomcat-6.0.32.tar.gz
-rw-r--r-- 1 root root 5457684 09-21 00:23 tomcat6.0.32.tar.gz
-rw-r--r-- 1 root root 4726179 10-10 11:08 subversion-deps-1.6.1.tar.gz
-rw-r--r-- 1 root root 7501026 10-10 11:08 subversion-1.6.1.tar.gz
drwxr-xr-x 16 1016 1016 4096 10-11 03:25 subversion-1.6.1
例五:列出目前工作目录下所有档案及目录;目录于名称后加"/", 可执行档于名称后加"*"
命令:ls -AF
输出:
[root@localhost opt]# ls -AF
log/ script/ soft/ src/ svndata/ web/
例六:计算当前目录下的文件数和目录数
命令:
ls -l * |grep "^-"|wc -l ---文件个数
ls -l * |grep "^d"|wc -l ---目录个数
例七: 在ls中列出文件的绝对路径
命令:ls | sed "s:^:`pwd`/:"
输出:
[root@localhost opt]# ls | sed "s:^:`pwd`/:"
/opt/log
/opt/script
/opt/soft
/opt/src
/opt/svndata
/opt/web
例九:列出当前目录下的所有文件(包括隐藏文件)的绝对路径, 对目录不做递归
命令:find $PWD -maxdepth 1 | xargs ls -ld
输出:
[root@localhost opt]# find $PWD -maxdepth 1 | xargs ls -ld
drwxr-xr-x 8 root root 4096 10-11 03:43 /opt
drwxr-xr-x 2 root root 4096 2012-03-08 /opt/log
drwxr-xr-x 2 root root 4096 2012-03-08 /opt/script
drwxr-xr-x 5 root root 4096 10-11 03:21 /opt/soft
drwxr-xr-x 2 root root 4096 2012-03-08 /opt/src
drwxr-xr-x 4 root root 4096 10-11 05:22 /opt/svndata
drwxr-xr-x 4 root root 4096 10-09 00:45 /opt/web
例十:递归列出当前目录下的所有文件(包括隐藏文件)的绝对路径
命令: find $PWD | xargs ls -ld
例十一:指定文件时间输出格式
命令:
ls -tl --time-style=full-iso
输出:
[root@localhost soft]# ls -tl --time-style=full-iso
总计 350644
drwxr-xr-x 16 1016 1016 4096 2012-10-11 03:25:58.000000000 +0800 subversion-1.6.1
ls -ctl --time-style=long-iso
输出:
[root@localhost soft]# ls -ctl --time-style=long-iso
总计 350644
drwxr-xr-x 16 1016 1016 4096 2012-10-11 03:25 subversion-1.6.1
扩展:
1. 显示彩色目录列表
打开/etc/bashrc, 加入如下一行:
alias ls="ls --color"
下次启动bash时就可以像在Slackware里那样显示彩色的目录列表了, 其中颜色的含义如下:
1. 蓝色-->目录
2. 绿色-->可执行文件
3. 红色-->压缩文件
4. 浅蓝色-->链接文件
5. 灰色-->其他文件