linux以及网络协议 HTTP状态码及其含义

ThinkPHP如何防止SQL注入?(理解)   
  
(1)查询条件尽量使用数组方式,这是更为安全的方式;

  (2)如果不得已必须使用字符串查询条件,使用预处理机制;

 

  (3)开启数据字段类型验证,可以对数值数据类型做强制转换;(3.1版本开始已经强制进行字段类型验证了)

 

  (4)使用自动验证和自动完成机制进行针对应用的自定义过滤;

 

  (5)使用字段类型检查、自动验证和自动完成机制等避免恶意数据的输入。

 

1. ls命令

ls命令是列出目录内容(List Directory Contents)的意思。运行它就是列出文件夹里的内容,可能是文件也可能是文件夹。

root@tecmint:~# ls

Android-Games                     Music
Pictures                          Public
Desktop                           Tecmint.com
Documents                         TecMint-Sync
Downloads                         Templates

“ls -l”命令以详情模式(long listing fashion)列出文件夹的内容。

root@tecmint:~# ls -l

total 40588
drwxrwxr-x 2 ravisaive ravisaive     4096 May  8 01:06 Android Games
drwxr-xr-x 2 ravisaive ravisaive     4096 May 15 10:50 Desktop
drwxr-xr-x 2 ravisaive ravisaive     4096 May 16 16:45 Documents
drwxr-xr-x 6 ravisaive ravisaive     4096 May 16 14:34 Downloads
drwxr-xr-x 2 ravisaive ravisaive     4096 Apr 30 20:50 Music
drwxr-xr-x 2 ravisaive ravisaive     4096 May  9 17:54 Pictures
drwxrwxr-x 5 ravisaive ravisaive     4096 May  3 18:44 Tecmint.com
drwxr-xr-x 2 ravisaive ravisaive     4096 Apr 30 20:50 Templates

"ls -a"命令会列出文件夹里的所有内容,包括以"."开头的隐藏文件。

root@tecmint:~# ls -a

.			.gnupg			.dbus			.goutputstream-PI5VVW		.mission-control
.adobe                  deja-dup                .grsync                 .mozilla                 	.themes
.gstreamer-0.10         .mtpaint                .thumbnails             .gtk-bookmarks          	.thunderbird
.HotShots               .mysql_history          .htaccess		.apport-ignore.xml      	.ICEauthority           
.profile                .bash_history           .icons                  .bash_logout                    .fbmessenger
.jedit                  .pulse                  .bashrc                 .liferea_1.8             	.pulse-cookie            
.Xauthority		.gconf                  .local                  .Xauthority.HGHVWW		.cache
.gftp                   .macromedia             .remmina                .cinnamon                       .gimp-2.8
.ssh                    .xsession-errors 	.compiz                 .gnome                          teamviewer_linux.deb          
.xsession-errors.old	.config                 .gnome2                 .zoncolor

注意:在Linux中,文件以“.”开头的就是隐藏文件,并且每个文件,文件夹,设备或者命令都是以文件对待。ls -l 命令输出:

  1. d (代表了是目录).
  2. rwxr-xr-x 是文件或者目录对所属用户,同一组用户和其它用户的权限。
  3. 上面例子中第一个ravisaive 代表了文件文件属于用户ravisaive
  4. 上面例子中的第二个ravisaive代表了文件文件属于用户组ravisaive
  5. 4096 代表了文件大小为4096字节.
  6. May 8 01:06 代表了文件最后一次修改的日期和时间.
  7. 最后面的就是文件/文件夹的名字


Linux下的tar压缩解压缩命令详解

tar

-c: 建立压缩档案
-x:解压
-t:查看内容
-r:向压缩归档文件末尾追加文件
-u:更新原压缩包中的文件

这五个是独立的命令,压缩解压都要用到其中一个,可以和别的命令连用但只能用其中一个。下面的参数是根据需要在压缩或解压档案时可选的。

-z:有gzip属性的
-j:有bz2属性的
-Z:有compress属性的
-v:显示所有过程
-O:将文件解开到标准输出

下面的参数-f是必须的

-f: 使用档案名字,切记,这个参数是最后一个参数,后面只能接档案名。

# tar -cf all.tar *.jpg
这条命令是将所有.jpg的文件打成一个名为all.tar的包。-c是表示产生新的包,-f指定包的文件名。

# tar -rf all.tar *.gif
这条命令是将所有.gif的文件增加到all.tar的包里面去。-r是表示增加文件的意思。

# tar -uf all.tar logo.gif
这条命令是更新原来tar包all.tar中logo.gif文件,-u是表示更新文件的意思。

# tar -tf all.tar
这条命令是列出all.tar包中所有文件,-t是列出文件的意思

# tar -xf all.tar
这条命令是解出all.tar包中所有文件,-t是解开的意思

压缩

tar -cvf jpg.tar *.jpg //将目录里所有jpg文件打包成tar.jpg 

tar -czf jpg.tar.gz *.jpg   //将目录里所有jpg文件打包成jpg.tar后,并且将其用gzip压缩,生成一个gzip压缩过的包,命名为jpg.tar.gz

 tar -cjf jpg.tar.bz2 *.jpg //将目录里所有jpg文件打包成jpg.tar后,并且将其用bzip2压缩,生成一个bzip2压缩过的包,命名为jpg.tar.bz2

tar -cZf jpg.tar.Z *.jpg   //将目录里所有jpg文件打包成jpg.tar后,并且将其用compress压缩,生成一个umcompress压缩过的包,命名为jpg.tar.Z

rar a jpg.rar *.jpg //rar格式的压缩,需要先下载rar for linux

zip jpg.zip *.jpg //zip格式的压缩,需要先下载zip for linux

解压

tar -xvf file.tar //解压 tar包

tar -xzvf file.tar.gz //解压tar.gz

tar -xjvf file.tar.bz2   //解压 tar.bz2

