PowerShell_零基础自学课程_5_自定义PowerShell环境及Powershell中的基本概念

PowerShell_零基础自学课程_5_自定义PowerShell环境及Powershell中的基本概念

  据我个人所知,windows下的cmd shell除了能够通过修改系统参数来对其中的环境变量进行改变外,其环境的可自定义性相对来说很困难,而在Linux环境中,可以通过修改/etc目录下的某些配置文件来达到配置shell环境的目的。也许这也是某些人诟病cmd shell功能不强的
原因之一。
  而目前这种状况在windows powershell中得到了改善,可以说PS中提供的自定义环境的功能基本可以和linux环境相比较;今天我们来看看如何在PS中来自定义shell环境; 首先来看几个概念。
1、脚本
  在cmd、Bash等shell中,脚本可以简单的理解为一系列将要按照顺序执行的命令的集合。在windows中以前就支持很多种脚本,例如:
bat脚本、VB脚本、Java脚本、WMI脚本,windows为这些脚本提供一个执行宿主环境,通常称为WSH(Windows script host)。 而且还可以通过扩展一些三方的工具来执行功能更加强大的脚本,例如Python、Perl等。
  PS也支持脚本的概念,PS脚本是一系列将要按照顺序执行的cmdlet的集合;在windows中脚本文件的扩展名是psl。
2、执行策略
  顾名思义,执行策略就是指可执行文件在启动执行过程中需要遵守的规则;在PS中执行策略决定脚本文件是否能执行,如果脚本能执行,执行策略还决定执行的脚本是否需要经过数字签名验证,同时还决定是否能加载脚本配置文件。
2、1 查看执行策略
  在PS中通过cmdlet get-executionpolicies 来查看PS脚本的执行策略。如下所示:
Exp:
  PS C:\Users\vol_20120330> get-executionpolicy
  RemoteSigned

  上面的执行结果表示:当前的脚本执行策略是RemoteSigned。 前面提到过PS有种执行策略,这里不再解释;但是还可以通过下面的cmdlet来获取相关的信息:
  get-help about_execution_policies

Exp:

PS C:\Users\vol_20120330> get-help about_execution_policies
主题
    about_Execution_Policies

简短说明
    说明 Windows PowerShell 执行策略,并介绍如何对它们进行管理。

详细说明
    使用 Windows PowerShell 执行策略,可以确定 Windows PowerShell
    加载配置文件和运行脚本的条件。

    可以为本地计算机、当前用户或特定会话设置执行策略。也可使用组策略设置
    为计算机和用户设置执行策略。

    用于本地计算机和当前用户的执行策略存储在注册表中。无需在 Windows PowerShell
    配置文件中设置执行策略。用于特定会话的执行策略仅存储在内存中,会话关闭时,
    该执行策略将丢失。

    执行策略并不是限制用户操作的安全系统。例如,当无法运行脚本时,
    用户可通过在命令行中键入脚本内容而轻松规避某个策略。执行策略的
    真正用途是帮助用户设置一些基本规则,并防止用户无意中违反这些规则。

 WINDOWS POWERSHELL 执行策略
 -------------------------------------

    Windows PowerShell 执行策略如下:

    "Restricted"是默认策略。

        Restricted
            - 默认执行策略。

            - 允许单个命令运行,但不能运行脚本。

            - 阻止所有脚本文件的运行,包括格式和配置文件 (.ps1xml)、模块脚本文件 (.psm1)
              和 Windows PowerShell 配置文件 (.ps1)。

        AllSigned
            - 可以运行脚本。

            - 要求所有脚本和配置文件由可信发布者签名,包括在本地计算机上编写的脚本。

            - 在运行来自尚未分类为可信或不可信发布者的脚本之前进行提示。

            - 运行来自 Internet 以外的源的未签名脚本及已签名但有恶意的脚本存在风险。

        RemoteSigned
            - 可以运行脚本。

            - 要求可信发布者对从 Internet(包括电子邮件和即时消息程序)下载的脚本和配置文件
              进行数字签名。

            - 不要求对已经运行和已在本地计算机编写的脚本(不是从 Internet 下载的脚本)进行数
              字签名。

            - 面临运行已签名但有恶意的脚本带来的风险。

        Unrestricted
            - 可以运行未签名脚本。(面临运行恶意脚本所带来的风险。)

            - 在运行从 Internet 下载的脚本和配置文件之前警告用户。

        Bypass
            - 不阻止任何执行项,不显示警告和提示。

            - 此执行策略设计用于两种配置:一种是 Windows PowerShell 脚本内置于一个较大的
              应用程序中;一种是 Windows PowerShell 成为拥有自身安全模型的某个程序的基础。

        Undefined
            - 当前作用域中未设置执行策略。

            - 如果所有作用域中的执行策略为 Undefined,则有效执行策略为 Restricted,该策略
              是默认执行策略。

  通过上面的命令可知, 默认的执行策略是restricted; 就是不允许执行脚本; 而我前面获取的执行策略配置信息,是通过下面的cmdlet来实现的:

Exp:

  set-executionpolicy

set-executionpolicy remotesigned

