在windows系统下,golang程序如何申请提升权限

本文有问题,请不要尝试源码

package main

import (
    "fmt"
    "os"
    "syscall"
    "unsafe"
)

func main() {
    for i := 1; i < 3; i++ {
        check()
    }

}
func check() {
    if os.Geteuid() == 0 {
        fmt.Println("Already running as root")
        return
    }

    // 获取程序的路径
    path, err := os.Executable()
    if err != nil {
        fmt.Println(err)
        return
    }

    // 获取当前进程的句柄
    handle, err := syscall.LoadLibrary("shell32.dll")
    if err != nil {
        fmt.Println(err)
        return
    }
    defer syscall.FreeLibrary(handle)

    // 获取ShellExecuteW函数的地址
    proc, err := syscall.GetProcAddress(handle, "ShellExecuteW")
    if err != nil {
        fmt.Println(err)
        return
    }

    // 调用ShellExecuteW函数以请求管理员权限
    args := []uintptr{
        0,
        uintptr(unsafe.Pointer(syscall.StringToUTF16Ptr("runas"))),
        uintptr(unsafe.Pointer(syscall.StringToUTF16Ptr(path))),
        0,
        0,
        0,
    }
    ret, _, err := syscall.Syscall6(uintptr(proc), 6, args[0], args[1], args[2], args[3], args[4], args[5])
    if ret != 0 {
        fmt.Println("Successfully requested admin privileges")
        return
    } else {
        fmt.Println("Failed to request admin privileges")
        fmt.Println(err)
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值