tar -xZvf file.tar.Z   //解压tar.Z

unrar e file.rar //解压rar

unzip file.zip //解压zip

总结

1、*.tar 用 tar -xvf 解压

2、*.gz 用 gzip -d或者gunzip 解压

3、*.tar.gz和*.tgz 用 tar -xzf 解压

4、*.bz2 用 bzip2 -d或者用bunzip2 解压

5、*.tar.bz2用tar -xjf 解压

6、*.Z 用 uncompress 解压

7、*.tar.Z 用tar -xZf 解压

8、*.rar 用 unrar e解压

9、*.zip 用 unzip 解压


查看网络服务和端口

netstat 命令用于显示各种网络相关信息,如网络连接,路由表,接口状态 (Interface Statistics),masquerade 连接,多播成员 (Multicast Memberships) 等等。

列出所有端口 (包括监听和未监听的):

netstat -a

列出所有 tcp 端口:

netstat -at

列出所有有监听的服务状态:

netstat -l

Linux查看端口是否被占用

1.netstat  -anp  |grep   端口号

如下,以3306为例,netstat  -anp  |grep  3306(此处备注下,我是以普通用户操作,故加上了sudo,如果是以root用户操作,不用加sudo即可查看),如下图1:

                                                                                     图1

图1中主要看监控状态为LISTEN表示已经被占用,最后一列显示被服务mysqld占用,查看具体端口号,只要有如图这一行就表示被占用了。

2.netstat   -nultp(此处不用加端口号)

该命令是查看当前所有已经使用的端口情况,如图2:

                                                                                       图2

图中可以看出我的82端口没有被占用

3.netstat  -anp  |grep  82查看82端口的使用情况,如图3:

                                                                                                                          图3

可以看出并没有LISTEN那一行,所以就表示没有被占用。此处注意,图中显示的LISTENING并不表示端口被占用,不要和LISTEN混淆哦,查看具体端口时候,必须要看到tcp,端口号,LISTEN那一行,才表示端口被占用了

列出所有端口 (包括监听和未监听的)

netstat -a     #列出所有端口
netstat -at    #列出所有tcp端口
netstat -au    #列出所有udp端口                             

列出所有处于监听状态的 Sockets

netstat -l        #只显示监听端口
netstat -lt       #只列出所有监听 tcp 端口
netstat -lu       #只列出所有监听 udp 端口
netstat -lx       #只列出所有监听 UNIX 端口

显示每个协议的统计信息

netstat -s   显示所有端口的统计信息
netstat -st   显示TCP端口的统计信息
netstat -su   显示UDP端口的统计信息

在netstat输出中显示 PID 和进程名称

netstat -pt


 CD