具体的设置方法可以自己获取帮助。

  我们知道,在当前会话中设置一些函数、别名和变量后,如果退出当前会话,那么这些设置将不再有效;而设置执行策略与这不同,因为执行策略信息保存在windows

的注册表信息里面, 这样当退出当前会话后,修改的执行策略信息仍将有效,即使卸载然后再重新安装PS,还将保持原来的设置不变。

3、配置文件

  PS环境默认有4个配置文件,下面一一进行介绍.

3、1  针对所有用户,影响所有shell的配置文件

  这个配置文件存放在:   %windir%\system32\windowspowershell\v1.0\profile.psl

  修改这个配置文件将影响所有的用户,以及所有的shell。

3、2  针对所有用户,只影响Windows Powershell的配置文件

  这个配置文件保存在:  %windir%\system32\windowspowershell\v1.0\microsoft.powershell_pfrofile.psl

  修改这个配置文件将影响所有的用户,但只针对windows Powershell有效。

3、3  针对当前用户,影响所有shell的用户配置文件

  这个配置文件保存在: %userprofile%\my documents\windowspowershell\v1.0\profile.psl

  修改这个配置文件只对当前用户有效,但是会影响所有的shell

3、4  针对当前用户,只影响PS的用户配置文件

  这个配置文件保存在: %userprofile%\my documents\windowspowershell\v1.0\microsoft.poweshel_profile.psl

修改这个配置文件只对当前用户有效,并且只影响PS。

  估计,大家会记得我在前面的文章中,就修改过这个配置文件。其路径就是: $path变量存储的路径。

3、5  配置文件路径

  这么多配置文件,那么在当前会话中到底哪个起作用呢?

这个问题的答案就是: 只有与$path 变量中存储路径相同的配置文件才起作用; 包括路径和文件名。

4、创建配置文件

  我们知道,在linux环境下,位于/etc 目录下的配置文件大部分系统自生成的;而在PS中,配置文件不是自动生成的,而需要用户手动创建。因此为了自定义PS的环境

就需要我们自己创建相关的配置文件;下面我们介绍如何创建配置文件。

  在PS环境中,我们通过  new-item  cmdlet来创建配置文件。如下所示:

Exp:

  new-item   -path   %env:windir%\system32\windowspowershell\v1.0\profile.psl   -itemtype file  -force

  通过上面的命令,我们就创建一个影响所有用户和所有shell的用户配置文件;我们可以通过notepad或者PS ISE IDE环境来编辑这个配置文件,我个人推荐使用IDE环境

来编辑配置文件(虽然,很多时候,有些人不太支持用IDE环境来学习编程,但我个人认为,我们可以通过CLI形式来深入学习,但是实际开发中还是用IDE效率高)。

5、检测配置文件是否存在

  我们有时候不知道,在某个计算机上是否存在配置文件,如果直接的创建配置文件,可能将系统中原有的配置文件给覆盖掉,因此在创建之前有必要检测一下是否存在配置

文件。

  当然可以通过一层层的打开文件夹来查看,但是有没有更简单的方法呢? 答案是: 这个可以有,真可以有。

  在PS中我们通过 test-path cmdlet来检测是否存在配置文件。

Exp:

test-path  $profile

当存在$profile 配置文件时,这个命令返回 TRUE ;当不存在$profile 配置文件时,这个命令返回 FALSE.

注意: 在ISE环境中使用这个命令和在PS中使用时得到的命令可能不一样。

6、Powershell中基本概念

6、1 标准参数

  在传统的shell命令中,各个命令的使用的参数不同,不具有一致性,而在PS中,提供了一套标准的参数,这样有利于学习和使用cmdlet。

在PS中使用参数时,必须在参数前面加上 “-” 符号,表示后面的标识符为一个参数;例如:get-help  -name   get-item ;其中name是参数,但是在使用的

时候必须加上“-”; 表示这是一个参数。

6、2 帮助参数

  所有cmdlet使用 ? 参数来指示需要输出帮助信息,但是不执行该cmdlet

6、3 通用参数

  windows powershell提供一些通用参数,由于这些参数是由PS的解释引擎控制,因此当cmdlet实现这些参数是,都将具有相同的行为方式。通用参数包括

whatif、confirm、verbose、debug、warn、erroraction、errorvarible、outvariable和outbuffer。

6、4 建议参数

  PS核心的cmdlet对类似的参数使用标准名称,这些参数名称虽然是可选的,但是使用建议参数将有利于cmdlet开发的标准化。建议参数包括:Force、exclude、

include、passthre、path和casesensitive。

7、小结

  目前接触的都是一些基础内容,需要慢慢的体会;以后慢慢将讲解一些关于WMI管理的内容。

时间: 2024-10-24 22:56:36

PowerShell_零基础自学课程_5_自定义PowerShell环境及Powershell中的基本概念的相关文章

PowerShell_零基础自学课程_1_初识PowerShell

