精华内容
下载资源
问答
  • 用来Linux系统添加用户的主要工具是useradd。这个命令简单便捷,可以一次性创建新用户账户以及设置用户HOME目录结构。useradd命令使用系统的默认值以及命令行参数来设置用户账户。系统默认值被设置在/etc/...

    用来向Linux系统添加新用户的主要工具是useradd。这个命令简单便捷,可以一次性创建新用户账户以及设置用户HOME目录结构。useradd命令使用系统的默认值以及命令行参数来设置用户账户。系统默认值被设置在/etc/default/useradd文件中。可以使用加入了-D选项的useradd命令来查看所用Linux系统中的这些默认值。
    在这里插入图片描述
    默认值解释如下:
    1)新用户会被添加到GID为100的公共组;
    2)新用户的HOME目录;
    3)新用户账户密码在过期后不会被禁用;
    4)新用户账户未被设置过期日期;
    5)新用户默认登录shell;
    6)系统会将/etc/skel目录下的内容复制到HOME目录下;
    7)系统是否在mail目录下创建一个用于接收邮件的文件。

    在Ubuntu Linux系统上,/etc/skel有下列文件:
    在这里插入图片描述
    默认情况下,useradd命令不会创建HOME目录,但是-m参数会使其创建HOME目录。
    要想在创建用户时改变默认值或者默认行为,可以使用命令行参数,如下所示:
    在这里插入图片描述
    你会发现,在创建新用户账户时使用命令行参数可以更改系统指定的默认值。但如果总需要修改某个值的话,最好还是修改下系统的默认值。
    可以在-D选项后跟上一个指定的值来修改系统默认的新用户设置,参数如下所示:
    -b:更改HOME目录位置
    -e:更改默认的新账户的过期日期
    -f:更改默认的新用户从密码过期到账户被禁用的天数
    -g:更改默认的组的名称
    -s:更改默认的登录shell
    更改默认值非常简单:

    useradd -D -s /bin/bash
    

    现在,useradd命令会将bash shell作为所有新建用户的默认登录shell。

    展开全文
  • linux添加用户

    2020-01-24 23:25:27
    用来Linux系统添加用户的主要工具是 useradd 。这个命令简单快捷,可以一次性创建新用户账户及设置用户HOME目录结构。 useradd 命令使用系统的默认值以及命令行参数来设置用户账户。系统默认值被设置在/etc/...

    linux添加新用户

    用来向Linux系统添加新用户的主要工具是 useradd 。这个命令简单快捷,可以一次性创建新用户账户及设置用户HOME目录结构。 useradd 命令使用系统的默认值以及命令行参数来设置用户账户。系统默认值被设置在/etc/default/useradd文件中。可以使用加入了 -D 选项的 useradd命令查看所用Linux系统中的这些默认值。

    [root@localhost ~]# useradd -D
    GROUP=100
    HOME=/home
    INACTIVE=-1
    EXPIRE=
    SHELL=/bin/bash
    SKEL=/etc/skel
    CREATE_MAIL_SPOOL=yes
    说明 一些Linux发行版会把Linux用户和组工具放在/usr/sbin目录下,这个目录可能不在 PATH 环境变量里。如果你的Linux系统是这样的话,可以将这个目录添加进 PATH 环境变量,或者用绝对文件路径名来使用这些工具。
    

    在创建新用户时,如果你不在命令行中指定具体的值, useradd 命令就会使用 -D 选项所显示的那些默认值。这个例子列出的默认值如下:

    • 新用户会被添加到GID为 100 的公共组;

    • 新用户的HOME目录将会位于/home/loginname;

    • 新用户账户密码在过期后不会被禁用;

    • 新用户账户未被设置过期日期;

    • 新用户账户将bash shell作为默认shell;

    • 系统会将/etc/skel目录下的内容复制到用户的HOME目录下;

    • 系统为该用户账户在mail目录下创建一个用于接收邮件的文件。

    倒数第二个值很有意思。 useradd 命令允许管理员创建一份默认的HOME目录配置,然后把它作为创建新用户HOME目录的模板。这样就能自动在每个新用户的HOME目录里放置默认的系统文件。

    使用默认系统参数创建一个新用户账户,然后检查所创建的用户HOME目录。

    [root@localhost ~]# useradd -m root1
    [root@localhost ~]# ls -al /home/root1/
    总用量 20
    drwx------. 2 root1 root1 4096 1月  12 23:01 .
    drwxr-xr-x. 3 root  root  4096 1月  12 23:01 ..
    -rw-r--r--. 1 root1 root1   18 10月 31 2018 .bash_logout
    -rw-r--r--. 1 root1 root1  193 10月 31 2018 .bash_profile
    -rw-r--r--. 1 root1 root1  231 10月 31 2018 .bashrc
    

    默认情况下, useradd 命令不会创建HOME目录,但是 -m 命令行选项会使其创建HOME目录。你能在此例中看到, useradd 命令创建了新HOME目录,并将/etc/skel目录中的文件复制了过来。记得及时使用man useradd 或者 info useradd命令查看操作。

    展开全文
  • 系统调用就是用户空间应用程序和内核提供服务之间一个接口。...在本文,我将探究 Linux SCI,演示如何 2.6.20 内核添加一个系统调用,然后从用户空间来使用这个函数。我们还将研究在进行系统

    系统调用就是用户空间应用程序和内核提供的服务之间的一个接口。由于服务是在内核中提供的,因此无法执行直接调用;相反,您必须使用一个进程来跨越用户空间与内核之间的界限。在特定架构中实现此功能的方法会有所不同。因此,本文将着眼于最通用的架构 —— i386。

    在本文中,我将探究 Linux SCI,演示如何向 2.6.20 内核添加一个系统调用,然后从用户空间来使用这个函数。我们还将研究在进行系统调用开发时非常有用的一些函数,以及系统调用的其他选择。最后,我们将介绍与系统调用有关的一些辅助机制,比如在某个进程中跟踪系统调用的使用情况。

    SCI

    Linux 中系统调用的实现会根据不同的架构而有所变化,而且即使在某种给定的体架构上也会不同。例如,早期的 x86 处理器使用了中断机制从用户空间迁移到内核空间中,不过新的 IA-32 处理器则提供了一些指令对这种转换进行优化(使用 sysenter 和 sysexit 指令)。由于存在大量的方法,最终结果也非常复杂,因此本文将着重于接口细节的表层讨论上。更详尽的内容请参看本文最后的 参考资料

    要对 Linux 的 SCI 进行改进,您不需要完全理解 SCI 的内部原理,因此我将使用一个简单的系统调用进程(请参看图 1)。每个系统调用都是通过一个单一的入口点多路传入内核。eax 寄存器用来标识应当调用的某个系统调用,这在 C 库中做了指定(来自用户空间应用程序的每个调用)。当加载了系统的 C 库调用索引和参数时,就会调用一个软件中断(0x80 中断),它将执行 system_call 函数(通过中断处理程序),这个函数会按照 eax 内容中的标识处理所有的系统调用。在经过几个简单测试之后,使用 system_call_table 和 eax 中包含的索引来执行真正的系统调用了。从系统调用中返回后,最终执行 syscall_exit,并调用 resume_userspace 返回用户空间。然后继续在 C 库中执行,它将返回到用户应用程序中。

    图 1. 使用中断方法的系统调用的简化流程
    系统调用的简化流程

    SCI 的核心是系统调用多路分解表。这个表如图 2 所示,使用 eax 中提供的索引来确定要调用该表中的哪个系统调用(sys_call_table)。图中还给出了表内容的一些样例,以及这些内容的位置。(有关多路分解的更多内容,请参看侧栏 “系统调用多路分解”)

    图 2. 系统调用表和各种链接
    系统调用表和各种链接

    添加一个 Linux 系统调用

    添加一个新系统调用主要是一些程序性的操作,但应该注意几件事情。本节将介绍几个系统调用的构造,从而展示它们的实现和用户空间应用程序对它们的使用。

    向内核中添加新系统调用,需要执行 3 个基本步骤:

    1. 添加新函数。
    2. 更新头文件。
    3. 针对这个新函数更新系统调用表。

    注意: 这个过程忽略了用户空间的需求,我将稍后介绍。

    最常见的情况是,您会为自己的函数创建一个新文件。不过,为了简单起见,我将自己的新函数添加到现有的源文件中。清单 1 所示的前两个函数,是系统调用的简单示例。清单 2 提供了一个使用指针参数的稍微复杂的函数。

    清单 1. 系统调用示例的简单内核函数
    asmlinkage long sys_getjiffies( void )
    {
      return (long)get_jiffies_64();
    }
    
    asmlinkage long sys_diffjiffies( long ujiffies )
    {
      return (long)get_jiffies_64() - ujiffies;
    }

    在清单 1 中,我们为进行 jiffies 监视提供了两个函数。(有关 jiffies 的更多信息,请参看侧栏 “Kernel jiffies”)。第一个函数会返回当前 jiffy,而第二个函数则返回当前值与所传递进来的值之间的差值。注意 asmlinkage 修饰符的使用。这个宏(在 linux/include/asm-i386/linkage.h 中定义)告诉编译器将传递栈中的所有函数参数。

    清单 2. 系统调用示例的最后内核函数
    asmlinkage long sys_pdiffjiffies( long ujiffies,
                                      long __user *presult )
    {
      long cur_jiffies = (long)get_jiffies_64();
      long result;
      int  err = 0;
    
      if (presult) {
    
        result = cur_jiffies - ujiffies;
        err = put_user( result, presult );
    
      }
    
      return err ? -EFAULT : 0;
    }

    清单 2 给出了第三个函数。这个函数使用了两个参数:一个 long 类型,以及一个指向被定义为 __user 的 long 的指针。__user 宏简单告诉编译器(通过 noderef)不应该解除这个指针的引用(因为在当前地址空间中它是没有意义的)。这个函数会计算这两个 jiffies 值之间的差值,然后通过一个用户空间指针将结果提供给用户。put_user 函数将结果值放入 presult 所指定的用户空间位置。如果在这个操作过程中出现错误,将立即返回,您也可以通知用户空间调用者。

    对于步骤 2 来说,我对头文件进行了更新:在系统调用表中为这几个新函数安排空间。对于本例来说,我使用新系统调用号更新了 linux/include/asm/unistd.h 头文件。更新如清单 3 中的黑体所示。

    清单 3. 更新 unistd.h 文件为新系统调用安排空间

    点击查看代码清单

    现在已经有了自己的内核系统调用,以及表示这些系统调用的编号。接下来需要做的是要在这些编号(表索引)和函数本身之间建立一种对等关系。这就是第 3 个步骤,更新系统调用表。如清单 4 所示,我将为这个新函数更新 linux/arch/i386/kernel/syscall_table.S 文件,它会填充清单 3 显示的特定索引。

    清单 4. 使用新函数更新系统调用表
    .long sys_getcpu
    .long sys_epoll_pwait
    .long sys_getjiffies		/* 320 */
    .long sys_diffjiffies.long sys_pdiffjiffies

    注意: 这个表的大小是由符号常量 NR_syscalls 定义的。

    现在,我们已经完成了对内核的更新。接下来必须对内核重新进行编译,并在测试用户空间应用程序之前使引导使用的新映像变为可用。

    对用户内存进行读写

    Linux 内核提供了几个函数,可以用来将系统调用参数移动到用户空间中,或从中移出。方法包括一些基本类型的简单函数(例如 get_user或 put_user)。要移动一块儿数据(如结构或数组),您可以使用另外一组函数: copy_from_user 和 copy_to_user。可以使用专门的调用移动以 null 结尾的字符串: strncpy_from_user 和 strlen_from_user。您也可以通过调用 access_ok 来测试用户空间指针是否有效。这些函数都是在 linux/include/asm/uaccess.h 中定义的。

    您可以使用 access_ok 宏来验证给定操作的用户空间指针。这个函数有 3 个参数,分别是访问类型(VERIFY_READ 或 VERIFY_WRITE),指向用户空间内存块的指针,以及块的大小(单位为字节)。如果成功,这个函数就返回 0:

    int access_ok( type, address, size );

    要在内核和用户空间移动一些简单类型(例如 int 或 long 类型),可以使用 get_user 和 put_user 轻松地实现。这两个宏都包含一个值以及一个指向变量的指针。get_user 函数将用户空间地址(ptr)指定的值移动到所指定的内核变量(var)中。 put_user 函数则将内核变量(var)指定的值移动到用户空间地址(ptr)。 如果成功,这两个函数都返回 0:

    int get_user( var, ptr );
    int put_user( var, ptr );

    要移动更大的对象,例如结构或数组,您可以使用 copy_from_user 和 copy_to_user 函数。这些函数将在用户空间和内核之间移动完整的数据块。 copy_from_user 函数会将一块数据从用户空间移动到内核空间,copy_to_user 则会将一块数据从内核空间移动到用户空间:

    unsigned long copy_from_user( void *to, const void __user *from, unsigned long n );
    unsigned long copy_to_user( void *to, const void __user *from, unsigned long n );

    最后,您可以使用 strncpy_from_user 函数将一个以 NULL 结尾的字符串从用户空间移动到内核空间中。在调用这个函数之前,您可以通过调用 strlen_user 宏来获得用户空间字符串的大小:

    long strncpy_from_user( char *dst, const char __user *src, long count );
    strlen_user( str );

    这些函数为内核和用户空间之间的内存移动提供了基本功能。实际上还可以使用另外一些函数(例如减少执行检查数量的函数)。您可以在 uaccess.h 中找到这些函数。

    使用系统调用

    现在内核已经使用新系统调用完成更新了,接下来看一下从用户空间应用程序中使用这些系统调用需要执行的操作。使用新的内核系统调用有两种方法。第一种方法非常方便(但是在产品代码中您可能并不希望使用),第二种方法是传统方法,需要多做一些工作。

    使用第一种方法,您可以通过 syscall 函数调用由其索引所标识的新函数。使用 syscall 函数,您可以通过指定它的调用索引和一组参数来调用系统调用。例如,清单 5 显示的简单应用程序就使用其索引调用了 sys_getjiffies

    清单 5. 使用 syscall 调用系统调用
    #include <linux/unistd.h>
    #include <sys/syscall.h>
    
    #define __NR_getjiffies		320
    
    int main()
    {
      long jiffies;
    
      jiffies = syscall( __NR_getjiffies );
    
      printf( "Current jiffies is %lx\n", jiffies );
    
      return 0;
    }

    正如您所见,syscall 函数使用了系统调用表中使用的索引作为第一个参数。如果还有其他参数需要传递,可以加在调用索引之后。大部分系统调用都包括了一个 SYS_ 符号常量来指定自己到 __NR_ 索引的映射。例如,使用 syscall 调用 __NR_getpid 索引:

    syscall( SYS_getpid )

    syscall 函数特定于架构,使用一种机制将控制权交给内核。其参数是基于 __NR 索引与 /usr/include/bits/syscall.h 提供的 SYS_ 符号之间的映射(在编译 libc 时定义)。永远都不要直接引用这个文件;而是要使用 /usr/include/sys/syscall.h 文件。

    传统的方法要求我们创建函数调用,这些函数调用必须匹配内核中的系统调用索引(这样就可以调用正确的内核服务),而且参数也必须匹配。Linux 提供了一组宏来提供这种功能。_syscallN 宏是在 /usr/include/linux/unistd.h 中定义的,格式如下:

    _syscall0( ret-type, func-name )
    _syscall1( ret-type, func-name, arg1-type, arg1-name )
    _syscall2( ret-type, func-name, arg1-type, arg1-name, arg2-type, arg2-name )

    _syscall 宏最多可定义 6 个参数(不过此处只显示了 3 个)。

    现在,让我们来看一下如何使用 _syscall 宏来使新系统调用对于用户空间可见。清单 6 显示的应用程序使用了 _syscall 宏定义的所有系统调用。

    清单 6. 将 _syscall 宏 用于用户空间应用程序开发 
    #include <stdio.h>
    #include <linux/unistd.h>
    #include <sys/syscall.h>
    
    #define __NR_getjiffies		320
    #define __NR_diffjiffies	321
    #define __NR_pdiffjiffies	322
    
    _syscall0( long, getjiffies );
    _syscall1( long, diffjiffies, long, ujiffies );
    _syscall2( long, pdiffjiffies, long, ujiffies, long*, presult );
    
    int main()
    {
      long jifs, result;
      int err;
    
      jifs = getjiffies();
    
      printf( "difference is %lx\n", diffjiffies(jifs) );
    
      err = pdiffjiffies( jifs, &result );
    
      if (!err) {
        printf( "difference is %lx\n", result );
      } else {
        printf( "error\n" );
      }
    
      return 0;
    }

    注意 __NR 索引在这个应用程序中是必需的,因为 _syscall 宏使用了 func-name 来构造 __NR 索引(getjiffies -> __NR_getjiffies)。其结果是您可以使用它们的名字来调用内核函数,就像其他任何系统调用一样。

    用户/内核交互的其他选择

    系统调用是请求内核中服务的一种有效方法。使用这种方法的最大问题就是它是一个标准接口,很难将新的系统调用增加到内核中,因此可以通过其他方法来实现类似服务。如果您无意将自己的系统调用加入公共的 Linux 内核中,那么系统调用就是将内核服务提供给用户空间的一种方便而且有效的方法。

    让您的服务对用户空间可见的另外一种方法是通过 /proc 文件系统。/proc 文件系统是一个虚拟文件系统,您可以通过它来向用户提供一个目录和文件,然后通过文件系统接口(读、写等)在内核中为新服务提供一个接口。

    使用 strace 跟踪系统调用

    Linux 内核提供了一种非常有用的方法来跟踪某个进程所调用的系统调用(以及该进程所接收到的信号)。这个工具就是 strace,它可以在命令行中执行,使用希望跟踪的应用程序作为参数。例如,如果您希望了解在执行 date 命令时都执行了哪些系统调用,可以键入下面的命令:

    strace date

    结果会产生大量信息,显示在执行 date 命令过程中所执行的各个系统调用。您会看到加载共享库、映射内存,最后跟踪到的是在标准输出中生成日期信息:

    ...
    write(1, "Fri Feb  9 23:06:41 MST 2007\n", 29Fri Feb  9 23:06:41 MST 2007) = 29
    munmap(0xb747a000, 4096)	= 0
    exit_group(0)			= ?
    $

    当当前系统调用请求具有一个名为 syscall_trace 的特定字段集(它导致 do_syscall_trace 函数的调用)时,将在内核中完成跟踪。您还可以看到跟踪调用是 ./linux/arch/i386/kernel/entry.S 中系统调用请求的一部分(请参看 syscall_trace_entry)。

    结束语

    系统调用是穿越用户空间和内核空间,请求内核空间服务的一种有效方法。不过对这种方法的控制也很严格,更简单的方式是增加一个新的 /proc 文件系统项来提供用户/内核间的交互。不过当速度因素非常重要时,系统调用则是使应用程序获得最佳性能的理想方法。请参看 参考资料 的内容进一步了解 SCI。

    参考资料 

    学习



    展开全文
  • 通常,要授予sudo访问权限,请将用户添加到sudoers文件定义sudo组。在Debian,Ubuntu及其衍生产品上,sudo组成员在基于RedHat发行版(如CentOS和Fedora)上获得sudo权限,sudo组名称是wheel。 在运行sudo...
  •  在Linux系统中,软件安装程序比较复杂,不过最常见有两种: 一种是软件源代码,您需要自己动手编译它。这种软件安装包通常是用gzip压缩过tar包(后缀名为.tar.gz)。  另一种是软件可执行程序,你只要...
  • 在Windows系统的右键菜单有一个“发送到”功能菜单...添加发送到菜单中的信息用户之所以不愿意使用“发送到”功能,最主要原因之一就是默认状态下里面选项太少,甚至有些默认选项用户根本就是用不到。所以为...

    在Windows系统的右键菜单中有一个“发送到”功能菜单,通过它我们可以把指定的文件发送到需要的软件程序中,从而快速打开文件进行相关操作。但是许多时候我们不仅仅是想要打开文件,有时可能需要更复杂的操作,通过下面的方法,就可以让“发送到”功能变得更强大。

    添加发送到菜单中的信息

    用户之所以不愿意使用“发送到”功能,最主要的原因之一就是默认状态下里面的选项太少,甚至有些默认的选项用户根本就是用不到。所以为了让用户更加方便的使用这个功能,我们不仅需要删除不常用的选项,还需要根据自己的实际情况向其中添加相关的选项。

    现在首先下载解压“SendTo Menu Editor”这款工具(https://www.sordum.org),通过这款工具我们就能非常方便的对“发送到”菜单中的选项进行管理。接着根据自己的系统版本,运行解压文件夹中的程序文件。在弹出的窗口列表中我们就可以看到默认状态下,“发送到”菜单中的所有选项内容,然后用户就可以根据自己平时的使用习惯对这些选项进行管理(图1)。

    c61262fba32a46a75bef2eddc53e5fbe.png

    例如我们不使用“蓝牙文件发送”这个功能,那么可以找到这个选项将前面的对勾去除,这样该选项就会从菜单中进行隐藏,在需要的时候进行勾选来恢复它的使用。当然用户也可以在列表中勾选上这个选项,点击工具栏中的“Rename shortcut”按钮将这个选项彻底进行删除,但是这样就无法再进行恢复操作了。

    但是要想更好的使用这项功能,我们还是需要在里面添加更多的选项才行。首先点击工具栏中的“add shortcut”按钮,在弹出的对话框中进行设置。我平时编辑文本文件使用的都是 Notepad2 这款工具,所以首先点击配置对话框“Enter File or Folder Location”选项后的“Select Target File”按钮,在弹出的对话框中选择Notepad2编辑器的主程序文件。接着在“Shortcut Name”输入框里面设置一个在“发送到”菜单中显示的名称,这里设置的就是Notepad2。最后点击“Create Shortcut”按钮,就可以完成该选项的创建操作(图2)。

    3cdf49102f7c143dc0f5c8015d1c713e.png

    以后我们只需要在磁盘中选中一个文本文件,点击右键菜单后选择“发送到”中的“Notepad2”,就可以快速利用该编辑器打开该文本文件(图3)。

    2426b66baf10bfe4bc7869fe53c737fb.png

    小提示:如果想在“发送到”菜单中创建一个快捷目录,那么需要在“Enter File or Folder Location”选项后点击“Select Target Folder”这个按钮进行选择配置。以后就可以通过右键菜单,将指定的文件快速发送到创建的快捷目录里面了。

    其他命令添加到发送到里

    上面的方法操作起来非常的简单,但是只限于添加软件程序和文件夹目录。如果用户想要添加其他和系统相关的命令,那么就要设置非常复杂的参数才可以。为了更加方便普通用户的操作,我们可以更换另外一款工具来进行添加设置。

    首先下载运行“Send To Toys”这款工具,在安装的时候会询问用户是否添加一些命令,通常情况下只需要全选就可以了。该工具安装完成以后,在右键的“发送到”菜单中就会发现多了很多的选项,其中包括发送到剪贴板、命令提示符以及运行框等等(图4)。

    a5256a1a717e470d41a449641be9a047.png

    其中选择“Clipboard (as content)”这个命令,就可以在不打开文本文件的情况下,直接将文本文件中的内容复制到剪贴板里面。如果要想使用“Default Mail Recipient”命令,首先需要在工具的窗口中选择“Default Mail Recipient”对话框。接着在对话框中设置收件人等相关信息,邮件信息设置完成以后点击“确定”按钮进行保存(图5)。以后再点击“Default Mail Recipient”这个命令,就可以将设置的信息快速的进行发送。

    abcd77b14960a237959f547fa27c2128.png

    “发送到”中完成图片转换

    利用“发送到”命令除了可以将文件快速发送到,指定的软件程序或者文件夹目录以外,还可以进行其他的一些操作。比如对于图片文件来说,我们最常使用的操作就是文件转换。而通常情况需要使用专业的软件才能完成批量转换的操作,而现在我们只需要通过“发送到”中的命令就可以快速完成相关的操作。

    首先下载安装“SendTo-Convert”这款右键转换工具(http://www.vieas.com),安装完成以后我们打开这款工具的配置窗口,对这款工具进行一些基本的配置操作。现在点击下方的“Options”按钮,在弹出对话框的“Language”列表中选择“ChineseTraditional”选项,保存以后工具界面就变成繁体中文的了(图6)。

    0fcf759a53e00feaf0476477b33bf709.png

    接下来返回到工具的配置窗口,我们可以根据要求设置文件的输出格式、不同图片格式的相关参数,以及还可以设置转换文件的保存目录等等。配置完成以后我们一定要勾选上“加入至 传送到 功能表”选项,最后点击“离开”按钮就可以了(图7)。

    b78d8908ec58548b843d9670ee94d7e0.png

    以后当我们要想进行图片转换操作时,首先在资源管理器中选中要转换的图片。接下来点击鼠标右键,在“发送到”菜单中就可以看到“SendTo-Convert”这个命令,点击它以后就可以快速完成转换操作。如果之前用户在配置窗口的“输出格式”选择的是“可选”,这时就会弹出一个图片格式的选择对话框。当用户选中需要的转换格式以后,就会马上开始进行图片格式转换操作(图8)。

    11691756abb1cd6aa337bbf1c6393df8.png
    展开全文
  • 一些结果是通过直接消息发送给主叫用户的,但是尚无法发送命令。 能够与您本人和机器人一起在单个私有通道保留来自机器人的所有相互信用命令和结果,可以防止公共渠道不知所措,并且可以使个人机器人历史保持清晰...
  • bash shell命令(六)

    2021-01-09 10:46:25
    用来Linux系统添加用户的主要工具是useradd。 从系统中删除用户可以用userdel命令。默认情况下, userdel命令会只删除/etc/passwd文件中的用户信息,而不会删除系统中属于该账户的任何文件。如果加上-r参数,
  • linux用户管理

    2020-01-24 23:24:38
    用来Linux系统添加用户的主要工具是 useradd 。这个命令简单快捷,可以一次性创建新用户账户及设置用户HOME目录结构。 useradd 命令使用系统的默认值以及命令行参数来设置用户账户。系统默认值被设置在/etc/...
  • 1.命令简介 gpasswd 是Linux下工作组文件 /etc/group 和 /etc/gshadow 管理工具。 系统管理员可以使用 -a 选项定义组管理员,使用 -m 选项定义成员,由组管理员用组名调用 gpasswd ... 组 GROUP 中添加用户 USE...
  • CMD命令:开始->运行->键入cmd或command(在命令行里可以看到系统版本、文件系统版本) 命令大全 1. gpedit.msc-----组策略 2. sndrec32-------录音机 3. Nslookup-------IP地址侦测器 ,是一个 监测网络 DNS...
  • 入门学习Linux常用必会60个命令实例详解doc/txt

    千次下载 热门讨论 2011-06-09 00:08:45
    这里笔者把比较重要和使用频率最多的命令,按照它们在系统中的作用分成下面六个部分一一介绍。 ◆ 安装和登录命令:login、shutdown、halt、reboot、install、mount、umount、chsh、exit、last; ◆ 文件处理命令...
  • ubuntu创建新的用户

    2019-03-26 17:47:00
    ubuntu系统中添加的用户:username sudo useradd -s /bin/bash -d /home/username/ -m usernamesudo passwd username 以下是useradd命令的options,用到选项已经标记为红色 Usage: useradd ...
  • DOS操作命令

    2015-03-13 09:17:45
    net localgroup administrators 用户名 /add 把"用户"添加到管理员使其具有管理员权限,注意:administrator后加s用复数 net start 查看开启了哪些服务 net start 服务名 开启服务;(如:net start telnet, ...
  • windows实用dos命令大全

    2010-12-10 21:27:35
    (1)子目录在删除前必须是空的,也就是说需要先进入该子目录,使用DEL(删除文件的命令)将其子目录下的文件删空,然后再退回到上一级目录,用RD命令删除该了目录本身;  (2)不能删除根目录和当前目录。  例:...
  • 学习目标 能够知道什么是Linux系统以及它应用场景 能够独立完成安装VMware虚拟机和网络配置 ...部署、存储都在Windwos操作系统的环境,从今天开始我们一起学习下Linux,Linux系统和Windows系统最大区.
  • 这样在本系统中就可以为博友提供更多个人色彩。在管理页面中添加和删除友情连接。这样博友可以在自己空间中快速定位自己关心网站。这样还可以让网友看到自己一些信息。友情链接及网页访问量统计显示:在博客...
  • (3)如果对方未开启企业通信系统的情况下,对方发送信史信息,如图1.6所示。 (4)本程序还支持群发功能,按住键盘上键,选择需要发送信息人,然后,单击鼠标右键选择“信使群发”命令,进行信使群发操作。
  • 利用chattr命令可以锁定系统中一些重要文件或目录,命令格式:chattr [-R] +/- i/a文件-R:递归修改所有文件及子目录,这是一个可选项。+:增加扩展属性;-:减少扩展属性;i:只读属性,增加该属性之后,任何人...
  • CMD网络命令及用法

    2011-06-24 20:18:35
    net localgroup administrators 用户名 /add 把“用户添加到管理员使其具有管理员权限,注意:administrator后加s用复数 net start 查看开启了哪些服务 net start 服务名 开启服务;(如:net start telnet, ...
  • linux用户创建

    2013-11-25 12:00:14
    命令向系统中增加了一个新组group1,新组组标识号是在当前已有最大组标识号基础上加1。 例2: 代码: #groupadd -g 101 group2 此命令向系统中增加了一个新组group2,同时指定新组组标识号是101。 2、...
  • 安装pip后,会向系统添加一个pip命令,该命令可以从命令提示符运行。2、安装方法(1)直接安装从 Python 2 版本 >=2.7.9 或 Python 3 版本 >=3.4 开始,官网安装包已经自带了 pip,在安装时用户可以直接选择...
  • 我们先给大家介绍什么是命令行界面(CLI):命令行界面或命令语言解释器,也称为命令行用户界面、控制台用户界面和字符用户界面,是一种与计算机程序交互方式,用户以连续文本行形式程序发出命令。通过创建...
  • 全书共分4个部分,第一部分介绍最基本概念、术语及建模原则,第二部分描述了关系数据模型和关系型DBMS,第三部分讨论数据库设计,第四部分主要描述数据库系统中使用物理文件结构和存取方法。书中涉及内容非常...
  • 前言:我们先给大家介绍什么是命令行界面(CLI):命令行界面或命令语言解释器,...CLI允许您接受命令行参数(操作系统命令行程序名称后面信息),以便程序添加其他特性,使代码易于使用和灵活。根据程序不同,这...
  • 前言:我们先给大家介绍什么是命令行界面(CLI):命令行界面或命令...CLI允许您接受命令行参数(操作系统命令行程序名称后面信息),以便程序添加其他特性,使代码易于使用和灵活。根据程序不同,这些参数可用...
  • 本文主要目的是在安卓系统中添加一个input event设备,并通过它向用户层发送按键事件。方法是采用动态模块方式将该设备加入到input子系统中,所以是一个虚拟设备。然后通过getevent和sendevent验证设备被正确...
  • 如果不是,那么它将用户添加一些XP,然后进行我之前解释词典处理。 调平系统: 练级系统是依靠XP系统和数据库为用户赋予练级角色的系统。 在每封邮件上以及添加XP之后,该漫游器都会检查发件人XP并添加...
  • linux用户操作保证了系统的安全性/etc/passwd 文件查看用户信息/etc/shadow用户信息加密添加用户用来Linux系统添加新用户的主要工具是 useradd 如果你不在命令行指定具体的值, useradd 命令就会使用 -D 选项所...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 500
精华内容 200
关键字:

向系统中添加用户的命令是