cd    进入用户主目录;
cd ~  进入用户主目录;
cd -  返回进入此目录之前所在的目录;
cd ..  返回上级目录(若当前目录为“/“,则执行完后还在“/";".."为上级目录的意思);
cd ../..  返回上两级目录;
cd !$  把上个命令的参数作为cd参数使用。


1、cd命令

这是一个非常基本,也是大家经常需要使用的命令,它用于切换当前目录,它的参数是要切换到的目录的路径,可以是绝对路径,也可以是相对路径。如:

[html]  view plain  copy
  1. cd /root/Docements # 切换到目录/root/Docements  
  2. cd ./path          # 切换到当前目录下的path目录中,“.”表示当前目录    
  3. cd ../path         # 切换到上层目录中的path目录中,“..”表示上一层目录  


2、ls命令

这是一个非常有用的查看文件与目录的命令,list之意,它的参数非常多,下面就列出一些我常用的参数吧,如下:

[html]  view plain  copy
  1. -l :列出长数据串,包含文件的属性与权限数据等  
  2. -a :列出全部的文件,连同隐藏文件(开头为.的文件)一起列出来(常用)  
  3. -d :仅列出目录本身,而不是列出目录的文件数据  
  4. -h :将文件容量以较易读的方式(GB,kB等)列出来  
  5. -R :连同子目录的内容一起列出(递归列出),等于该目录下的所有文件都会显示出来  

注:这些参数也可以组合使用,下面举两个例子:

[html]  view plain  copy
  1. ls -l #以长数据串的形式列出当前目录下的数据文件和目录  
  2. ls -lR #以长数据串的形式列出当前目录下的所有文件  


3、grep命令

该命令常用于分析一行的信息,若当中有我们所需要的信息,就将该行显示出来,该命令通常与管道命令一起使用,用于对一些命令的输出进行筛选加工等等,它的简单语法为

[html]  view plain  copy
  1. grep [-acinv] [--color=auto] '查找字符串' filename  

它的常用参数如下:

[html]  view plain  copy
  1. -a :将binary文件以text文件的方式查找数据  
  2. -c :计算找到‘查找字符串’的次数  
  3. -i :忽略大小写的区别,即把大小写视为相同  
  4. -v :反向选择,即显示出没有‘查找字符串’内容的那一行  
  5. # 例如:  
  6. # 取出文件/etc/man.config中包含MANPATH的行,并把找到的关键字加上颜色  
  7. grep --color=auto 'MANPATH' /etc/man.config  
  8. # 把ls -l的输出中包含字母file(不区分大小写)的内容输出  
  9. ls -l | grep -i file  


4、find命令

find是一个基于查找的功能非常强大的命令,相对而言,它的使用也相对较为复杂,参数也比较多,所以在这里将给把它们分类列出,它的基本语法如下:

[html]  view plain  copy
  1. find [PATH] [option] [action]  
  2.   
  3. # 与时间有关的参数:  
  4. -mtime n : n为数字,意思为在n天之前的“一天内”被更改过的文件;  
  5. -mtime +n : 列出在n天之前(不含n天本身)被更改过的文件名;  
  6. -mtime -n : 列出在n天之内(含n天本身)被更改过的文件名;  
  7. -newer file : 列出比file还要新的文件名  
  8. # 例如:  
  9. find /root -mtime 0 # 在当前目录下查找今天之内有改动的文件  
  10.   
  11. # 与用户或用户组名有关的参数:  
  12. -user name : 列出文件所有者为name的文件  
  13. -group name : 列出文件所属用户组为name的文件  
  14. -uid n : 列出文件所有者为用户ID为n的文件  
  15. -gid n : 列出文件所属用户组为用户组ID为n的文件  
  16. # 例如:  
  17. find /home/ljianhui -user ljianhui # 在目录/home/ljianhui中找出所有者为ljianhui的文件  
  18.   
  19. # 与文件权限及名称有关的参数:  
  20. -name filename :找出文件名为filename的文件  
  21. -size [+-]SIZE :找出比SIZE还要大(+)或小(-)的文件  
  22. -tpye TYPE :查找文件的类型为TYPE的文件,TYPE的值主要有:一般文件(f)、设备文件(b、c)、  
  23.              目录(d)、连接文件(l)、socket(s)、FIFO管道文件(p);  
  24. -perm mode :查找文件权限刚好等于mode的文件,mode用数字表示,如0755;  
  25. -perm -mode :查找文件权限必须要全部包括mode权限的文件,mode用数字表示  
  26. -perm +mode :查找文件权限包含任一mode的权限的文件,mode用数字表示  
  27. # 例如:  
  28. find / -name passwd # 查找文件名为passwd的文件  
  29. find . -perm 0755 # 查找当前目录中文件权限的0755的文件  
  30. find . -size +12k # 查找当前目录中大于12KB的文件,注意c表示byte  

5、cp命令

该命令用于复制文件,copy之意,它还可以把多个文件一次性地复制到一个目录下,它的常用参数如下: 

[html]  view plain  copy
  1. -a :将文件的特性一起复制  
  2. -p :连同文件的属性一起复制,而非使用默认方式,与-a相似,常用于备份  
  3. -i :若目标文件已经存在时,在覆盖时会先询问操作的进行  
  4. -r :递归持续复制,用于目录的复制行为  
  5. -u :目标文件与源文件有差异时才会复制  

例如 :

[html]  view plain  copy
  1. cp -a file1 file2 #连同文件的所有特性把文件file1复制成文件file2  
  2. cp file1 file2 file3 dir #把文件file1、file2、file3复制到目录dir中  


6、mv命令

该命令用于移动文件、目录或更名,move之意,它的常用参数如下:

[html]  view plain  copy
  1. -f :force强制的意思,如果目标文件已经存在,不会询问而直接覆盖  
  2. -i :若目标文件已经存在,就会询问是否覆盖  
  3. -u :若目标文件已经存在,且比目标文件新,才会更新  

注:该命令可以把一个文件或多个文件一次移动一个文件夹中,但是最后一个目标文件一定要是“目录”。


例如:

[html]  view plain  copy
  1. mv file1 file2 file3 dir # 把文件file1、file2、file3移动到目录dir中  
  2. mv file1 file2 # 把文件file1重命名为file2  


7、rm命令

该命令用于删除文件或目录,remove之间,它的常用参数如下:

[html]  view plain  copy
  1. -f :就是force的意思,忽略不存在的文件,不会出现警告消息  
  2. -i :互动模式,在删除前会询问用户是否操作  
  3. -r :递归删除,最常用于目录删除,它是一个非常危险的参数  


例如:

[html]  view plain  copy
  1. rm -i file # 删除文件file,在删除之前会询问是否进行该操作  
  2. rm -fr dir # 强制删除目录dir中的所有文件  

8、ps命令

该命令用于将某个时间点的进程运行情况选取下来并输出,process之意,它的常用参数如下:

[html]  view plain  copy
  1. -A :所有的进程均显示出来  
  2. -a :不与terminal有关的所有进程  
  3. -u :有效用户的相关进程  
  4. -x :一般与a参数一起使用,可列出较完整的信息  
  5. -l :较长,较详细地将PID的信息列出  

其实我们只要记住ps一般使用的命令参数搭配即可,它们并不多,如下:

[html]  view plain  copy
  1. ps aux # 查看系统所有的进程数据  
  2. ps ax # 查看不与terminal有关的所有进程  
  3. ps -lA # 查看系统所有的进程数据  
  4. ps axjf # 查看连同一部分进程树状态  


9、kill命令

该命令用于向某个工作(%jobnumber)或者是某个PID(数字)传送一个信号,它通常与ps和jobs命令一起使用,它的基本语法如下:

[html]  view plain  copy
  1. kill -signal PID  

signal的常用参数如下:

注:最前面的数字为信号的代号,使用时可以用代号代替相应的信号。

[html]  view plain  copy
  1. 1:SIGHUP,启动被终止的进程  
  2. 2:SIGINT,相当于输入ctrl+c,中断一个程序的进行  
  3. 9:SIGKILL,强制中断一个进程的进行  
  4. 15:SIGTERM,以正常的结束进程方式来终止进程  
  5. 17:SIGSTOP,相当于输入ctrl+z,暂停一个进程的进行  

例如:

[html]  view plain  copy
  1. # 以正常的结束进程方式来终于第一个后台工作,可用jobs命令查看后台中的第一个工作进程  
  2. kill -SIGTERM %1   
  3. # 重新改动进程ID为PID的进程,PID可用ps命令通过管道命令加上grep命令进行筛选获得  
  4. kill -SIGHUP PID  


10、killall命令

该命令用于向一个命令启动的进程发送一个信号,它的一般语法如下:

[html]  view plain  copy
  1. killall [-iIe] [command name]  


它的参数如下:

[html]  view plain  copy
  1. -i :交互式的意思,若需要删除时,会询问用户  
  2. -e :表示后面接的command name要一致,但command name不能超过15个字符  
  3. -I :命令名称忽略大小写  
  4. # 例如:  
  5. killall -SIGHUP syslogd # 重新启动syslogd  


11、file命令

该命令用于判断接在file命令后的文件的基本数据,因为在Linux下文件的类型并不是以后缀为分的,所以这个命令对我们来说就很有用了,它的用法非常简单,基本语法如下:

[html]  view plain  copy
  1. file filename  
  2. #例如:  
  3. file ./test  


12、tar命令

该命令用于对文件进行打包,默认情况并不会压缩,如果指定了相应的参数,它还会调用相应的压缩程序(如gzip和bzip等)进行压缩和解压。它的常用参数如下:

[html]  view plain  copy
  1. -c :新建打包文件  
  2. -t :查看打包文件的内容含有哪些文件名  
  3. -x :解打包或解压缩的功能,可以搭配-C(大写)指定解压的目录,注意-c,-t,-x不能同时出现在同一条命令中  
  4. -j :通过bzip2的支持进行压缩/解压缩  
  5. -z :通过gzip的支持进行压缩/解压缩  
  6. -v :在压缩/解压缩过程中,将正在处理的文件名显示出来  
  7. -f filename :filename为要处理的文件  
  8. -C dir :指定压缩/解压缩的目录dir  

但是通常我们只需要记住下面三条命令即可:

[html]  view plain  copy
  1. 压缩:tar -jcv -f filename.tar.bz2 要被处理的文件或目录名称  
  2. 查询:tar -jtv -f filename.tar.bz2  
  3. 解压:tar -jxv -f filename.tar.bz2 -C 欲解压缩的目录  

注:文件名并不定要以后缀tar.bz2结尾,这里主要是为了说明使用的压缩程序为bzip2



13、cat命令

该命令用于查看文本文件的内容,后接要查看的文件名,通常可用管道与more和less一起使用,从而可以一页页地查看数据。例如:

[html]  view plain  copy
  1. cat text | less # 查看text文件中的内容  
  2. # 注:这条命令也可以使用less text来代替  


14、chgrp命令

该命令用于改变文件所属用户组,它的使用非常简单,它的基本用法如下:

[html]  view plain  copy
  1. chgrp [-R] dirname/filename  
  2. -R :进行递归的持续对所有文件和子目录更改  
  3. # 例如:  
  4. chgrp users -R ./dir # 递归地把dir目录下中的所有文件和子目录下所有文件的用户组修改为users  


15、chown命令

该命令用于改变文件的所有者,与chgrp命令的使用方法相同,只是修改的文件属性不同,不再详述。



16、chmod命令

该命令用于改变文件的权限,一般的用法如下:

[html]  view plain  copy
  1. chmod [-R] xyz 文件或目录  
  2. -R:进行递归的持续更改,即连同子目录下的所有文件都会更改  

同时,chmod还可以使用u(user)、g(group)、o(other)、a(all)和+(加入)、-(删除)、=(设置)跟rwx搭配来对文件的权限进行更改。

[html]  view plain  copy
  1. # 例如:  
  2. chmod 0755 file # 把file的文件权限改变为-rxwr-xr-x  
  3. chmod g+w file # 向file的文件权限中加入用户组可写权限  


18、vim命令

该命令主要用于文本编辑,它接一个或多个文件名作为参数,如果文件存在就打开,如果文件不存在就以该文件名创建一个文件。vim是一个非常好用的文本编辑器,它里面有很多非常好用的命令,在这里不再多说。你可以从这里下载vim常用操作的详细说明。






1、cd命令

这是一个非常基本,也是大家经常需要使用的命令,它用于切换当前目录,它的参数是要切换到的目录的路径,可以是绝对路径,也可以是相对路径。如:

[html]  view plain  copy
  1. cd /root/Docements # 切换到目录/root/Docements  
  2. cd ./path          # 切换到当前目录下的path目录中,“.”表示当前目录    
  3. cd ../path         # 切换到上层目录中的path目录中,“..”表示上一层目录  


2、ls命令

这是一个非常有用的查看文件与目录的命令,list之意,它的参数非常多,下面就列出一些我常用的参数吧,如下:

[html]  view plain  copy
  1. -l :列出长数据串,包含文件的属性与权限数据等  
  2. -a :列出全部的文件,连同隐藏文件(开头为.的文件)一起列出来(常用)  
  3. -d :仅列出目录本身,而不是列出目录的文件数据  
  4. -h :将文件容量以较易读的方式(GB,kB等)列出来  
  5. -R :连同子目录的内容一起列出(递归列出),等于该目录下的所有文件都会显示出来  

注:这些参数也可以组合使用,下面举两个例子:

[html]  view plain  copy
  1. ls -l #以长数据串的形式列出当前目录下的数据文件和目录  
  2. ls -lR #以长数据串的形式列出当前目录下的所有文件  


3、grep命令

该命令常用于分析一行的信息,若当中有我们所需要的信息,就将该行显示出来,该命令通常与管道命令一起使用,用于对一些命令的输出进行筛选加工等等,它的简单语法为

[html]  view plain  copy
  1. grep [-acinv] [--color=auto] '查找字符串' filename  

它的常用参数如下:

[html]  view plain  copy
  1. -a :将binary文件以text文件的方式查找数据  
  2. -c :计算找到‘查找字符串’的次数  
  3. -i :忽略大小写的区别,即把大小写视为相同  
  4. -v :反向选择,即显示出没有‘查找字符串’内容的那一行  
  5. # 例如:  
  6. # 取出文件/etc/man.config中包含MANPATH的行,并把找到的关键字加上颜色  
  7. grep --color=auto 'MANPATH' /etc/man.config  
  8. # 把ls -l的输出中包含字母file(不区分大小写)的内容输出  
  9. ls -l | grep -i file  


4、find命令

find是一个基于查找的功能非常强大的命令,相对而言,它的使用也相对较为复杂,参数也比较多,所以在这里将给把它们分类列出,它的基本语法如下:

[html]  view plain  copy
  1. find [PATH] [option] [action]  
  2.   
  3. # 与时间有关的参数:  
  4. -mtime n : n为数字,意思为在n天之前的“一天内”被更改过的文件;  
  5. -mtime +n : 列出在n天之前(不含n天本身)被更改过的文件名;  
  6. -mtime -n : 列出在n天之内(含n天本身)被更改过的文件名;  
  7. -newer file : 列出比file还要新的文件名  
  8. # 例如:  
  9. find /root -mtime 0 # 在当前目录下查找今天之内有改动的文件  
  10.   
  11. # 与用户或用户组名有关的参数:  
  12. -user name : 列出文件所有者为name的文件  
  13. -group name : 列出文件所属用户组为name的文件  
  14. -uid n : 列出文件所有者为用户ID为n的文件  
  15. -gid n : 列出文件所属用户组为用户组ID为n的文件  
  16. # 例如:  
  17. find /home/ljianhui -user ljianhui # 在目录/home/ljianhui中找出所有者为ljianhui的文件  
  18.   
  19. # 与文件权限及名称有关的参数:  
  20. -name filename :找出文件名为filename的文件  
  21. -size [+-]SIZE :找出比SIZE还要大(+)或小(-)的文件  
  22. -tpye TYPE :查找文件的类型为TYPE的文件,TYPE的值主要有:一般文件(f)、设备文件(b、c)、  
  23.              目录(d)、连接文件(l)、socket(s)、FIFO管道文件(p);  
  24. -perm mode :查找文件权限刚好等于mode的文件,mode用数字表示,如0755;  
  25. -perm -mode :查找文件权限必须要全部包括mode权限的文件,mode用数字表示  
  26. -perm +mode :查找文件权限包含任一mode的权限的文件,mode用数字表示  
  27. # 例如:  
  28. find / -name passwd # 查找文件名为passwd的文件  
  29. find . -perm 0755 # 查找当前目录中文件权限的0755的文件  
  30. find . -size +12k # 查找当前目录中大于12KB的文件,注意c表示byte  

5、cp命令

该命令用于复制文件,copy之意,它还可以把多个文件一次性地复制到一个目录下,它的常用参数如下: 

[html]  view plain  copy
  1. -a :将文件的特性一起复制  
  2. -p :连同文件的属性一起复制,而非使用默认方式,与-a相似,常用于备份  
  3. -i :若目标文件已经存在时,在覆盖时会先询问操作的进行  
  4. -r :递归持续复制,用于目录的复制行为  
  5. -u :目标文件与源文件有差异时才会复制  

例如 :

[html]  view plain  copy
  1. cp -a file1 file2 #连同文件的所有特性把文件file1复制成文件file2  
  2. cp file1 file2 file3 dir #把文件file1、file2、file3复制到目录dir中  


6、mv命令

该命令用于移动文件、目录或更名,move之意,它的常用参数如下:

[html]  view plain  copy
  1. -f :force强制的意思,如果目标文件已经存在,不会询问而直接覆盖  
  2. -i :若目标文件已经存在,就会询问是否覆盖  
  3. -u :若目标文件已经存在,且比目标文件新,才会更新  

注:该命令可以把一个文件或多个文件一次移动一个文件夹中,但是最后一个目标文件一定要是“目录”。


例如:

[html]  view plain  copy
  1. mv file1 file2 file3 dir # 把文件file1、file2、file3移动到目录dir中  
  2. mv file1 file2 # 把文件file1重命名为file2  


7、rm命令

该命令用于删除文件或目录,remove之间,它的常用参数如下:

[html]  view plain  copy
  1. -f :就是force的意思,忽略不存在的文件,不会出现警告消息  
  2. -i :互动模式,在删除前会询问用户是否操作  
  3. -r :递归删除,最常用于目录删除,它是一个非常危险的参数  


例如:

[html]  view plain  copy
  1. rm -i file # 删除文件file,在删除之前会询问是否进行该操作  
  2. rm -fr dir # 强制删除目录dir中的所有文件  

8、ps命令

该命令用于将某个时间点的进程运行情况选取下来并输出,process之意,它的常用参数如下:

[html]  view plain  copy
  1. -A :所有的进程均显示出来  
  2. -a :不与terminal有关的所有进程  
  3. -u :有效用户的相关进程  
  4. -x :一般与a参数一起使用,可列出较完整的信息  
  5. -l :较长,较详细地将PID的信息列出  

其实我们只要记住ps一般使用的命令参数搭配即可,它们并不多,如下:

[html]  view plain  copy
  1. ps aux # 查看系统所有的进程数据  
  2. ps ax # 查看不与terminal有关的所有进程  
  3. ps -lA # 查看系统所有的进程数据  
  4. ps axjf # 查看连同一部分进程树状态  


9、kill命令

该命令用于向某个工作(%jobnumber)或者是某个PID(数字)传送一个信号,它通常与ps和jobs命令一起使用,它的基本语法如下:

[html]  view plain  copy
  1. kill -signal PID  

signal的常用参数如下:

注:最前面的数字为信号的代号,使用时可以用代号代替相应的信号。

[html]  view plain  copy
  1. 1:SIGHUP,启动被终止的进程  
  2. 2:SIGINT,相当于输入ctrl+c,中断一个程序的进行  
  3. 9:SIGKILL,强制中断一个进程的进行  
  4. 15:SIGTERM,以正常的结束进程方式来终止进程  
  5. 17:SIGSTOP,相当于输入ctrl+z,暂停一个进程的进行  

例如:

[html]  view plain  copy
  1. # 以正常的结束进程方式来终于第一个后台工作,可用jobs命令查看后台中的第一个工作进程  
  2. kill -SIGTERM %1   
  3. # 重新改动进程ID为PID的进程,PID可用ps命令通过管道命令加上grep命令进行筛选获得  
  4. kill -SIGHUP PID  


10、killall命令

该命令用于向一个命令启动的进程发送一个信号,它的一般语法如下:

[html]  view plain  copy
  1. killall [-iIe] [command name]  


它的参数如下:

[html]  view plain  copy
  1. -i :交互式的意思,若需要删除时,会询问用户  
  2. -e :表示后面接的command name要一致,但command name不能超过15个字符  
  3. -I :命令名称忽略大小写  
  4. # 例如:  
  5. killall -SIGHUP syslogd # 重新启动syslogd  


11、file命令

该命令用于判断接在file命令后的文件的基本数据,因为在Linux下文件的类型并不是以后缀为分的,所以这个命令对我们来说就很有用了,它的用法非常简单,基本语法如下:

[html]  view plain  copy
  1. file filename  
  2. #例如:  
  3. file ./test  


12、tar命令

该命令用于对文件进行打包,默认情况并不会压缩,如果指定了相应的参数,它还会调用相应的压缩程序(如gzip和bzip等)进行压缩和解压。它的常用参数如下:

[html]  view plain  copy
  1. -c :新建打包文件  
  2. -t :查看打包文件的内容含有哪些文件名  
  3. -x :解打包或解压缩的功能,可以搭配-C(大写)指定解压的目录,注意-c,-t,-x不能同时出现在同一条命令中  
  4. -j :通过bzip2的支持进行压缩/解压缩  
  5. -z :通过gzip的支持进行压缩/解压缩  
  6. -v :在压缩/解压缩过程中,将正在处理的文件名显示出来  
  7. -f filename :filename为要处理的文件  
  8. -C dir :指定压缩/解压缩的目录dir  


上面的解说可以已经让你晕过去了,但是通常我们只需要记住下面三条命令即可:

[html]  view plain  copy
  1. 压缩:tar -jcv -f filename.tar.bz2 要被处理的文件或目录名称  
  2. 查询:tar -jtv -f filename.tar.bz2  
  3. 解压:tar -jxv -f filename.tar.bz2 -C 欲解压缩的目录  

注:文件名并不定要以后缀tar.bz2结尾,这里主要是为了说明使用的压缩程序为bzip2



13、cat命令

该命令用于查看文本文件的内容,后接要查看的文件名,通常可用管道与more和less一起使用,从而可以一页页地查看数据。例如:

[html]  view plain  copy
  1. cat text | less # 查看text文件中的内容  
  2. # 注:这条命令也可以使用less text来代替  


14、chgrp命令

该命令用于改变文件所属用户组,它的使用非常简单,它的基本用法如下:

[html]  view plain  copy
  1. chgrp [-R] dirname/filename  
  2. -R :进行递归的持续对所有文件和子目录更改  
  3. # 例如:  
  4. chgrp users -R ./dir # 递归地把dir目录下中的所有文件和子目录下所有文件的用户组修改为users  


15、chown命令

该命令用于改变文件的所有者,与chgrp命令的使用方法相同,只是修改的文件属性不同,不再详述。



16、chmod命令

该命令用于改变文件的权限,一般的用法如下:

[html]  view plain  copy
  1. chmod [-R] xyz 文件或目录  
  2. -R:进行递归的持续更改,即连同子目录下的所有文件都会更改  

同时,chmod还可以使用u(user)、g(group)、o(other)、a(all)和+(加入)、-(删除)、=(设置)跟rwx搭配来对文件的权限进行更改。

[html]  view plain  copy
  1. # 例如:  
  2. chmod 0755 file # 把file的文件权限改变为-rxwr-xr-x  
  3. chmod g+w file # 向file的文件权限中加入用户组可写权限  


18、vim命令

该命令主要用于文本编辑,它接一个或多个文件名作为参数,如果文件存在就打开,如果文件不存在就以该文件名创建一个文件。vim是一个非常好用的文本编辑器,它里面有很多非常好用的命令,在这里不再多说。你可以从这里下载vim常用操作的详细说明。



19、gcc命令

对于一个用Linux开发C程序的人来说,这个命令就非常重要了,它用于把C语言的源程序文件,编译成可执行程序,由于g++的很多参数跟它非常相似,所以这里只介绍gcc的参数,它的常用参数如下:

[html]  view plain  copy
  1. -o :output之意,用于指定生成一个可执行文件的文件名  
  2. -c :用于把源文件生成目标文件(.o),并阻止编译器创建一个完整的程序  
  3. -I :增加编译时搜索头文件的路径  
  4. -L :增加编译时搜索静态连接库的路径  
  5. -S :把源文件生成汇编代码文件  
  6. -lm:表示标准库的目录中名为libm.a的函数库  
  7. -lpthread :连接NPTL实现的线程库  
  8. -std= :用于指定把使用的C语言的版本  
  9.   
  10. # 例如:  
  11. # 把源文件test.c按照c99标准编译成可执行程序test  
  12. gcc -o test test.c -lm -std=c99  
  13. #把源文件test.c转换为相应的汇编程序源文件test.s  
  14. gcc -S test.c  


20、time命令

该命令用于测算一个命令(即程序)的执行时间。它的使用非常简单,就像平时输入命令一样,不过在命令的前面加入一个time即可,例如:

[html]  view plain  copy
  1. time ./process  
  2. time ps aux  

在程序或命令运行结束后,在最后输出了三个时间,它们分别是:

user:用户CPU时间,命令执行完成花费的用户CPU时间,即命令在用户态中执行时间总和;

system:系统CPU时间,命令执行完成花费的系统CPU时间,即命令在核心态中执行时间总和;

real:实际时间,从command命令行开始执行到运行终止的消逝时间;



1.变量的引用 
PHP 的引用允许你用两个变量来指向同一个内容

    $a="ABC";
    $b =&$a;
    echo $a;//这里输出:ABC
    echo $b;//这里输出:ABC
    $b="EFG";
    echo $a;//这里$a的值变为EFG 所以输出EFG
    echo $b;//这里输出EFG
unset($a),$b依然不变


一、CSRF攻击原理

  CSRF是什么呢?CSRF全名是Cross-site request forgery,是一种对网站的恶意利用,CSRF比XSS更具危险性。想要深入理解CSRF的攻击特性我们有必要了解一下网站session的工作原理。 

  session我想大家都不陌生,无论你用.net或PHP开发过网站的都肯定用过session对象,然而session它是如何工作的呢?如果你不清楚请往下看。 
先问个小问题:如果我把浏览器的cookie禁用了,大家认为session还能正常工作吗? 

  答案是否定的,我在这边举个简单的例子帮助大家理解session。 
比如我买了一张高尔夫俱乐部的会员卡,俱乐部给了我一张带有卡号的会员卡。我能享受哪些权利(比如我是高级会员卡可以打19洞和后付费喝饮料,而初级会员卡只能在练习场挥杆)以及我的个人资料都是保存在高尔夫俱乐部的数据库里的。我每次去高尔夫俱乐部只需要出示这张高级会员卡,俱乐部就知道我是谁了,并且为我服务了。

  这里我们的高级会员卡卡号 = 保存在cookie的sessionid; 
而我的高级会员卡权利和个人信息就是服务端的session对象了。 

  我们知道http请求是无状态的,也就是说每次http请求都是独立的无关之前的操作的,但是每次http请求都会将本域下的所有cookie作为http请求头的一部分发送给服务端,所以服务端就根据请求中的cookie存放的sessionid去session对象中找到该会员资料了。 
当然session的保存方法多种多样,可以保存在文件中,也可以内存里,考虑到分布式的横向扩展我们还是建议把它保存在第三方媒介中,比如redis或者mongodb。 

  我们理解了session的工作机制后,CSRF也就很容易理解了。CSRF攻击就相当于恶意用户A复制了我的高级会员卡,哪天恶意用户A也可以拿着这张假冒的高级会员卡去高尔夫俱乐部打19洞,享受美味的饮料了,而我在月底就会收到高尔夫俱乐部的账单! 

  了解CSRF的机制之后,危害性我相信大家已经不言而喻了,我可以伪造某一个用户的身份给其好友发送垃圾信息,这些垃圾信息的超链接可能带有木马程序或者一些欺骗信息(比如借钱之类的),如果CSRF发送的垃圾信息还带有蠕虫链接的话,那些接收到这些有害信息的好友万一打开私信中的连接就也成为了有害信息的散播着,这样数以万计的用户被窃取了资料种植了木马。整个网站的应用就可能在瞬间奔溃,用户投诉,用户流失,公司声誉一落千丈甚至面临倒闭。曾经在MSN上,一个美国的19岁的小伙子Samy利用css的background漏洞几小时内让100多万用户成功的感染了他的蠕虫,虽然这个蠕虫并没有破坏整个应用,只是在每一个用户的签名后面都增加了一句“Samy 是我的偶像”,但是一旦这些漏洞被恶意用户利用,后果将不堪设想,同样的事情也曾经发生在新浪微博上面。 

  举例: 

  CSRF攻击的主要目的是让用户在不知情的情况下攻击自己已登录的一个系统,类似于钓鱼。如用户当前已经登录了邮箱,或bbs,同时用户又在使用另外一个,已经被你控制的站点,我们姑且叫它钓鱼网站。这个网站上面可能因为某个图片吸引你,你去点击一下,此时可能就会触发一个js的点击事件,构造一个bbs发帖的请求,去往你的bbs发帖,由于当前你的浏览器状态已经是登陆状态,所以session登陆cookie信息都会跟正常的请求一样,纯天然的利用当前的登陆状态,让用户在不知情的情况下,帮你发帖或干其他事情。

 

二、CSRF防御

  • 通过 referer、token 或者 验证码 来检测用户提交。
  • 尽量不要在页面的链接中暴露用户隐私信息。
  • 对于用户修改删除等操作最好都使用post 操作 。
  • 避免全站通用的cookie,严格设置cookie的域。


HTTP状态码及其含义

常见的HTTP 1.1状态代码以及它们对应的状态信息和含义
状态代码 状态信息 含义  

200 OK 一切正常,对GET和POST请求的应答文档跟在后面。 
201 Created 服务器已经创建了文档,Location头给出了它的URL。  
202 Accepted 已经接受请求,但处理尚未完成。  
204 No Content 没有新文档,浏览器应该继续显示原来的文档。如果用户定期地刷新页面,而Servlet可以确定用户文档足够新,这个状态代码是很有用的。  
205 Reset Content 没有新的内容,但浏览器应该重置它所显示的内容。用来强制浏览器清除表单输入内容(HTTP 1.1新)。    
301 Moved Permanently 客户请求的文档在其他地方,新的URL在Location头中给出,浏览器应该自动地访问新的URL。  
302 Found 类似于301,但新的URL应该被视为临时性的替代,而不是永久性的。注意,在HTTP1.0中对应的状态信息是“Moved Temporatily”。 

出现该状态代码时,浏览器能够自动访问新的URL,因此它是一个很有用的状态代码。 
注意这个状态代码有时候可以和301替换使用。例如,如果浏览器错误地请求http://host/~user(缺少了后面的斜杠),有的服务器返回301,有的则返回302。 
400 Bad Request 请求出现语法错误。  
401 Unauthorized 客户试图未经授权访问受密码保护的页面。应答中会包含一个WWW-Authenticate头,浏览器据此显示用户名字/密码对话框,然后在填写合适的Authorization头后再次发出请求。  
403 Forbidden 资源不可用。服务器理解客户的请求,但拒绝处理它。通常由于服务器上文件或目录的权限设置导致。  

404 Not Found 无法找到指定位置的资源。这也是一个常用的应答。  
405 Method Not Allowed 请求方法(GET、POST、HEAD、Delete、PUT、TRACE等)对指定的资源不适用。(HTTP 1.1新)  
500 Internal Server Error 服务器遇到了意料不到的情况,不能完成客户的请求。  
501 Not Implemented 服务器不支持实现请求所需要的功能。例如,客户发出了一个服务器不支持的PUT请求。  
502 Bad Gateway 服务器作为网关或者代理时,为了完成请求访问下一个服务器,但该服务器返回了非法的应答。  
503 Service Unavailable 服务器由于维护或者负载过重未能应答。例如,Servlet可能在数据库连接池已满的情况下返回503。服务器返回503时可以提供一个Retry-After头。  
504 Gateway Timeout 由作为代理或网关的服务器使用,表示不能及时地从远程服务器获得应答。(HTTP 1.1新)  
505 HTTP Version Not Supported 服务器不支持请求中所指明的HTTP版本。

echo、print、print_r的区别

echo    不是函数,没有返回值,仅用于打印信息,如果只是输出 echo 会更快
print   有返回值,是函数,还能格式化输出
print_r 则是打印复合类型如数组 对象


Redis中的有序集合是怎么实现的,它的数据结构是怎么样的

https://www.cnblogs.com/paulversion/p/8194966.html

 找出数组中不重复的值[1,2,3,3,2,1,5]

用 hash/桶 的思路
$res = [];
foreach ($data as $item) {
    if(array_key_exists($item, $res)) {
        ++$res[$item];
    } else {
        $res[$item] = 1;
    }
}

foreach ($res as $k=>$v) {
    if($v == 1) {
        echo $k;
    }

}

PHP的的这种弱类型变量是怎么实现的?

zval联合体

PHP中发起http请求有哪几种方式?它们有何区别?

curl
stream流的方式
socket方式
https://segmentfault.com/a/1190000010302052

有10亿条订单数据,属于1000个司机的,请取出订单量前20的司机

对方希望要的思路: 
1、先顺序读取10亿条数据,统计每个司机各点多少订单量
2、构建一个最大堆,顺序过滤1000个司机,找到前20个司机
伪代码:
$order_data = [];
foreach(10亿条订单 as $order_info) {
    if(isset($order_data[$order_info]) {
        $order_data[$order_info] ++;
    } else {
        $order_data[$order_info] = 1;
    }
}

$map = [];
foreach ($order_data as $num) {
    if (count($map) < 20) {
        $map[] = $num;
        continue;
    }
    $min = min($map);
    if ($num > $min) {
        for ($i = 0; $i < count($map); ++$i) {
            if ($map[$i] == $min) {
                $map[$i] = $num;    //将最小值替换
                break;  //跳出循环,只替换一次
            }
        }
    }
}

数据库

  • 什么是索引,作用是什么?常见索引类型有那些?Mysql 建立索引的原则?

索引是一种特殊的文件,它们包含着对数据表里所有记录的引用指针,相当于书本的目录。其作用就是加快数据的检索效率。常见索引类型有主键、唯一索引、复合索引、全文索引。

  • 索引创建的原则

    • 最左前缀原理
    • 选择区分度高的列作为索引
    • 尽量的扩展索引,不要新建索引
  • 高并发如何处理?
    • 使用缓存
    • 优化数据库,提升数据库使用效率
    • 负载均衡


常见的HTTP 1.1状态代码以及它们对应的状态信息和含义
状态代码 状态信息 含义  

200 OK 一切正常,对GET和POST请求的应答文档跟在后面。 
201 Created 服务器已经创建了文档,Location头给出了它的URL。  
202 Accepted 已经接受请求,但处理尚未完成。  
204 No Content 没有新文档,浏览器应该继续显示原来的文档。如果用户定期地刷新页面,而Servlet可以确定用户文档足够新,这个状态代码是很有用的。  
205 Reset Content 没有新的内容,但浏览器应该重置它所显示的内容。用来强制浏览器清除表单输入内容(HTTP 1.1新)。    
301 Moved Permanently 客户请求的文档在其他地方,新的URL在Location头中给出,浏览器应该自动地访问新的URL。  
302 Found 类似于301,但新的URL应该被视为临时性的替代,而不是永久性的。注意,在HTTP1.0中对应的状态信息是“Moved Temporatily”。 

出现该状态代码时,浏览器能够自动访问新的URL,因此它是一个很有用的状态代码。 
注意这个状态代码有时候可以和301替换使用。例如,如果浏览器错误地请求http://host/~user(缺少了后面的斜杠),有的服务器返回301,有的则返回302。 
400 Bad Request 请求出现语法错误。  
401 Unauthorized 客户试图未经授权访问受密码保护的页面。应答中会包含一个WWW-Authenticate头,浏览器据此显示用户名字/密码对话框,然后在填写合适的Authorization头后再次发出请求。  
403 Forbidden 资源不可用。服务器理解客户的请求,但拒绝处理它。通常由于服务器上文件或目录的权限设置导致。  

404 Not Found 无法找到指定位置的资源。这也是一个常用的应答。  
405 Method Not Allowed 请求方法(GET、POST、HEAD、Delete、PUT、TRACE等)对指定的资源不适用。(HTTP 1.1新)  
500 Internal Server Error 服务器遇到了意料不到的情况,不能完成客户的请求。  
501 Not Implemented 服务器不支持实现请求所需要的功能。例如,客户发出了一个服务器不支持的PUT请求。  
502 Bad Gateway 服务器作为网关或者代理时,为了完成请求访问下一个服务器,但该服务器返回了非法的应答。  
503 Service Unavailable 服务器由于维护或者负载过重未能应答。例如,Servlet可能在数据库连接池已满的情况下返回503。服务器返回503时可以提供一个Retry-After头。  
504 Gateway Timeout 由作为代理或网关的服务器使用,表示不能及时地从远程服务器获得应答。(HTTP 1.1新)  
505 HTTP Version Not Supported 服务器不支持请求中所指明的HTTP版本。

猜你喜欢

转载自blog.csdn.net/honkkki/article/details/80808407