In the previous tip we showed how to import digital certificates with .NET methods on any version of PowerShell. Newer versions of PowerShell come...
ps1
Categories
- Free tools
- SQL Admin Toolset
- SQL Compliance Manager
- SQL Defrag Manager
- SQL Diagnostic Manager for MySQL
- SQL Diagnostic Manager for SQL Server
- SQL Diagnostic Manager Pro
- SQL Doctor
- SQL Enterprise Job Manager
- SQL Inventory Manager
- SQL Query Tuner for SQL Server
- SQL Safe Backup
- SQL Secure
- SQL Workload Analysis for SQL Server
- Uptime Infrastructure Monitor Formerly Uptime
Directly Importing Certificates (Part 1)
Installing certificate files on a computer can be done using .NET methods with any version of PowerShell. This would import a certificate file to...
Beware of Aliases
Can you spot what is wrong here? PS C:\> function r { "This never runs" } PS C:\> r function r { "This never runs" } PS C:\> When you run...
Dealing with Long File Paths
Historically, the Windows file system sometimes stalls when paths grow longer than 256 characters. There is a module available at the PowerShell...
Detecting Character Code 0
Occasionally, strings use a “Byte 0” character as a delimiter. Unlike most other delimiters, this delimiter does not show in text output...
Auto-Declaring Alias Names for Functions
You probably know that PowerShell supports alias names for commands. But did you know that you can define alias names for PowerShell functions...
Checking Operating System Version
Here is a simple and fast way of checking the operating system version: PS C:\> [Environment]::OSVersion Platform ServicePack Version...
Comparing Against $NULL
If you want to find out whether a variable contains $Null (nothing), always make sure you keep $null on the left side of the comparison. Most of the...
Examining Certificate Details
If you’d like to examine and view the details of a certificate file without the need to import it into your certificate store, here is a...
Exporting ActiveDirectory Module
To manage users and computers in your Active Directory from PowerShell, you need the ActiveDirectory module which comes as part of the free RSAT...
Managing NTFS Permissions
While there are not many built-in cmdlets to manage NTFS permissions, there is a growing list of open source PowerShell modules adding these. One...
Determine if Array Contains Value – Using Wildcards
If you’d like to know whether an array contains a given element, PowerShell provides the –contains operator. This operator does not...
Working with LDAP and Dates
LDAP filters are a fast and powerful way of retrieving information from Active Directory. However, LDAP filters use a very low-level date and time...
Using a PowerShell Parameter Validator
PowerShell function parameters support a ValidateScript attribute where you can assign PowerShell code. The code is invoked when the parameter...
Casting Data with Culture
When casting data (converting it to a different data type), PowerShell supports two approaches that can differ considerably. Here is an example:...
Invoking a Script Block
Code inside a script block can either be invoked by call operators such as „&“ or „.“, or by calling the Invoke()...
Running Cmdlets without Verb
This has been part of PowerShell since version 1.0: cmdlets with verb „get“ can be invoked without the verb. So instead of...
Texts with Maximum Length (Part 2)
Here is another strategy to make sure a text does not exceed a given length. In contrast to our previous tip, this code will not pad spaces in case...
Texts with Maximum Length (Part 1)
If you want to make sure a text is of given length, here is an easy approach: $text = 'this is a long text' $MaxLength = 10...
Finding All Profiles with Desktop
This simple line dumps all paths to all desktops found in any of the local user profiles – just make sure you are running the line with...
Where-Object and .Where()
Beginning in PowerShell 4, you can use the Where() and Foreach() methods in place of Where-Object and ForEach-Object whenever you do not want to use...
Creating Object Arrays on the Fly
Here is a quick code sample that generates an array of objects using the built-in CSV parser: $csv = @' PC,Date PC82012,2017-02-28...
Exploring Type Accelerators
PowerShell uses a number of so-called type accelerators that help with long .NET type names. Instead of using...
Dangerous Temp Files!
Internal system functions are often helpful, but always make sure you fully understand what they do. A particularly popular system method is called...