一.需求描述:
对于PCB制造企业来说,基本都采用建立共享目享+域名管控权限,好像别的大多数行业都是这样的吧。呵呵
在实际应用中,经常会有这样的问题,自己登入的帐号没有共享目录的权限,但又想通过程序实现访问共享目享的权限
二.应用场景:
1.服务器端:
例1:工程系统提供接口给OMS订单管理系统调用,当销售人员通过OMS系统传文件给工程接口后,需要将销售传的客户文件放到工程部的公共目录中去
但此时服务器端是本地登入,无公共目录访问权限,此模拟windows域帐号登入的正好可以用上了。
2.客户端:
例1: 工程部小A 需从某个公共目录拷贝文件到本机目录,但自己的域帐号无权限,只要小A使用了工程系统,
在工程系统中某个触发点增加模拟windows域帐号登入,即可实现此功能了。
三.代码实现:
string info = ""; try { IntPtr admin_token = IntPtr.Zero; if (WinLogonHelper.LogonUser(ref admin_token) != 0) { using (WindowsIdentity wid_admin = new WindowsIdentity(admin_token)) { using (WindowsImpersonationContext wic = wid_admin.Impersonate()) { string[] files = Directory.GetFiles(@"\192.168.11.11ShareFiles", "*.tgz"); //获取网盘tgz文件清单 File.Copy(@"\192.168.11.11aa.zip", @"e:a.zip");//将网络盘ZIP拷贝 } } } else { info = $"无文件访问权限"; } } catch (Exception ex) { info = $"异常: {ex.Message}"; }
public class WinLogonHelper { /// <summary> /// 模拟windows登录域 /// </summary> [DllImport("advapi32.DLL", SetLastError = true)] public static extern int LogonUser(string lpszUsername, string lpszDomain, string lpszPassword, int dwLogonType, int dwLogonProvider, ref IntPtr phToken); public static int LogonUser(ref IntPtr phToken) { return WinLogonHelper.LogonUser("用户名", "域名", "密码", 2, 0, ref phToken); } }