- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在用phonegap/cordova 编写一个应用程序。在应用程序中,用户有一个个人资料,他们可以选择 Facebook 图片以包含在他们的个人资料中。
当他们为自己的个人资料选择图像时,我想将这些特定图像上传到我自己的服务器。
我做了一些研究,并能够编写一些下载图像的代码,但直到编写代码后我才在移动设备上进行测试。
我使用 XML HTTP 请求将图像下载为 blob。但是,在移动设备上进行测试时,我收到了未设置 blob.size 参数的错误。
我在浏览器中检查了一下,确实有 blob.size 参数存在。在移动设备中,blob.size 参数未定义。这让我相信我手机上的 webkit 不支持 blob,因此无法将图像下载为 blob。
我真的有两个问题:
1) 我的评估是否正确,因为 webkit 不支持 blob,所以未下载 blob?
2)如果1为真,在cordova中下载图像然后将其上传到我自己的服务器的正确方法是什么?或者,有什么方法可以调整我的代码,使其可以在移动设备上运行吗?另外我应该注意,由于文件已经下载到我的手机上,有没有办法简单地在本地存储中访问它们,而不是再次下载它们,然后将该文件上传到我的服务器?
我当前下载为 blob 的代码如下:
function xhrPromise(url){
var xhr = new XMLHttpRequest();
xhr.open('GET', url, true);
xhr.responseType = 'blob';
xhr.onload = function(e) {
if (this.status == 200) {
var myBlob = this.response;
return myBlob;
}
};
xhr.send();
}
根据进一步的研究,我想知道解决方案是否是使用 cordova 文件传输插件?
如有任何建议,我们将不胜感激。
最佳答案
1) Webkit 通过 HTML 文件 API 支持 blob。阅读:Exploring the FileSystem APIs
2)我会尽力为您指出正确的方向。如果我想下载图像然后将其重新上传到另一台服务器,我会做什么。
使用Cordova's FileTransfer Plugin下载图片并将其写入 SD 卡 (Android) 或应用程序文档文件夹 (iOS) 中的临时位置。
如果图像小于 2MB,请使用简单的 HTML 标记链接到下载的图片,使用 CDVFILE 协议(protocol) <img src="cdvfile://localhost/persistent/temp/image.jpg" />
(对于 Android)然后使用 AJAX 将图像编码为 base64 将其发布到您的服务器。阅读:How to convert image into base64 string using javascript .
如果图像超过 2MB,请使用 Cordova's FileTransfer Plugin上传。
在使用 Cordova 的 FileTransfer 插件时,您会遇到 HTML File API,我强烈建议您保留此链接作为引用。阅读:Exploring the FileSystem APIs
我更喜欢使用base64编码的原因是因为1)我不喜欢依赖Cordova插件,它们曾经是 super 有缺陷的。 2) 您可以将 base64 字符串保存到 MySQL(但任何超过 2MB 的字符串都会影响您的服务器和对其进行编码的设备)。
关于javascript - 如何在手机上下载图片并上传到我的服务器?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25492678/
在德国,移动运营商通常会提供一种简单的方法来配置您的手机的 MMS 和 GPRS:在运营商的网站上输入您的电话号码和设备型号后,您会收到一条发送给您的“配置短信”。 我试图从技术角度理解它是如何工作的
我正在开发一个非常复杂的应用程序。它针对手机和平板电脑有不同的布局,我不知道最好的方法。 我听说您可以发布两个不同的应用程序,一个用于移动设备,另一个用于平板电脑,但人们不推荐它。 我应该用两个不同的
我不确定这个问题属于这里....但仍然.... 我的应用程序每 3 分钟与服务器交换一次数据。我在手机覆盖范围内使用蜂窝平板电脑(不是 Wi-Fi)。如果一个人在没有手机覆盖的地方使用它,他将不会获得
我有这样的 CSS: .editTable-body { width: 100%; height:140px; margin-top: 20px; overflow:
我有这个链接,它在移动设备上被设计为按钮,我面临的问题是它在手机和平板电脑上看起来不同。这是因为设备分辨率还是我应该通过 CSS 修复的问题。这是我当前的 CSS CSS border-radiu
大家好,我一个月前开始学习网络开发,但我遇到了背景图片无法在移动设备上正确显示的问题。 我正在使用下面的模板,甚至这个模板也有同样的问题。 问题只是背景图像在移动设备上放大,而不是相应地与屏幕尺寸成比
我一直在尝试为我的网站制作一个导航栏,但是当我移动它时,我导航栏中的列表移动了 40 像素到计算机屏幕的右侧,那里没有任何东西。 你能帮帮我吗? 最佳答案 在您的导航栏样式中,将导航栏的宽度设置为 1
一周以来,我一直不明白为什么我的网站被设计成响应式的,一切正常吗?笔记本电脑即使放在小尺寸的情况下也能完美运行,然后进入我的手机却没有响应。 我试过卸载插件,我更改了主题,但找不到原因。 你能抱住我吗
我在 my website 上实现了以下字体. /* Vivaldi Font */ @font-face { font-family: 'vivaldi'; src: url('as
我正在使用 Angular 4 并构建一个应用程序。它工作正常,但当我在移动设备上运行时出现问题。整个风格发生了变化并分发了整个应用程序。我担心我必须做什么。任何帮助将不胜感激 最佳答案 在表格前取
我目前使用的是 HTC Wildfire 手机的接近传感器。问题在于,如果传感器前方 1 厘米范围内有物体,它只会返回一个 bool 值。 所以,我想问一下市场上是否有一款 Android 手机具有接
根据 this Android C2DM 通过心跳机制使套接字保持 Activity 状态,使其能够接收推送消息。这让我希望我可以通过活跃的 wifi 连接向休眠手机发送消息。 我已经将“delay_
我不希望小型设备的边缘有任何空白。当屏幕已经很小时,使用除屏幕全宽之外的任何东西都会适得其反。 所以我通过wordpress使用了一个主题,但我想出了容器div并且能够修改它,我想让它更窄。 我还声明
有谁知道这些设备之一是否连接到网络,是否可以从 header 或其他方式读取其电话号码? 最佳答案 电话号码不会出现在 HTTP header 中。您的 IP 地址将对网络服务器可见,仅此而已。 编辑
我在使用以下步骤在 android 设备上设置设备所有者时遇到错误。这过去在其他设备上也有效: 执行恢复出厂设置 在设备上启用 Debug模式 从命令行在连接的设备上运行以下命令: adb insta
有人尝试在 Windows Phone 7.1 (RC) 上使用 Udp 单播吗?我有几个问题想问你们。 根据文件http://msdn.microsoft.com/en-us/library/sys
我正在制作一个游戏(仅使用 eclipse 和 android sdk),并且我有一个基于文本文件输入的关卡构建功能。 例如,“levelone.txt”可能包含“[2,5],[14,7],[10,9
我听说要测试 Android 应用程序,您必须在 2 部不同的手机上进行测试(取决于分辨率)推荐哪些手机? 最佳答案 我还建议在一台配备“纯”Android 的设备上进行测试,并且至少在另一台配备 H
我正在使用蓝牙设备手动连接 Android 手机,没有问题。但我的问题是当我启动 Activity 或应用程序时如何自动连接。 我正在引用示例 API 中的蓝牙聊天进行连接。 http://devel
我知道我可以使用 uri 在页面之间传递值,例如: NavigationService.Navigate( new Uri("/DestinationPage.xaml?parameter1=v1",
我是一名优秀的程序员,十分优秀!