解決Godaddy主機asp.net無法上傳檔案的問題

來源:互聯網
上載者:User
 

        Godaddy的WINDOWS主機,asp.net的信任模式為中等,如果是新站子站中使用檔案操作將會出現無許可權調用程式集的錯誤!相信很多朋友都曾嘗試過很多辦法,但結果非常令人失望,Godaddy不允許在Web.Config中修改信任模式,有的朋友將asp.net的版本設定為1.1,這樣就可以使用完全的信任模式。那我們的程式是.net2.0甚至是.net 4.0的怎麼辦呢?

         以下我就會通過一個檔案上傳的例子來說明如何解決Goddady主機的無許可權調用程式集的解決辦法!

         

         如果在子站中上傳檔案,就會提示沒有I/O操作的許可權,如:

       

        AllowPartiallyTrustedCallersAttribute 特性允許部分分受信任的代碼調用某個程式集,該特性位於System.Security命名空間下。

只能用於程式集,只要我們為程式集添加該特性,那我們的代碼就能調用System.Security.Permissions.FileIOPermission程式集。

代碼如下:

 

using System.Reflection;  

using System.Security;  

using System.Runtime.CompilerServices;  

using System.Runtime.InteropServices;  

   

// 有關程式集的常規資訊通過下列屬性集  

// 控制。更改這些屬性值可修改  

// 與程式集關聯的資訊。  

[assembly: AllowPartiallyTrustedCallers]  

[assembly: AssemblyCompany("OPSoft Inc.")]  

[assembly: AssemblyProduct("OPSite.Web")]  

[assembly: AssemblyCopyright("著作權 (C) www.ops.cc 2011")] 

 

 

我們需要添加粗體部分到我們的程式集資訊檔中。現在我們可以再試試上傳功能,發現隱藏檔的時候:

Server.MapPath("~") 返回的路徑已經是根目錄了,那子站的檔案上傳到根目錄肯定沒有這個許可權的!

可以使用AppDomain.CurrentDomain.BaseDirectory 擷取當前程式集的目錄路徑。

 

這樣asp.net就可以完美的在goddady的子站中上傳檔案和I/O操作了!

 

文章由劉銘(奧博網路站長)撰寫,轉載請保留原文地址

 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.