• <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或更高版本
            久久99热这里只有精品国产| 亚洲午夜久久久| 老男人久久青草av高清| 大美女久久久久久j久久| 久久久久久毛片免费播放| 亚洲欧美日韩中文久久| 久久中文字幕人妻丝袜| 亚洲精品NV久久久久久久久久| 久久精品99无色码中文字幕| 久久久久婷婷| 亚洲精品无码久久久久| 伊人色综合久久天天人手人婷 | 精品久久久久久无码中文字幕一区| 国产A三级久久精品| 久久精品九九亚洲精品| 91精品国产乱码久久久久久 | 国产精品99久久免费观看| 久久丫精品国产亚洲av不卡| 久久天堂电影网| 婷婷久久综合九色综合九七| 久久午夜夜伦鲁鲁片免费无码影视| 亚洲中文字幕久久精品无码喷水| 久久66热人妻偷产精品9| 精品国产福利久久久| 久久影视国产亚洲| 老色鬼久久亚洲AV综合| 国产AⅤ精品一区二区三区久久| 欧美日韩精品久久久久| 久久久久亚洲AV成人片 | 久久久婷婷五月亚洲97号色 | 国产精品欧美久久久天天影视| 久久se精品一区精品二区国产| 久久久无码精品亚洲日韩京东传媒 | 漂亮人妻被黑人久久精品| 丰满少妇人妻久久久久久4| 久久国产香蕉一区精品| 亚洲国产精品无码久久SM| 99久久精品免费看国产一区二区三区| 合区精品久久久中文字幕一区| 国产精品一久久香蕉国产线看| 午夜精品久久久久久久无码|