m|(.*)/([^/]+).wft$|i#你说的是最基本的用法,这里单独看下去你会觉得很虚激乱,实际也不亩好用看懂迅誉铅,重点在下面那行。
my $wft_base_name = $2#$2指你第二个括号([^/]+)里选出来的结果。上面没有匹配是用的$_默认值
喜欢的话去看看更详细的介绍
第一种办法,最简单的,调用 shell:
$ip = `ifconfig eth0|grep -oE '([0-9]{1,3}\.?){4}'|head -n 1`
注:这里输入是固定的,所以简单的 [0-9]{1,3} 了,如果岁睁是在 web 程序等地方验证 ip,需要更严谨!
或者
$ip = `ifconfig eth0|awk -F: '/inet addr/{split($2,a," ")print a[1]exit}'`
好吧,这样显得太不 perl 了,而且频繁的调用外部 shell 不太好
第二种:
open FH,"ifconfig eth0|"
while(){
last unless /inet addr:((\d{1,3}\.?){4})/
print $1
}
看起来稍微 perl 了一些,虽然实质跟上面的调用 shell 和 grep 法是一样的。
第三种,更 perl 一点,纯粹读文件:
open FH,'<','/etc/sysconfig/network-scripts/ifcfg-eth0'
while(){
next unless /IPADDR\s*=\s*(\S+)/
print $1
}
进一步的,如果不一定 rh 系,还要去读 /etc/issue ,
确定网络配置文件到底是 /etc/sysconfig/network-script/ifcfg-eth0
还是 /etc/network/interfaces 还是其他,然后根据不同发行版写不同的处理方法……额,
这是打算自己写模块么?
好吧,大家来充分体会 CPAN 的魅力,去 search 一下,
找到一把 Sys::HostIP、Sys::HostAddr、Net::Inetface 等模块。
第四种:
use Sys::HostAddr
my $interface = Sys::HostAddr->new(ipv =>'4', interface =>'eth0')
print $interface->main_ip
不过进去看橡辩看pm文件,汗,这几个模块都是调用ifconfig命令,不过是根据发行版的不同进行封装而已。
还有办法么?还有,看
第五种:
perl -MPOSIX -MSocket -e 'my $host = (uname)[1]print inet_ntoa(scalar gethostbyname($host))'
不过有童鞋说了,这个可能因为hostname的原因,导致获取的都是127.0.0.1……
那么最后还有一招。通过 strace ifconfig 命令可以看到,
linux 实质是通过 ioctl 命令完成的网络接口 ip 获取。那么,我们也用 ioctl 就是了!
第六种如下:
#!/usr/bin/perl
use strict
use warnings
use Socket
require 'sys/ioctl.ph'
sub get_ip_address($) {
my $pack = pack("a*", shift)
my $socket
socket($socket, AF_INET, SOCK_DGRAM, 0)
ioctl($socket, SIOCGIFADDR(), $pack)
return inet_ntoa(substr($pack,20,4))
}
print get_ip_address("eth0")
这样的好处,就是只调用了核心模块,在分发脚梁雀缺本时,不用连带安装其他模块。
一、打开穗辩蚂SecureCRT二、连接Unix系统
三、输入命令
perl -MPOSIX=strftime -le 'print strftime("%Y%m%d%M%S",localtime( (stat "file"猜埋)[10] ))'灶辩
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)