有時我們需要將來自於用戶端的檔案上傳到WEB伺服器端,並在服務端將檔案儲存體到第三方檔案伺服器中儲存。
實現如下:
1、在檔案伺服器B上建立一共用資料夾,同時在該伺服器上建立一使用者,如DocShareUser,給此使用者指派共用資料夾的讀寫權限
2、在WEB伺服器A上也同時傳建一同名使用者DocShareUser (注意,使用者名稱和密碼必須一致)
3、在網站下添加一虛擬目錄,虛擬目錄的實體路徑執行伺服器A的共用目錄,路徑符合UNC規則,如\\ServerB\DocShare,傳遞身分識別驗證使用者佈建為預設即可。
4、信任關係許可權,只有在建立信任的基礎上,方可向B伺服器上傳檔案,該問題可通過兩種方式解決,
方式1:在Web.Config中增加運行類比帳號<identity impersonate="true" userName="DocShareUser" password="password" />
方式2:在Global.asax中載入,網站一運行就自動建立信任關係,System.Diagnostics.Process.Start("net.exe", "use \\\\B伺服器的IP\\共用資料夾 \"B伺服器上的密碼\" /user:\"B伺服器上的使用者名稱\""),B伺服器上的使用者是指能寫入那個共用資料夾的使用者 (建議使用此方式,不會影響網站認證的變化)
5、步驟4如採取Web.Config中增加類比帳號方式,則需要給C:\Windows\Microsoft.NET\Framework64\v4.0.30319\Temporary ASP.NET Files臨時目錄分配所建使用者DocShareUser的讀寫控制許可權 (路徑視安裝Framework版本而定)
6、代碼中通過Server.MapPath("虛擬目錄")方式擷取上傳地址,寫入檔案流即可
7、注意上傳檔案IIS有預設4M限制,可通過WEB.config修改,如下
複製代碼 代碼如下:<httpRuntime maxRequestLength="10240" appRequestQueueLimit="90" executionTimeout="90"/>
以上在WIN2008R2+IIS7下驗證通過。