我正在创建一个Windows 8商店应用程序.这个应用程序的前端(主项目)是HTML5 / Javascript.我正在关注this guide by Tim Heuer创建一个C#WinRT组件,它包装了SQLite调用并充当控制器.前端通过Javascript调用此组件,以更新数据并获取演示文稿内容.
所以我的解决方案中有2个项目,javascript中的“main”和C#中的“db”.我已经设法让SQLite按照指南工作了.我有这种结构的原因是我正在尝试将应用程序从iOS移植到Win8. “控制器”部分是一个独立的组件,它已经移植到C#.
但是,有一点需要注意.因为this known problem,我必须从’db’项目中删除对C Runtime v11的引用,以使其可编译.虽然它在开发机器上运行良好.
然后我得到了这台测试机(三星xe700t1a确切地说是Intel i5),我发现当在这台测试机器上“调试远程”时,Visual Studio将不会部署SQLite3.结果,我的SQLite调用失败并出现错误:“无法加载DLL的sqlite3”:找不到指定的模块.(HRESULT异常:0x8007007E)“.
根据我之前提到的指南,SQLite通过WinRT扩展可用,是为了自动部署.
我想知道为什么会发生这种情况以及如何使其正确?我也想知道这个结构中的应用程序是否存在针对Windows应用商店的任何认证问题?
我还遇到了this post和this post,表明目前无法在WinRT组件中使用SQLite.但现在改变现在为时已晚,如果没有混合结构,这个项目将无法实现.
解决方法:
我找到了解决方案.我使用了this post的提示,而且非常简单.
我要做的是在解决方案中创建另一个项目,输出类型设置为C#类库.将引用移动到SQLite for WinRT,并将sqlite-net(nuget)包装器移动到这个新项目.之后,我必须手动浏览sqlite-net中的类,并将所有“内部”类更改为“public”.
对于原始控制器项目,我使用myclasslib添加;以便找到类定义.
显然,这种解决方法将完美无瑕地运作.部署了SQLite3,并且没有针对缺少引用的警告.