METHODE BEST
erforderlich: nichts (N. B.Dies ist die gleiche Technik wie getent ohne getent) zu erfordern
home() { # returns empty string on invalid user
grep "^$1:" /etc/passwd | cut -d ':' -f 6
}
# grep "^$user:" /etc/passwd | cut -d ':' -f 6
/var/lib/memcached
NICE METHOD FOR ROOT LINUX
Required: Linux, root (oder Sudo)
LÖSUNG FÜR COMPLETE EXPANSION
magic() { # returns unexpanded tilde express on invalid user
local _safe_path; printf -v _safe_path "%q" "$1"
eval "ln -sf $_safe_path /tmp/realpath.$$"
readlink /tmp/realpath.$$
rm -f /tmp/realpath.$$
}
Beispiel Nutzung:
$ magic ~nobody/would/look/here
/var/empty/would/look/here
$ magic ~invalid/this/will/not/expand
~invalid/this/will/not/expand
VERFAHREN ZUR CSH NUTZEN
Dies ist ein BASH-Skript wird, ruft es nur csh.
erforderlich: csh
home() { # return errorlevel 1 on invalid user
export user=$1; csh -c "echo ~$user"
}
$ export user=root; csh -c "echo ~$user"
/var/root
$ export user=nodfsv; csh -c "echo ~$user"
Unknown user: nodfsv.
VERFAHREN DESPERATION
erforderlich: Finger (veraltet)
home() {
finger -m "$1" |
grep "^Directory:" |
sed -e 's/^Directory: //' -e 's/ .*//'
}
# finger -m "haldaemon" |
> grep "^Directory:" |
> sed -e 's/^Directory: //' -e 's/ .*//'
/home/haldaemon
können Sie kombiniert die grep Operation in sed, aber da diese Methode sucky ist, würde ich nicht stören.
Dies wird fehlschlagen, wenn z.B. LDAP-Authentifizierung wird verwendet. –
Sie möchten 'getent passwd' verwenden. Das wird verwenden, was auch immer Name Service Switch-Datenbanken in /etc/nsswitch.conf konfiguriert sind (zB:/etc/passwd, nis, ldap, etc). –