Linux--安全加固02
目录:
1.BIOS
2.SSH安全
3.禁用telnet
4.禁用代码编译
5.ProFTP
6.TCPwrappers
7.创建一个SU组
8.root通知
9.history安全
10.欢迎信息
11.禁用所有特殊账户
12.chmod危险文件
13.指定允许root登陆的TTY设备
14.选择一个安全的密码
15.检查Rootkit
16.安装补丁
17.隐藏Apache信息
18.隐藏php信息
19.关闭不使用的服务
20.检测监听中的端口
21.关闭打开的端口和服务
22.删除不用的rpm包
23.禁用危险的php函数
24.安装配置防火墙
25.安装和配置BFD
26.内核加固(sysctl.conf)
27.更改SSH端口
28./tmp /var/tmp,/dev/shm分区安全
29.PHP IDS
总结
========================================================================
介绍
这个教程将一步步的指引你,使你的Linux系统变得安全。
任何默认安装的操作系统都是不够安全的,本文将指引你如何建立一个
相对安全的Linux系统。
========================================================================
1.BIOS
你应该总是在系统启动的时候设置一个BIOS密码和禁用从CD-ROM和软盘引导。
这将防止一些人未经允许访问你的系统和更改BIOS设置
2.SSH安全
SSH是一个协议,利用它可以登录到一个远程系统或远程执行系统命令,
默认允许root登录,并且sshv1存在缺陷,我们应该在
sshd_config禁止root访问和使用sshv2来让ssh更加安全。
方法:
- vi /etc/ssh/sshd_config
把协议改为2
- PermitRootLogin = no
重启
- sshd /etc/rc.d/init.d/sshd restart
3.禁用telnet
早期的Linux默认开启telnet服务,telnet,ftp,rlogin都是明文传输的协议
是容易被嗅探到的,这就是为什么推荐使用安全的版本(sftp,scp,ssh)的原因
如果你必须要使用telnet,那么至少应该隐藏banner信息
方法:
修改
- /etc/xinetd.d/telnet
- disable=yes
4.禁用代码编译
你可以禁用代码编译并且只把编译的权限分配给一个用户组
方法:
添加编译用户组
- /usr/sbin/groupadd compiler ,cd /usr/bin
把常见的编译器所属组赋给编译用户组
- chgrp compiler *cc*
- chgrp compiler *++*
- chgrp compiler ld
- chgrp compiler as
设置mysqlaccess的访问
- chgrp root mysqlaccess
设置权限
- chmod 750 *cc*
- chmod 750 *++*
- chmod 750 ld
- chmod 750 as
- chmod 755 mysqlaccess
把用户添加到组里
修改/etc/group
- compiler:x:520:user1,user2
5.ProFTP
你可以通过修改proftpd.conf来禁止root登陆
方法:
修改/etc/proftpd.conf
- Add RootLogin off
重启
- proftpd /sbin/service proftpd stop
- /sbin/service proftpd start
6.TCP wrappers
编辑hosts.allow和hosts.deny可以限制或允许访问inet服务
方法:
限制访问inet服务
修改/etc/hosts.allow
建议格式:
- #Approved IP addresses
- ALL:192.168.0.1
- ALL:192.168.5.2
- #CSV uploader machine
- proftpd:10.0.0.5
- #pop3 from antwhere
- ipop3:ALL
修改/etc/hosts.deny
- ALL:ALL EXCEPT localhostENY
7.创建SU用户组
因为我们在SSH禁止了root用户访问并且禁用了telnet,所有我们应该
分配给一些用户su权限来获取root特权
方法:
vi /etc/group
添加一行 wheel:x:10:root,user1,user2
- chgrp wheel /bin/su
- chmod o-rwx /bin/su
8.root通知
当一个具有root权限的用户登录的时候发mail
方法:
编辑/root下的.bashrc ,当有root权限的用户登录时发生email通知
- echo ‘ALERT ? Root Shell Access (Server Name) on:’ `date` `who` | mail -s “Alert: Root Access from `who | cut -d”(” -f2 | cut -d”)” -f1`” your@email.com
9.history安全
这是一个避免删除.bash_history或重定向到/dev/null的好主意
因此他不能清除或删除他最后执行的命令
方法:
- chattr +a .bash_history
- chattr +i .bash_history
获取用户的人会知道他的历史命令锁定并且要同意才可以使用服务
10.使用欢迎信息
你必须提供一些信息让攻击者知道该系统不对公众开放。
在国外有类似案件,攻击者入侵一个系统并且系统没有这些信息,
这种情况下法院不能做任何裁决,因为系统说welcome
方法:
删除/etc/redhat-release
编辑/etc/issue /etc/motd并显示警告信息
11.禁用所有特殊账户
你应该从系统中删除所有默认用户和组
例如news,lp,sync,shutdown,uucp,games,halt 等
方法:
删除账户userdel name
删除组 groupdel name
锁定特定账户:
- /usr/sbin/usermod -L -s /bin/false user
12.chmod危险文件
这可能是限制不具有root权限的用户执行下面这些命令的好主意
方法:
- chmod 700 /bin/ping
- chmod 700 /usr/bin/finger
- chmod 700 /usr/bin/who
- chmod 700 /usr/bin/w
- chmod 700 /usr/bin/locate
- chmod 700 /usr/bin/whereis
- chmod 700 /sbin/ifconfig
- chmod 700 /usr/bin/pico
- chmod 700 /usr/bin/vi
- chmod 700 /usr/bin/which
- chmod 700 /usr/bin/gcc
- chmod 700 /usr/bin/make
- chmod 700 /bin/rpm
13.指定允许root登陆的TTY设备
/etc/securetty文件允许你指定root可以从哪个TTY设备登录
方法:
- vi /etc/securetty
只留2个连接
- tty1
- tty2
14.选择一个安全的密码
在/etc/login.defs文件中定义了shadow密码的具体配置
默认密码长度最短为5字符,你应该至少设置为8
方法:
- vi /etc/login.defs
- PASS_MIN_LEN 8
15.检测Rootkit
用chkrootkit或rkhunter,以chkrootkit为例
方法:
- wget ftp://ftp.pangeia.com.br/pub/seg/pac/chkrootkit.tar.gz
- wget ftp://ftp.pangeia.com.br/pub/seg/pac/chkrootkit.md5
首先检查md5校验值: md5sum chkrootkit.tar.gz
然后解压安装
- tar -zxvf chkrootkit.tar.gz
- cd chkrootkit
- ./configure
- make sense
然后运行./chkrootkit
我们可以将其添加到contrab使其每天自动扫描:
- vi /etc/cron.daily/chkrootkit.sh
#!/bin/bash
# 输入chkrootkit的安装目录
- cd /root/chkrootkit/
# 输入你想收到检测报告的email
- ./chkrootkit | mail -s “Daily chkrootkit from Server Name” your@email.com
16.安装补丁
你要经常检查更新以修复某些缺陷或系统稳定性的改进
否则你存在漏洞的系统将会不时的遭受新的攻击
方法:
- 列出可用更新:up2date -l
- 安装未排除的更新:up2date -u
- 安装包括排除的更新up2date -uf
17.隐藏Apache信息
你应该隐藏Apache的banner信息使攻击者不知道Apache的版本,从而使他们难以利用漏洞
方法:
修改/etc/httpd/conf/httpd.conf
改变服务器签名:
- ServerSignature Off
重启Apache /sbin/service httpd restart
18.隐藏php信息
你应该隐藏php的banner信息,原因同上
方法:
修改php.ini
改变
- expose_php=Off
重启Apache
19.关闭不用的服务
你应该把任何未使用的服务关闭,可以在/etc/xinetd.d文件夹里找到
方法:
- cd /etc/xinetd.d
- grep disable *
这将显示所有服务开启或关闭的状态,然后根据需要来开启或关闭服务
20.检测监听的端口
检测是否有必要开放端口是非常重要的
方法:
- netstat -tulp或
- lsof -i -n | egrep ‘COMMAND|LISTEN|UDP’或
- nmap!
21.关闭端口和服务
重点是关闭在系统启动时打开的不需要的端口
方法:
对于正在运行的服务,可以执行chkconfig -list | grep on
禁用服务可以执行chkconfig servicename off
然后停止正在运行的服务:/etc/init.d/service stop
22.删除不用的rpm包
首先应该清楚你的系统的作用,它是web,mail,file服务器或其他
然后觉得哪些包是必要的,之后删除不需要的软件包
方法:
首先列出安装列表rpm -qa
更详细的信息rpm -qi rpmname
还可以检测删除包可能出现的冲突rpm -e ?test rpmname
23.禁用危险的php函数
你应该禁用php的危险函数防止在网站上执行系统命令
方法:
- whereis php.ini
- vi /usr/local/lib/php.ini
编辑
- disable_functions = “symlink,shell_exec,exec,proc_close,proc_open,popen,
- system,dl,passthru,escapeshellarg, escapeshellcmd”
24.安装配置防火墙
高级策略防火墙(APF)是一种IP表(网络过滤),它是基于当今互联网部署服务器防火墙系统的基本需要和客户部署LINUX安装的唯一需要而设计的。 它是最好的开源防
火墙之一。
配置APF防火墙方法:
下载APF:wget http://www.r-fx.ca/downloads/apf-current.tar.gz
解压安装:
- tar -zxvf apf-current.tar.gz
- cd apf-0.9.7-1
- ./install.sh
然后我们配置它vi /etc/apf/conf.apf
一般配置:
启用防火墙使用DShield.org块列表
USE_DS=”1″
然后我将列出常规的配置和CPanel配置方式,因为CPanel是应该最广泛的虚拟主机管理软件
1.常规配置(DNS,Mail,Web,FTP)
- Common ingress (inbound)
- # Common ingress (inbound) TCP ports -3000_3500 = passive port range for Pure FTPD IG_TCP_CPORTS=”21,22,25,53,80,110,143,443,995″
- #
- # Common ingress (inbound) UDP ports IG_UDP_CPORTS=”53″
- # Egress filtering [0 = Disabled / 1 = Enabled]
- EGF=”1″
- # Common egress (outbound) TCP ports
- EG_TCP_CPORTS=”21,25,80,443,43″
- #
- # Common egress (outbound) UDP ports
- EG_UDP_CPORTS=”20,21,53″
- 2.CPanel配置
- Common ingress (inbound) ports
- # Common ingress (inbound) TCP ports -3000_3500 = passive port range for Pure FTPD IG_TCP_CPORTS=”21,22,25,53,80,110,143,443,2082,2083, 2086,2087,
- 2095, 2096,3000_3500″
- #
- # Common ingress (inbound) UDP ports
- IG_UDP_CPORTS=”53″
- Common egress (outbound) ports
- # Egress filtering [0 = Disabled / 1 = Enabled]
- EGF=”1″
- # Common egress (outbound) TCP ports
- EG_TCP_CPORTS=”21,25,80,443,43,2089″
- #
- # Common egress (outbound) UDP ports
- EG_UDP_CPORTS=”20,21,53″
之后启动防火墙 /etc/apf/apf -s
如果运行良好我在回去修改配置文件,使DEVM=”0″
然后我们配置APF的AntiDos: vi /etc/apf/ad/conf.antidos
找到下面的内容并替换成你的资料
- # Organization name to display on outgoing alert emails
- CONAME=”Your Company”
- # Send out user defined attack alerts [0=off,1=on]
- USR_ALERT=”0″
- #
- # User for alerts to be mailed to
- USR=you@yourco.com
你应把USR_ALERT改为1
保存后重启APF:/etc/apf/apf ?r
- To make the firewall start with the Operating System: chkconfig ?level 2345 apf on
APF开机自启动:chkconfig ?level 2345 apf on
禁止一个IP用/etc/apf/apf -d ip或vi /etc/apf/deny_hosts.rules
允许一个IP用/etc/apf/apf -a ip或vi /etc/apf/deny_hosts.rules
25.安装配置BFD(暴力破解检测)
BFD是一个用于分析应用日志和检测验证失败的模块化shell脚本
而且安装配置和用法都是非常容易的。使用BFD的原因很简单。
其实在LINUX领域几乎没有结合防火墙或实时设备来监控不验证和
暴力攻击审计的程序。在用BFD之前你必须安装APF防火墙。
方法:
- wget http://www.r-fx.ca/downloads/bfd-current.tar.gz
- tar -zxvf bfd-current.tar.gz
- cd bfd-0.9
然后我们来配置它 vi /usr/local/bfd/conf.bfd
把以下内容改为你的资料
- # Enable/disable user alerts [0 = off; 1 = on]
- ALERT_USR=”1″
- #
- # User alert email address
- EMAIL_USR=”your@mail.com”
- #
- # User alert email; subject
- SUBJ_USR=”Brute Force Warning for $HOSTNAME”
- #
然后vi /usr/local/bfd/ignore.hosts
把你的IP设置成允许主机,避免意外的锁定自己。
之后重启BFD /usr/local/sbin/bfd -s
26.内核加固(sysctl.conf)
sysctl.conf用来加固内核,目的是避免DOS和欺骗攻击
方法:
到/proc/sys目录或sysctl -a命令了解下当前配置的大概情况
然后vi /etc/sysctl.conf
添加如下内容:
- # Kernel sysctl configuration file for Red Hat Linux
- #
- # For binary values, 0 is disabled, 1 is enabled. See sysctl(8) and
- # sysctl.conf(5) for more details.
- # Controls IP packet forwarding
- net.ipv4.ip_forward = 0
- # Controls source route verification
- net.ipv4.conf.default.rp_filter = 1
- # Controls the System Request debugging functionality of the kernel
- kernel.sysrq = 0
- # Controls whether core dumps will append the PID to the core filename.
- # Useful for debugging multi-threaded applications.
- kernel.core_uses_pid = 1
- #Prevent SYN attack
- net.ipv4.tcp_syncookies = 1
- net.ipv4.tcp_max_syn_backlog = 2048
- net.ipv4.tcp_synack_retries = 2
- # Disables packet forwarding
- net.ipv4.ip_forward=0
- # Disables IP source routing
- net.ipv4.conf.all.accept_source_route = 0
- net.ipv4.conf.lo.accept_source_route = 0
- net.ipv4.conf.eth0.accept_source_route = 0
- net.ipv4.conf.default.accept_source_route = 0
- # Enable IP spoofing protection, turn on source route verification
- net.ipv4.conf.all.rp_filter = 1
- net.ipv4.conf.lo.rp_filter = 1
- net.ipv4.conf.eth0.rp_filter = 1
- net.ipv4.conf.default.rp_filter = 1
- # Disable ICMP Redirect Acceptance
- net.ipv4.conf.all.accept_redirects = 0
- net.ipv4.conf.lo.accept_redirects = 0
- net.ipv4.conf.eth0.accept_redirects = 0
- net.ipv4.conf.default.accept_redirects = 0
- # Enable Log Spoofed Packets, Source Routed Packets, Redirect Packets
- net.ipv4.conf.all.log_martians = 1
- net.ipv4.conf.lo.log_martians = 1
- net.ipv4.conf.eth0.log_martians = 1
- # Disables IP source routing
- net.ipv4.conf.all.accept_source_route = 0
- net.ipv4.conf.lo.accept_source_route = 0
- net.ipv4.conf.eth0.accept_source_route = 0
- net.ipv4.conf.default.accept_source_route = 0
- # Enable IP spoofing protection, turn on source route verification
- net.ipv4.conf.all.rp_filter = 1
- net.ipv4.conf.lo.rp_filter = 1
- net.ipv4.conf.eth0.rp_filter = 1
- 14
- net.ipv4.conf.default.rp_filter = 1
- # Disable ICMP Redirect Acceptance
- net.ipv4.conf.all.accept_redirects = 0
- net.ipv4.conf.lo.accept_redirects = 0
- net.ipv4.conf.eth0.accept_redirects = 0
- net.ipv4.conf.default.accept_redirects = 0
- # Disables the magic-sysrq key
- kernel.sysrq = 0
- # Modify system limits for Ensim WEBppliance
- fs.file-max = 65000
- # Decrease the time default value for tcp_fin_timeout connection
- net.ipv4.tcp_fin_timeout = 15
- # Decrease the time default value for tcp_keepalive_time connection
- net.ipv4.tcp_keepalive_time = 1800
- # Turn off the tcp_window_scaling
- net.ipv4.tcp_window_scaling = 0
- # Turn off the tcp_sack
- net.ipv4.tcp_sack = 0
- # Turn off the tcp_timestamps
- net.ipv4.tcp_timestamps = 0
- # Enable TCP SYN Cookie Protection
- net.ipv4.tcp_syncookies = 1
- # Enable ignoring broadcasts request
- net.ipv4.icmp_echo_ignore_broadcasts = 1
- # Enable bad error message Protection
- net.ipv4.icmp_ignore_bogus_error_responses = 1
- # Log Spoofed Packets, Source Routed Packets, Redirect Packets
- net.ipv4.conf.all.log_martians = 1
- # Set maximum amount of memory allocated to shm to 256MB
- kernel.shmmax = 268435456
- # Improve file system performance
- vm.bdflush = 100 1200 128 512 15 5000 500 1884 2
- # Improve virtual memory performance
- vm.buffermem = 90 10 60
- # Increases the size of the socket queue (effectively, q0).
- net.ipv4.tcp_max_syn_backlog = 1024
- # Increase the maximum total TCP buffer-space allocatable
- net.ipv4.tcp_mem = 57344 57344 65536
- # Increase the maximum TCP write-buffer-space allocatable
- net.ipv4.tcp_wmem = 32768 65536 524288
- 15
- # Increase the maximum TCP read-buffer space allocatable
- net.ipv4.tcp_rmem = 98304 196608 1572864
- # Increase the maximum and default receive socket buffer size
- net.core.rmem_max = 524280
- net.core.rmem_default = 524280
- # Increase the maximum and default send socket buffer size
- net.core.wmem_max = 524280
- net.core.wmem_default = 524280
- # Increase the tcp-time-wait buckets pool size
- net.ipv4.tcp_max_tw_buckets = 1440000
- # Allowed local port range
- net.ipv4.ip_local_port_range = 16384 65536
- # Increase the maximum memory used to reassemble IP fragments
- net.ipv4.ipfrag_high_thresh = 512000
- net.ipv4.ipfrag_low_thresh = 446464
- # Increase the maximum amount of option memory buffers
- net.core.optmem_max = 57344
- # Increase the maximum number of skb-heads to be cached
- net.core.hot_list_length = 1024
- ## DO NOT REMOVE THE FOLLOWING LINE!
- ## nsobuild:20051206
重启后生效
/sbin/sysctl -p
- sysctl -w net.ipv4.route.flush=1
27.更改SSH端口
更改SSH默认端口号在一定程度上可以提高安全性
方法:
vi /etc/ssh/sshd_config
Port 22改为其他端口
当然不要忘记把更改的端口加进防火墙
然后重启生效/etc/init.d/ssh restart
如果安装了APF并把端口添加之后,还要重启APF:/etc/init.d/apf restart
28./tmp,/var/tmp,/dev/shm分区的安全
/tmp,/var/tmp,/dev/shm目录是不安全的,任何用户都可以执行脚本。
最好的解决办法是挂载ncexec和nosuid选项的参数
注意:不建议在CPanel使用
方法:
/tmp目录:
cd /dev
创建 100M (“count”) 的存储文件:
dd if=/dev/zero of=tmpMnt bs=1024 count=100000
设为一个扩展的文件系统:
- /sbin/mke2fs /dev/tmpMnt (“…is not a block special device. continue?”回答yes)
备份现有临时文件:
- cp -R /tmp/ /tmp_backup
用noexec挂载新文件系统:
- mount -o loop,rw,nosuid,noexec /dev/tmpMnt /tmp
- chmod 0777 /tmp
把备份的文件拷贝回去:
- cp -R /tmp_backup/* /tmp/
删除备份:
- rm -rf /tmp_backup
修改/etc/fstab 添加下面的条目使其在引导时仍然有效
- /dev/tmpMnt /tmp ext2 loop,rw,nosuid,noexec 0 0
/var/tmp目录:
- mv /var/tmp /var/tmpbak
- ln -s /tmp /var/tmp
- cp /var/tmpbak/* /tmp/
/dev/shm目录:
编辑/etc/fstab
把 none /dev/shm tmpfs defaults,rw 0 0
改为
- none /dev/shm tmpfs defaults,nosuid,noexec,rw 0 0
1.限制使用su的用户并合理利用sudo:
vi /etc/pam.d/su,添加auth required /lib/security/$ISA/pam_wheel.so group=wheel行,
用命令“usermod -G 10 <用户名>”来添加允许使用su的用户
合理利用sudo大家可以查看资料,也可以有人整理专题讨论。
2.禁止root使用ssh远程登入:
vi /etc/ssh/sshd_config,找到#PermitRootLogin yes 改成?> PermitRootLogin no,重启ssh服务
3.给重要文件加锁,拒绝修改:
# chattr +i /etc/passwd
# chattr +i /etc/shadow
4.删除大部分不必要帐号,取消帐号中不必要的shell。
如下帐号可被删除:
adm,lp,sync,shutdown,halt,mail,news,uucp,operator,games,gopher,ftp,rpm,nscd,rpc,
rpcuser,nfsnobody,mailnull,smmsp,pcap,xfs,ntp
如果要使用KDE之类的图形窗口,则有些帐号如rpc,xfs是需要的。
文件系统权限
1) 找出系统中所有含s"位的程序,把不必要的"s"位去掉,或者把根本不用的直接删除,这样可以防止用户滥用及提升权限的可能性,其命令如下:
find / -type f -perm -4000 -o -perm -2000 -print | xargs ls -lg
2) 把重要文件加上不可改变属性(一般情况不用这么做):
chattr +i /etc/passwd
Immutable,系统不允许对这个文件进行任何的修改。如果目录具有这个属性,那么任何的进程只能修改目录之下的文件,不允许建立和删除文件。
3) 找出系统中没有属主的文件:
find / -nouser -o -nogroup
4) 找出任何都有写权限的文件和目录:
find / -type f -perm -2 -o -perm -20 |xargs ls -lg
find / -type d -perm -2 -o -perm -20 |xargs ls -ldg
5) Suid及sgid文件检查:
执行如下命令:
find / -user root -perm -4000 -print -exec md5sum {} \;
find / -user root -perm -2000 -print -exec md5sum {} \;
将结果重定向到一个文件,保存起来以后备查。
Banner伪装
1)系统banner
2)各服WEB服务软件banner伪装及隐藏。
Linux--安全加固02的更多相关文章
- linux安全加固浅谈
难易程度:★★★阅读点:linux;python;web安全;文章作者:xiaoye文章来源:i春秋关键字:网络渗透技术 前言linux被越来越多的企业使用,因此掌握一些基本的linux安全加固是有必 ...
- Linux NIO 系列(02) 阻塞式 IO
目录 一.环境准备 1.1 代码演示 二.Socket 是什么 2.1 socket 套接字 2.2 套接字描述符 2.3 文件描述符和文件指针的区别 三.基本的 SOCKET 接口函数 3.1 so ...
- Linux基础命令-02
Linux基础命令-02:
- linux安全加固(2)
目录:1.BIOS2.SSH安全3.禁用telnet4.禁用代码编译5.ProFTP6.TCPwrappers7.创建一个SU组8.root通知9.history安全10.欢迎信息11.禁用所有特殊账 ...
- linux安全加固(1)
Redhat是目前企业中用的最多的一类Linux,而目前针对Redhat攻击的黑客也越来越多了.我们要如何为这类服务器做好安全加固工作呢? 一. 账户安全 1.1 锁定系统中多余的自建帐号 检查方法: ...
- linux安全加固
1 . BIOS 你应该总是在系统启动的时候设置一个BIOS 密码和禁用从CD-ROM 和软盘引导,这将可以防止一些人未经允许访问你的系统和更改BIOS 设置 2 .sshd 服务 SSH 是一个协议 ...
- Linux操作系统加固
1. 账号和口令 1.1 禁用或删除无用账号 减少系统无用账号,降低安全风险. 操作步骤 使用命令 userdel <用户名> 删除不必要的账号. 使用命令 passwd -l <用 ...
- 阿里云服务器 ECS Linux操作系统加固
1. 账号和口令 1.1 禁用或删除无用账号 减少系统无用账号,降低安全风险. 操作步骤 使用命令 userdel <用户名> 删除不必要的账号. 使用命令 passwd -l <用 ...
- Linux安全加固--系统相关
一.系统相关 1.系统关键文件设置 1.1.设置文件初始权限 设置默认的umask值,增强安全性. [root@localhost ~]# umask 0022 /etc/profile最下面添加一行 ...
随机推荐
- CentOS 忘记root密码(重置root密码)
首先开机选择Advanced options for ****这一行按回车: 然后选中最后是(recovery mode)这一行按"E"进入编辑页面: 将ro recovery改为 ...
- easyUi datagrid鼠标经过提示单元格内容
此文章是基于 EasyUI+Knockout实现经典表单的查看.编辑 一. jquery.cellTip.js /** * 扩展两个方法 */ using('datagrid', function() ...
- java设计模式-----18、职责链模式
概念: Chain of Responsibility(CoR)模式也叫职责链模式.责任链模式或者职责连锁模式,是行为模式之一,该模式构造一系列分别担当不同的职责的类的对象来共同完成一个任务,这些类的 ...
- 重温jQuery
Write Less, Do More! ——John Resig(jQuery设计者) 目录 基础知识 概况 编程访问DOM节点 基础知识 Web网页是有结构的HTML文档.浏览器分析HTML文档, ...
- react里 MD5加密
https://www.f2td.com/2018/11/13/encrypt-the-user-password-with-md5/
- Java 接口和多态
接口 1.1 接口的概述 接口是功能的集合,同样可看做是一种数据类型,是比抽象类更为抽象的”类”. 接口只描述所应该具备的方法,并没有具体实现,具体的实现由接口的实现类(相当于接口的子类)来完成.这样 ...
- Android Studio插件之MVPHelper,一键生成MVP代码
MVP盛行,听到的最多的抱怨就是咋要写这么多接口,那么本文作者提供了一个插件,自动生成这些接口的声明.感兴趣的还可以学习该插件的写法,按照自己平时的需求修改,提供开发效率. MVPHelper 一款I ...
- 如何调试flutter应用
The Dart Analyzer 这个工具帮助你分析代码,发现可能的错误. 运行命令行 终端进入flutter工程所在目录,执行flutter analyze 使用IntelliJ IDEA Dar ...
- linux 网络命令ping、关闭防火墙、ifconfig、ip addr、setup、nmtui、write、wall、mail
ping /bin/ping语法:ping [选项] IP地址 选项:-c 指定发送次数功能描述:测试网络连通性 ping -c 4 192.168.1.101 关闭防火墙systemctl stop ...
- java 内存分析之构造方法执行过程
package Demo; public class BirthDate { private int day; private int month; private int year; public ...