c# 使用特定帐号密码访问Windows网路共享
透过程式存取windows网路分享的档案也算常见需求,但存取身分是个问题。之前我惯用的技巧是用有权限的ad网域帐号执行排程存取网路分享,但这招要搬进网站或遇到不同网路分享用不同帐号便会破功。最近遇上类似议题,直觉要得回头靠winapi impersonation解决,之前曾写过通用元件,担心11年前windows vista/7时代的作品有点过时,就爬文找找更好的做法。
之前的变身做法是改变thread的执行身分,然而针对网路分享还有另一个winapi - wnetaddconnection2,可做到对多个网路分享使用不同登入身分。在*找到有人分享把它包成搭配using使用的context物件,符合我惯用的风格,二话不说,按赞并写文分享。
为方便使用,我再做了一层包装,写了一个networkcopier,将查目录或复制档案动作简化成copy(srcnetpath, targetpath, domain, userid, passwd)、dirfiles(srcnetpath, domain, userid, passwd),并支援预设帐密可省略输入domain, userid, passwd;另外还有getconnetioncontext(path, domain, userid, passwd) 可取回networkconnection 物件方便用同一连线身分进行多项操作,若来源与目的属不同网路分享则可套叠多重身分,写成:
建立networkconnection时,需要引入共享路径而不是完整路径,例如要访问\\svra\share\subfolder\test.txt,建立networkconnection的参数为\\svra\share\,为省去人工截取的麻烦,我写了一段正则表达式更顺手。
完整程式如下,需要的朋友请自取使用:
以上就是c# 使用特定帐号密码访问windows网路共享的详细内容,更多关于c# 访问windows网路共享的资料请关注其它相关文章!