powershell Win32 API:本地用户管理(2)

本文介绍了如何在C#中利用`NetUserEnum`函数从`netapi32.dll`库枚举本地所有用户,包括优点(如枚举额外内容)和缺点(模块过大、API结构复杂)。
摘要由CSDN通过智能技术生成

声明:未经允许不得转载,转载时请标注来源;禁止用作商业及其他衍生目的。

有误请指正,侵权请联系删除。有更好的方法也请联系我求赞,关注,评论

主要目的:实现枚举本地的所有用户。

食材:netapi32.dll


[void](Add-Type -TypeDefinition @"
using System;
using System.Collections.Generic;
using System.Runtime.InteropServices;

public class UserEnum
{
    // 定义Netapi32.dll库中的函数
    [DllImport("Netapi32.dll", CharSet = CharSet.Unicode)]
    private static extern int NetUserEnum(
        string serverName,
        int level,
        int filter,
        out IntPtr userInfo,
        int prefMaxLen,
        out int entriesRead,
        out int totalEntries,
        out int resumeHandle);

    [DllImport("Netapi32.dll")]
    private static extern int NetApiBufferFree(IntPtr buffer);

    // 定义USER_INFO_1结构体
    [StructLayout(LayoutKind.Sequential, CharSet = CharSet.Unicode)]
    public struct USER_INFO_1
    {
        public string username;
        public string password;
        public int passwordAge;
        public int privilege;
        public string homeDirectory;
        public string comment;
        public int flags;
        public string scriptPath;
    }

    public static List<string> EnumerateUsers()
    {
        // 调用NetUserEnum来获取用户信息
        List<string> userList = new List<string>();
        int entriesRead, totalEntries, resumeHandle;
        IntPtr pBuffer;

        int result = NetUserEnum(null, 1, 0, out pBuffer, -1, out entriesRead, out totalEntries, out resumeHandle);

        if (result == 0 && entriesRead > 0)
        {
            IntPtr pBufferTemp = pBuffer;
            for (int i = 0; i < entriesRead; i++)
            {
                // 将指针转换为USER_INFO_1结构体
                USER_INFO_1 user = (USER_INFO_1)Marshal.PtrToStructure(pBufferTemp, typeof(USER_INFO_1));
                userList.Add(user.username);

                // 将指针移到下一个结构体
                pBufferTemp = new IntPtr(pBufferTemp.ToInt64() + Marshal.SizeOf(typeof(USER_INFO_1)));
            }

            // 释放内存
            NetApiBufferFree(pBuffer);
        }

        return userList;
    }

}
"@)
[UserEnum]::EnumerateUsers()   #实现本地用户列表的枚举
优点:可枚举net.exe无法枚举的内容

缺点:c#模块过大,主要部分(API,结构)过于复杂,但都可以简化(为效率和稳定性应适当减少重复循环性质的powershell代码)

  • 10
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值