2014/8/14
我已经把这个问题向微软反映了。还在坐等答复。
answers.microsoft.com
2014/8/11
新的一个星期又来了,今天在windows 论坛上把我的问题发出来了。希望找到大神帮我解决。
发现一个情况,如果没有更新windows update 很有可能爆出vclibs版本太低,不能安装app等。但是更新了update 后,依旧显示vclibs安装不对。
2014/8/7
把系统破解了。
使用winstore,下载app错误码变了。变成802460007和80070490
在事件查看里面还是有各种错误。
在windows 论坛上找了很久关于这些错误码的解决方法,没有一个是说到点子上的。这个修复metro app已经快让我逼疯了
2014/8/6
在开发win8的metro app卸载的时候,在公司测试发现有几台机子都没有检测出app。经过查看发现,其实metro app已经无法启动了。所以目前的研究方向和目的就是如何修复win8 app。直到现在,在这个问题上已经研究了一个星期了,完全走向了死路,毫无头绪。
还是先来总结一下现在研究到有用的内容吧
前提知识:
1.卸载app调用的是powershell 中的 remove-appxpackage
命令。在这里需要注意的是
- 该命令传入的参数是app的key name
- 该命令卸载的app,是你启动进程使用用户所拥有的app。例如,当你不是管理员账户,你用管理员账户启动powershell,那么卸载的不是当前用户的app,是管理员的app
2.获取app的命令是get-appxpackage
。这里有个小技巧,获取后可能显示很多app的详细信息,你可以使用配适语句来让结果更加明了。
-
get-appxpackage | select name
只会显示所有app的名字 -
get-appxpackage | where name -like *winjs*
只会显示名字和winjs匹配的app详细信息
3.安装app使用的命令是add-appxpackage
,也有两个需要注意的地方。
-
add-appxpackage -path <string>
直接安装appx文件 -
add-appxpackage -regiser <string> -disabledebelopmentmode
这个是修复win8 app的重要命令,需要传入的是appxmainfest.xml文件路径,让系统可以重新注册安装app。也就是在没有appx安装包的时候,我们可以安装app的方式,这应该是提供给开发者在开发app没有在winstore上架的时候,安装本app使用的。
4.这个appxmainfest.xml是个什么文件呢?
- 这个文件是应用部件清单声明应用的标识、应用的功能以及用来进行部署和更新的信息。
5.那AppxBlockMap.xml和AppxSignature.p7x又是什么文件呢?
- 应用包块映射文件 (AppxBlockMap.xml)块映射文件列出包中包含的所有应用文件,以及操作系统用来验证文件完整性和优化应用更新的相关加密哈希值。应用包数字签名文件 (AppxSignature.p7x)应用包签名可确保包及其内容在签名之后未进行过更改。 如果签名证书验证为可信根证书颁发机构的证书,则该签名还标识包的签名者。包的签名者通常是应用的发布者或作者。
6.metro app有3种开发模式
- 第一是C#,第二C++,第三Javascript。分别对应了不同的运行时,.net、vclibs、winjs,这三个运行时。如果缺少运行时,metro app是运行不起来的。也是就很多人发现,app目录下有exe执行文件,但执行他却不能启动app,提示的就是缺少 app container。
好了。前提知识讲完了,现在我们来一步一步研究如何修复这个win8 metro app。
总所周知,win8这个系统真的是非常烂。特别是在出现问题的时候,连网上google解决方案都没有,真的是很恶心。没办法,只有一步一步尝试咯。
目前最有效的一个。从注册表,可以重注恢复和无关联运行时的app,(pc设置,app商店,照相机,相册&skydiver)。powershell执行。
((Get-ChildItem "HKLM:SOFTWARE\Microsoft\Windows\CurrentVersion\Appx\AppxAllUserStore\InboxApplications") | Get-ItemProperty).Path | Add-AppxPackage -Register -DisableDevelopmentMode
从文件夹,重注恢复运行时的方式。cmd执行
FOR /F %I IN ('dir "c:\Program Files\windowsapps\microsoft.vclibs*" /B') DO (call powershell -ExecutionPolicy Unrestricted Add-AppxPackage -DisableDevelopmentMode -Register 'c:\program files\windowsapps\%I\AppxManifest.xml')
FOR /F %I IN ('dir "c:\Program Files\windowsapps\microsoft.winjs*" /B') DO (call powershell -ExecutionPolicy Unrestricted Add-AppxPackage -DisableDevelopmentMode -Register 'c:\program files\windowsapps\%I\AppxManifest.xml')
以上两种方法都可以引升到修复其他app。但是为产生许多其他的问题
在修复其他app的过程中,基本上会爆运行时找不到的问题。
在修复运行时过程中,又会爆app中的某些文件缺少的问题。
综上,可以得知。重注或者安装运行时的时候,系统会同时重注所有关联这个运行时的app。同理,在重注app时,也会去重注与这app关联的其他app,例如运行时。
好了,但不是我们之前不是修复了win store吗,那我们直接把所有坏的app卸载了重新安装一遍不就可以了。NO!现在才开始了噩梦。win store开始爆各式各样的错误了。
下载安装,app安装一直处于pending状态。
运行wsreset.exe,清理下载缓存。爆0x8007064A错误
将HKEY_CURRENT_USER\Software\Classes\Local Settings\Software\Microsoft\Windows\CurrentVersion\AppModel\Repository\Packages
改为SYSTEM拥有爆0x80070002错误
- 这个错误真的是要命,我已经花了一个星期的时间在这个错误上面了。网上所有的解决方法都是错的呀。妈蛋! 这0002应该是文件缺失的错误,你如果不放弃。可以试一试以下几种方式。
- 重启windows update服务,并设置服务为自动。在CMD中输入
net stop wuauserv net start wuauserv
。因为vclibs和winjs是由系统自动更新的,所以不一定系统自己就吧这个文件缺失更新上去了呢。 - 修复系统
sfc /scannow
DISM.exe /Online /Cleanup-image /Scanhealth
DISM.exe /Online /Cleanup-image /Restorehealths
- 修改ie设置 LAN settings - Uncheck the “Use a proxy server for your LAN” check box
- 在网上找到运行时的最新安装包,安装上去。
- 将好电脑的注册表值复制注册表到破电脑里面。看看有没有效果。
相关位置有:
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Appx\AppxAllUserStore\Applications
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Appx\AppxAllUserStore\<用户的SID号>
HKEY_CURRENT_USER\Software\Classes\Local Settings\Software\Microsoft\Windows\CurrentVersion\AppModel\SystemAppData
HKEY_CURRENT_USER\Software\Classes\Local Settings\Software\Microsoft\Windows\CurrentVersion\AppModel\Repository\Families
HKEY_CURRENT_USER\Software\Classes\Local Settings\Software\Microsoft\Windows\CurrentVersion\AppModel\Repository\Packages
如果不能复制或者输入到注册表,试一试修改权限,将拥有用户修改为自己,弄完以后再修改回去。 - 最有效的方法新建一个新用户,系统会在新用户登录初始化的时候,安装原装的app(获取预安装app
Get-AppXProvisionedPackage
)。登陆后,metro app完美使用。但你必须将老用户的东西都备份到新用户这里来
好了到这里真的是走头无路了。没办法完美的在原有用户上恢复app了。研究了一个星期哭晕在厕所的节奏。