PowerShell 技能连载 - 使用 FTP:上传文件(第 4 部分)
PowerShell 不附带用于通过 FTP 下载和上传数据的 cmdlet。但是,您可以使用 .NET 来实现。
要将文件从本地驱动器上传到 FTP 服务器,请尝试以下代码:
1 | $localFile = "C:\test.txt" |
PowerShell 技能连载 - 使用 FTP:上传文件(第 4 部分)
PowerShell 不附带用于通过 FTP 下载和上传数据的 cmdlet。但是,您可以使用 .NET 来实现。
要将文件从本地驱动器上传到 FTP 服务器,请尝试以下代码:
1 | $localFile = "C:\test.txt" |
PowerShell 技能连载 - 使用 FTP:下载二进制文件(第 3 部分)
PowerShell 不附带用于通过 FTP 下载和上传数据的 cmdlet。但是,您可以使用 .NET 来实现。
要以二进制模式从 FTP 服务器下载文件,请尝试以下代码,该代码还说明了如何使用显式凭据进行身份验证:
1 | $username='testuser' |
PowerShell 技能连载 - 使用 FTP:下载文件(第 2 部分)
PowerShell 不附带用于通过 FTP 下载和上传数据的 cmdlet。但是,您可以为此使用 .NET。
要从 FTP 服务器下载文件,请尝试使用以下代码:
1 | $localFile = "C:\test.txt" |
PowerShell 技能连载 - 使用 FTP:列出文件夹(第 1 部分)
PowerShell 不附带用于通过 FTP 下载和上传数据的 cmdlet。但是,您可以使用 .NET 来实现。
要显示 FTP 文件夹的内容,请尝试使用以下代码:
1 | $username='testuser' |
使用 Web 服务,确定您的公共 IP 地址和有关您的 ISP 的信息几乎是举手之劳:
1 | PS> Invoke-RestMethod -Uri https://ipinfo.io |
PowerShell 技能连载 - 显示警告对话框(第 2 部分)
在之前的技能中,我们创建了新的快捷方式文件,您已经看到 CreateShortcut() 方法如何提供方法来控制快捷方式的几乎所有细节。这是在桌面上创建 PowerShell 快捷方式的代码:
这个技能可以帮助您始终在其他窗口的顶部显示对话框。为此,下面的代码创建了一个新的虚拟窗口,并确保该窗口位于所有其他窗口的顶部。然后,此窗口用作弹出对话框的父级:
1 | Add-Type -AssemblyName System.Windows.Forms |
PowerShell 技能连载 - 显示警告对话框(第 1 部分)
这是一个显示弹出警告对话框的快速代码示例:
1 | Add-Type -AssemblyName System.Windows.Forms |
这些是可用的按钮样式:
1 | PS> [Enum]::GetNames([System.Windows.Forms.MessageBoxButtons]) |
这些是可用的图标样式:
1 | PS> [Enum]::GetNames([System.Windows.Forms.MessageBoxIcon]) |
有时,在 PowerShell 脚本中使用控制台应用程序很有用,甚至是必要的。例如,在上一个技能中,我们研究了删除映射网络驱动器的方法,尽管 Remove-PSDrive 声称能够执行此操作,但最可靠的方法仍然是使用旧的 net.exe 控制台命令。
让我们快速看看如何检查控制台命令是否成功完成。
让我们尝试通过映射一个新的网络驱动器,然后使用控制台应用程序将其删除。当然,您可以将相同的原则应用于您可能需要在 PowerShell 脚本中运行的任何控制台应用程序:
1 | PS> net use z: \\127.0.0.1\c$ |
创建好映射驱动器,然后再删除。但是,状态消息是本地化的(因此很难将它们与多国环境中的预期值进行比较),并且错误会作为异常出现。
通过使用 $?,您可以将输出转换为仅 $true 或 $false:$true 表示命令成功完成,而 $false 表示(任何)错误:
1 | PS> $null = net use z: \\127.0.0.1\c$; $result = $?; $result |
这要好得多,因为您的脚本随后可以判断 $result 并在出现错误时采取适当的步骤或将消息写入日志文件。
但是,如果出现错误,详细的错误信息仍会发送到控制台,并且没有(明显的)方法可以将其删除。即使是成熟的 try...catch 错误处理程序也不会响应它们:
1 | PS> $null = try { net use z: \\127.0.0.1\c$} catch {}; $result = $?; $result |
原因是:控制台应用程序不会抛出 .NET 异常。发生错误时,控制台应用程序仅通过输出流 #2 发出信息。
而这恰好是包装控制台应用程序的解决方案:将所有流重定向到输出流。这段代码映射了一个网络驱动器:第一次调用成功所有后续调用都失败:
1 | PS> $null = net use z: \\127.0.0.1\c$ *>&1; $? |
同样,这会再次删除映射的驱动器,就像在第一次调用成功之前一样,所有剩余的调用都会失败:
1 | PS> $null = net use z: /delete *>&1; $result = $?; $result |
虽然 Remove-PSDrive 可以删除包括网络驱动器在内的所有类型的驱动器,但更改可能要等系统重新启动时才能生效。这当然是荒谬的。
这个任务是一个很好的例子,为什么 PowerShell 使控制台应用程序成为平等公民是有用的。事实上,即使在 2021 年,移除网络驱动器的最可靠方法也是使用旧的但经过验证的 net.exe。下面的示例删除网络驱动器号 Z:
1 | PS> net use z: /delete |
有很多方法可以列出映射的网络驱动器。其中之一使用 PowerShell 的 Get-PSDrive 并检查目标根目录是否以 “\“ 开头,表示 UNC 网络路径:
1 | PS> Get-PSDrive -PSProvider FileSystem | Where-Object DisplayRoot -like '\\*' |
一个不错的方面是 Get-PSDrive 返回有用的附加详细信息,例如驱动器的大小。