• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            S.l.e!ep.¢%

            像打了激速一樣,以四倍的速度運轉,開心的工作
            簡單、開放、平等的公司文化;尊重個性、自由與個人價值;
            posts - 1098, comments - 335, trackbacks - 0, articles - 1
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            用戶賬戶管理數據重定向(UAC)

            Posted on 2010-05-13 16:22 S.l.e!ep.¢% 閱讀(800) 評論(0)  編輯 收藏 引用 所屬分類: UAC

            用戶賬戶管理數據重定向(UAC)

            cince , 2009/12/25 14:28 , TechNet , Comments(0) , Reads(361) , Via Original
            一些在xp下設計的程序,轉到vista\7下就不能運行了。尤其是那種寫入注冊表的,寫入program file文件夾的程序。
            在msdn上給出了解釋。uac還有這樣子的保護,相當于虛擬機了。
            [來自MSDN]
            很多應用程序都設計為把文件寫入Program Files,Windows目錄,或者系統根(一般是C盤)文件夾。一些應用程序被設計為更新Microsoft Windows 注冊表的值,特別是HKLM/Software中的值。但是這樣會有存在一個問題:文件或注冊表的值并沒有被創建或更新。您可能會問,“怎么回事?我的應用程序運行良好并沒有報錯啊。我的文件到底去哪兒了?”

            您可能遇到過下面的一種或多種情況:

            ??? 您的應用程序寫入Program Files,Windows目錄,或者系統根(一般是C盤)文件夾,但是您在這些地方并沒有找到您的文件

            ??? 您的應用程序寫入Windows注冊表,特別是HKLM/Software中,但是您沒有看到注冊表進行了更新

            ??? 您切換到了另一個帳戶,并且您的應用程序沒有辦法找到已寫入Program Files,Windows目錄,或者系統根(一般是C盤)文件夾的文件,或者找到了這些文件的老版本

            ??? 在啟用或禁用用戶帳戶控制(UAC)后,您的應用程序都沒有辦法找到Program Files或Windows目錄中的文件

            如果這些出現在了您的應用程序中,都是由于UAC虛擬化的原因。下面所提供的信息為您介紹了所有關于發現這個應用程序兼容性問題,解決方案,以及特殊兼容性問題的一些附加信息。

            真正的問題:UAC 虛擬化

            在Windows Vista中,一般由管理員來運行應用程序。這樣,應用程序可以自由的讀寫系統文件和注冊表的值。如果標準用戶可以運行這些應用程序,那他們可能會由于沒有足夠的權限而導致失敗。Windows Vista通過重定向寫入(以及后續文件或者注冊表操作)對應用戶的配置文件(profile)位置,來對標準用戶運行應用程序的能力進行了提升。

            例如,如果一個應用程序試圖寫入C:\Program Files\Contoso\Settings.ini,并且用戶沒有權限來對該文件夾進行寫入操作,寫入操作將會被重定向到C:\Users\Username\AppData\Local\VirtualStore\Program Files\Contoso\settings.ini。如果應用程序試圖在注冊表中寫入HKEY_LOCAL_MACHINE\Software\Contoso\,這將會被自動重定向到HKEY_CURRENT_USER\Software\Classes\VirtualStore\MACHINE\Software\Contoso或HKEY_USERS\UserSID_Classes\VirtualStore\Machine\Software\Contoso。

            下圖顯示了Windows 虛擬化進程的兩個組件:文件虛擬化和注冊表虛擬化
            Open in new window
            ??重要注意

            當為Windows Vista開發應用程序時,請確定在對應的requestedExecutionLevel元素中嵌入應用程序清單文件。這將會關閉文件和注冊表虛擬化,減少虛擬化的文件和注冊表值的復雜性。


            更多關于UAC虛擬化和新UAC技術,請參閱“Windows Vista中的新UAC技術”http://msdn.microsoft.com/en-us/library/bb756960.aspx .

            解決方案

            虛擬化是為了幫助現存的應用程序解決兼容性問題而出現的。為Windows 7而設計的新的應用程序不應該對敏感的系統區域進行寫入操作,不應該依靠虛擬化來對不正確的應用程序行為進行修正。開發應用程序的時候,應該始終考慮使其運行在標準用戶的權限下,而不是在管理員權限下運行。測試您的應用程序時,也要用標準用戶權限而不是管理員權限。

            如果您正在使用UAC虛擬化來為Windows 7開發應用程序,那么請將您的應用程序重新設計為將文件寫入合適位置。當更新現有的代碼以在Windows 7上運行的時候,您應該:

            ??? 確定在運行時,應用程序存儲數據只是在對應用戶的位置或者在對訪問控制列表(ACL)進行了設置的%alluserprofile%系統位置。更多關于ACLs的信息,請參閱訪問控制列表.

            ??? 使用已知的文件夾來寫入數據文件。所有用戶可以使用的一般數據應該被寫入一個對所有人共享的公共位置。所有其他的數據都應該被寫入對應用戶的位置。

            o??一般數據文件可以包含,但不限制,日志文件,配置文件(INI/XML),狀態存儲應用程序例如保存的游戲等等。

            o??用戶文件則不同;它們應該被保存到Documents文件夾(或者用戶指定的位置)

            ??? 確保您沒有在代碼中指定你覺得合適的路徑。建議您使用下面的模型和APIs來獲取特定已知的Windows的正確路徑:

            o??C/C++ native 應用程序: 使用SHGetKnownFolderPath方法來獲取已知文件夾的整個路徑,它們可以用文件夾的KNOWNFOLDERID來識別。它是一個標識您想要獲取的已知位置的GUID參數:

            ??????????? FOLDERID_ProgramData – 向所有人共享項目數據的目錄

            ??????????? FOLDERID_LocalAppData – 對應用戶項目數據的目錄(不可移動的)

            ??????????? FOLDERID_RoamingAppData –對應用戶項目數據的目錄(可移動的)

            o??托管代碼: 使用System.Environment.GetFolderPath方法。GetFolderPath包含一個標識您想要獲取的已知位置的參數:

            ??????????? Environment.SpecialFolder.CommonApplicationData –向所有人共享項目數據的目錄

            ??????????? Environment.SpecialFolder.LocalApplicationData –對應用戶項目數據的目錄(不可移動的)

            ??????????? Environment.SpecialFolder.ApplicationData –對應用戶項目數據的目錄(可移動的)

            ??? 如果上面提到的方法都不起作用,則請您使用環境變量:

            o??%ALLUSERSPROFILE% –向所有人共享項目數據的目錄

            o??%LOCALAPPDATA% –對應用戶項目數據的目錄(不可移動的) - Windows Vista或更高版本

            o??%APPDATA% –對應用戶項目數據的目錄(可移動的) - Windows Vista或更高版本
            无码任你躁久久久久久久| 亚洲va久久久噜噜噜久久男同| 一本久久综合亚洲鲁鲁五月天亚洲欧美一区二区 | 日产久久强奸免费的看| 久久不见久久见免费影院www日本| 91精品国产高清91久久久久久| 欧美大香线蕉线伊人久久| 欧美牲交A欧牲交aⅴ久久| 无码国内精品久久人妻| 久久综合久久自在自线精品自 | 日韩精品无码久久久久久| 久久一日本道色综合久久| 久久久久久无码Av成人影院| 97久久精品无码一区二区| 国产精品久久久久久吹潮| 久久精品草草草| 国产巨作麻豆欧美亚洲综合久久 | 久久久久免费精品国产| 亚洲精品无码久久一线| 国内精品久久久久影院一蜜桃| 77777亚洲午夜久久多喷| 久久亚洲国产中v天仙www| 久久国产乱子伦精品免费午夜| 日韩十八禁一区二区久久| 亚洲综合熟女久久久30p| 久久国产乱子精品免费女| 久久精品二区| 亚洲精品午夜国产VA久久成人| 国产99精品久久| 亚洲国产日韩综合久久精品| 久久精品国产亚洲AV麻豆网站| 日本久久久久久中文字幕| 色综合久久夜色精品国产| 久久人人爽人人爽人人片AV不| 久久综合九色综合欧美狠狠| 国产精品久久久久久久久久影院| 久久久精品人妻一区二区三区四| 精品久久人人做人人爽综合| 亚洲中文字幕无码久久2020| 丁香五月综合久久激情| 久久婷婷激情综合色综合俺也去 |