欢迎转载本系列文章:转载请注明出处:www.cnblogs.com/volcanol 自从微软推出.Net以来,微软旗下的windows体系就发生了很大的变化,首先是操作系统的界面的变化,例如vista与XP的界面变化, 其次是一些应用的变化,例如在XP下就没有Aero桌面效果,而在Win7下就有Aero桌面效果(本人没有用过vista,不知道有没有Aero的效果). 但这些都是用户直观的感受,除了这些还有更深层次的变化,如C++的CLR和CLI.以及一些时下非常流行的技术(像WPF.WCF还有

PowerShell_零基础自学课程_6_PS中获取帮助信息详解、管道、格式化输

前些文章陆续的说了一些关于这些主题,但是讨论的都不够深入,今天我们深入的了解一下获取帮助信息.管道以及格式化输出的内容. 一.获取帮助信息 在PS中获取帮助信息,最常用的有: -? .get-command和get-help.这三者获取的信息不是完全一致的,并且由于get-command和get-help是cmdlet:因此具有很多实用 的参数来帮助我们获取我们想要的信息. 1.1  -? 参数 如果我们知道某个cmdlet的拼写,但是不知道他的用户,那么最快速的方法就是用:-? 参数. 例如:

PowerShell_零基础自学课程_3_如何利用Powershell ISE调试PS脚本

微软在推出PS的同时,没有忘记其一贯的作风,什么东东都弄一个IDE环境,这不微软没有忘记给PS也来一个IDE的环境, 通过这个IDE环境,可以建立psl文件,可以调试psl文件. 1.IDE界面 我们看一下IDE环境的界面: 如图所示: IDE环境被分成了三个窗格,这个窗格的布局可以自定义.其中左上角的窗格是输出窗格,在IDE中执行的结果 通过它输出:左下角的窗口是交互窗格,也叫做命令窗格,可以在里面输入要执行的命令,同时这个窗格还会提示当前的工作路径, 上图的工作路径是:C:\users\vo

PowerShell_零基础自学课程_2_Powershell与Cmd以及Unix/Linux Shell

上篇文章我说道,windows为了改变用户对其console界面的诟病,于是就从windows   vista开始,计划要改变这种局面,于是就有 了Powershell的出现. 1.兼容shell命令 为了兼容Unix/Linux Shell(主要是bash)的命令:Powershell中提供了一套机制来兼容cmd.exe和bash命令.这就是上篇文章中提到 的别名机制.下图是powershell中兼容的cmd命令和unix/linux shell的命令. 2.标准命令的别名 同样,powers

PowerShell_零基础自学课程_8_高级主题:WMI对象和COM组件

本系列文章从最初的初识开始,基本上可以完成一些简单的系统管理了,为了更方便的管理系统,同时为了更好的发掘系统的性能,就需要用到系统提供 的一些高级特性,在Windows Server系列的OS中,如果可以利用最新的特性对系统进行管理,将会是一件非常不错的事情,虽然目前WinServer用的比较少 但是在一些地方还是有用到,尤其当某些场合需要非计算机专业的人员在服务器上进行操作的时候,winServer以其比Unix/Linux简单性更加适合应用.今天 这里就对PS中一些高级特性进行介绍. 一.W

零基础自学前端 D3.js 初体验03 柱状图+排序

<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>d3</title> </head> <script src="https://d3js.org/d3.v4.min.js"></script> <body> <button type="button"

python零基础自学——前篇自白

首先声明,本人就是个菜鸟,小白一个,在这里记录我自学python时的点点滴滴,用于我的经验积累以及复习.当然,若有零基础自学的人看见,交流学习经验那就最好不过了. python其实对零基础的小白来说就再适合不过了,为什么这么说,个人对编程的理解就是高.大.上.总感觉都是些BT才可以玩这个的. 我自己创业,开公司有过好的时候,但最后都倒闭了,积累如此阅历,却回首发现,自己没有一项术语自己的专业既能.所以就想学习编程.跟专业朋友交流以后,都推荐我学习python.原因有以下几点: 一:简单. 因为是

讨教大学:零基础自学编程,选JAVA,Python还是PHP?

越来越多非科班出身的人也义无反顾的投身到了IT互联网行业,加入了码农大军.但是对于非科班自学编程的朋友们来说,考虑的第一个问题一定是:我该从哪一个语言开始学起?在这里小编就为大家介绍一下零基础自学几大主流语言的优劣势. 首先从这几大语言的难度谈起,不同语言门槛和难度不同,Python<PHP<JavaScript<Java<C++.也就是说,Python是最好入门的一种语言,兼具易学性和趣味性,学几天就可以做出一些有意思的小功能出来.这也给了初学者学下去的信心和兴趣,不至于啃书几天

小猿圈web前端开发讲师:零基础自学html5开发方法

web前端开发目前市场使用率随着需求逐年递增.越来越多的年轻人转行进入了web前端开发领取.html5强大的功能是有目共睹的,本属自身独特的优势让这一技术越来越受欢迎,相比于原生APP,html5已经逐渐在用户体验生无限接近,再加上低廉的开发成本和强大的适配功能,早已经可以俘获开发商和开发者的芳心,本文小猿圈web前端开发讲师介绍零基础如何自学html5开发? 小猿圈web前端开发讲师:零基础自学html5开发方法: 1.拒绝插件,遇到交互效果就选择扒插件,这是一种非常不可取的方法,在这种情况之