- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试使用 Facebook Graph API 将 Facebook 帖子发布到用户自己的墙上,但遇到多个问题。
我有一个 Wordpress 网站,并且正在使用 OneAll.com 服务来维护和管理用户的社交登录。在将帐户链接到 Facebook 帐户后,我已将用户发帖所需的权限添加到我的 Facebook 应用程序。问题在于,OneAll 似乎不会更新存储在该社交身份中的访问 token ,直至其过期。但由于新添加的应用权限,访问 token 似乎提前过期,因此我需要在 OneAll 上手动重新同步用户的社交身份。
他们确实有一个函数可以调用以通过 API ( Here ) 同步身份,但我似乎无法成功向其发送请求。
我尝试按照 Java servlet 中的指定设置 HTTP PUT
请求,但每次调用时都会失败,并返回 错误 411
。我已经完成了研究,似乎需要在请求中指定内容长度,但即使我尝试添加它,它似乎也不起作用。
因此,我尝试在应用程序的 Parse.com 云代码中设置一个云函数来激活此重新同步,但这个函数每次也失败,并出现一个我似乎无法弄清楚的错误代码:
Input: {"oaIDToken":"924e6f**********"}
Result: Uncaught Error: Can't form encode an Object
知道这个错误意味着什么以及如何修复它吗?我不知道我做错了什么。这是我的云功能:
Parse.Cloud.define("forceOAIDUpdate", function(request, response) {
var IDToken = request.params.oaIDToken;
var IDURL = "https://w*******d.api.oneall.com/identities/" + IDToken + "/synchronize.json";
Parse.Cloud.httpRequest({
method: 'PUT',
url: IDURL,
body: {
request: {
synchronize: {
update_user_data: true,
force_token_update: true
}
}
},
success: function(httpResponse) {
console.log("OA ID token successfully refreshed.");
console.log(httpResponse.text);
response.success("OA ID token refreshed");
},
error: function(httpResponse) {
console.error('Requested OA ID refresh failed with response code ' +
httpResponse.status);
response.error("Failed to refresh OA ID. Error: " +
httpResponse.data + httpResponse.text + httpResponse.error);
}
});
});
我知道函数接收到的 OneAll 身份 token 是有效/正确的,因为它适用于为用户执行其他操作的其他函数。另外,当我尝试在 Java servlet 中执行此操作时,我将基本身份验证登录附加到请求中,但它似乎没有什么区别。不管怎样,缺少身份验证是否可能是导致此错误的原因?如果是这样,我如何在 Parse 云 HTTP 请求中插入该身份验证 header ?我检查过,但找不到任何在线资源可以清楚地描述它。
还有一件非常奇怪的事情我无法弄清楚。我尝试使用 REST 控制台/客户端手动调用 OneAll 的 REST API,但无论其 REST API 的任何端口的 URL 是什么,连接总是失败 - 控制台立即返回没有响应。无论是否在请求中附加基本身份验证 header ,情况都是如此。到底是怎么回事??
可以这么说,我已经遇到了“作家的障碍”,并且已经没有办法调试这个问题了。我将非常感谢任何帮助。这个问题已经困扰我好几个小时了。
最佳答案
我终于明白了!!!
Parse 中的 Can't form encode an Object
错误仅意味着我的正文参数需要编码为 JSON 字符串。
通过在 HTTP 请求
header 中包含基本授权解决了身份验证问题。但它必须以 Base64 进行编码,并且由于 Parse 的 Cloud 代码似乎不支持 btoa() 函数(正如我尝试过的那样),我必须手动包含/创建一个 Base64
编码器。
所以我将Parse Cloud函数更改为以下内容,终于成功了:
Parse.Cloud.define("forceOAIDUpdate", function(request, response) {
var Base64 = {
// private property
_keyStr : "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",
// public method for encoding
encode : function (input) {
var output = "";
var chr1, chr2, chr3, enc1, enc2, enc3, enc4;
var i = 0;
input = Base64._utf8_encode(input);
while (i < input.length) {
chr1 = input.charCodeAt(i++);
chr2 = input.charCodeAt(i++);
chr3 = input.charCodeAt(i++);
enc1 = chr1 >> 2;
enc2 = ((chr1 & 3) << 4) | (chr2 >> 4);
enc3 = ((chr2 & 15) << 2) | (chr3 >> 6);
enc4 = chr3 & 63;
if (isNaN(chr2)) {
enc3 = enc4 = 64;
} else if (isNaN(chr3)) {
enc4 = 64;
}
output = output +
Base64._keyStr.charAt(enc1) + Base64._keyStr.charAt(enc2) +
Base64._keyStr.charAt(enc3) + Base64._keyStr.charAt(enc4);
}
return output;
},
// public method for decoding
decode : function (input) {
var output = "";
var chr1, chr2, chr3;
var enc1, enc2, enc3, enc4;
var i = 0;
input = input.replace(/[^A-Za-z0-9\+\/\=]/g, "");
while (i < input.length) {
enc1 = Base64._keyStr.indexOf(input.charAt(i++));
enc2 = Base64._keyStr.indexOf(input.charAt(i++));
enc3 = Base64._keyStr.indexOf(input.charAt(i++));
enc4 = Base64._keyStr.indexOf(input.charAt(i++));
chr1 = (enc1 << 2) | (enc2 >> 4);
chr2 = ((enc2 & 15) << 4) | (enc3 >> 2);
chr3 = ((enc3 & 3) << 6) | enc4;
output = output + String.fromCharCode(chr1);
if (enc3 != 64) {
output = output + String.fromCharCode(chr2);
}
if (enc4 != 64) {
output = output + String.fromCharCode(chr3);
}
}
output = Base64._utf8_decode(output);
return output;
},
// private method for UTF-8 encoding
_utf8_encode : function (string) {
string = string.replace(/\r\n/g,"\n");
var utftext = "";
for (var n = 0; n < string.length; n++) {
var c = string.charCodeAt(n);
if (c < 128) {
utftext += String.fromCharCode(c);
}
else if((c > 127) && (c < 2048)) {
utftext += String.fromCharCode((c >> 6) | 192);
utftext += String.fromCharCode((c & 63) | 128);
}
else {
utftext += String.fromCharCode((c >> 12) | 224);
utftext += String.fromCharCode(((c >> 6) & 63) | 128);
utftext += String.fromCharCode((c & 63) | 128);
}
}
return utftext;
},
// private method for UTF-8 decoding
_utf8_decode : function (utftext) {
var string = "";
var i = 0;
var c = c1 = c2 = 0;
while ( i < utftext.length ) {
c = utftext.charCodeAt(i);
if (c < 128) {
string += String.fromCharCode(c);
i++;
}
else if((c > 191) && (c < 224)) {
c2 = utftext.charCodeAt(i+1);
string += String.fromCharCode(((c & 31) << 6) | (c2 & 63));
i += 2;
}
else {
c2 = utftext.charCodeAt(i+1);
c3 = utftext.charCodeAt(i+2);
string += String.fromCharCode(((c & 15) << 12) | ((c2 & 63) << 6) | (c3 & 63));
i += 3;
}
}
return string;
}
}
var IDToken = request.params.oaIDToken;
var key = "f1a914*******************************";
var secret = "e804************************************";
var basicAuthOA = key + ":" + secret;
var basicAuthOAEncoded = Base64.encode(basicAuthOA);
var IDURL = "https://whentosend.api.oneall.com/identities/" + IDToken + "/synchronize.json";
var headerAuth = {
'Authorization': "Basic " + basicAuthOAEncoded
}
var params = {
request: {
synchronize: {
update_user_data: true,
force_token_update: true
}
}
}
Parse.Cloud.httpRequest({
method: 'PUT',
url: IDURL,
headers: headerAuth,
body: JSON.stringify(params),
success: function(httpResponse) {
console.log("OA ID token successfully refreshed.");
console.log(httpResponse.text);
response.success("OA ID token refreshed");
},
error: function(httpResponse) {
console.error('Requested OA ID refresh failed with response code ' +
httpResponse.status);
response.error("Failed to refresh OA ID. Error: " +
httpResponse.data + httpResponse.text + httpResponse.error);
}
});
});
我希望这可以帮助其他人节省大量的调试时间。令人沮丧的是,我花了几天时间才弄清楚这一点,我不希望任何程序员遇到这种情况。
关于java - REST API 无响应,Parse.com 云错误 : Can't Form Encode an Object,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31555774/
我是 CAN 协议(protocol)的新手,正在阅读 Robert Bosch 的 CAN 规范 ver2.0 B 部分。我无法理解第 63 页上的以下几行 ”注意:启动/唤醒:如果在启动期间只有一
我用 C 写了一些代码来读取 CAN 总线数据。当我读取 11 位 CAN ID 时一切正常。一旦我尝试读取 29 位 ID,它就会错误地显示 ID。 示例: 接收29位ID的消息: 0x01F0A0
如果这看起来与另一个问题相似或者看起来已经得到回答,我提前道歉。我觉得它非常详细,足以证明自己的问题。 我正在尝试寻找一个虚拟的 CAN 总线模拟器(或一些可以轻松制作模拟器的方法),它只会生成 CA
我的问题涉及 GNU 的品牌。 如果您有一系列命令可用作多个目标的配方,则 canned recipe派上用场了。我可能看起来像这样: define run-foo # Here comes a #
您好,我是一名学习canopen的学生。Canopen中的COB-ID和CAN标识符有什么关系?我在CIA主页上看到COB-ID不是CAN ID,但我不明白。 例如,如果 PDO 通过 CAN 总线传
我知道一个显性确认位是由另一个节点传输的消息的接收器发送的。 我无法理解的是,接收方是在接收到整个消息后发送单个显性位,还是接收者发送相同的消息,其中 ACK 位字段为显性? 或者是接收器在发送器传输
我是 CAN 协议(protocol)的新手,我正在尝试通过 Linux 的 SocketCAN 使用它。然而,我对可用的 2 种不同的 CAN 套接字(RAW 和广播管理器 (BCM))感到困惑。
就目前情况而言,这个问题不太适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、民意调查或扩展讨论。如果您觉得这个问题可以改进并可能重新开放,visit
我正在尝试制作一个在 Windows 下运行并与 ELM327 设备通信的软件。我创建了第一个版本,然后我进入了我的 SMART ForTwo (SMART 451) 车辆,我设法连接了仪表盘(发送
我知道在 CAN Controller 中,如果错误计数达到某个阈值(比如 255),就会发生总线关闭,这意味着特定的 CAN 节点将从 CAN 网络中关闭。所以根本不会有任何交流。但是,如果上述情况
我正在使用 ELM327,我希望能够设置要发送的 CAN 消息的 header 和数据部分。我看到有一个代码用于设置消息的标题 SH xxyyzz 但是我很难找出如何设置数据部分并控制何时发送消息。
我想做的是: 将数据插入具有两列的表中,并在同一 PHP 页面中显示更新的值。我能够获取数据并显示它,但无法插入任何数据。请指导我。 文件名为 mypage.php 到目前为止我的代码:
(这个问题是关于 Android 11 的) 我想将崩溃日志打印到其他应用程序可以读取的文件中(具体来说,我希望能够导航到该文件并使用"file"应用程序查看数据)。 我看过很多关于这个问题的答案,但
这会产生“ fatal error :无法解开Optional.None”,我似乎不明白为什么 var motionManager = CMMotionManager() motionManager.
在 Java 中,我经常遇到带有后缀 -able 的接口(interface),例如可序列化、可迭代等。这表明实现这些接口(interface)的对象具有可以对其执行某些操作的特性,例如该对象可以被序
我正在阅读 CanJS API 文档并遇到 can.Construct.extend http://canjs.com/docs/can.Construct.extend.html .我知道 can.
我正在使用 C 语言在 STM32F1xx 上进行开发,直到现在我都在尝试使用“CANopenNode-master”实现 CANopen 堆栈,并且我正在使用 2 个中断。 第一个是用于处理 SYN
我一直在使用 SocketCAN,尤其是 Virtual CAN vcan。但是,到目前为止,我从未使用过 CAN FD(灵活数据速率)。 好吧,我今天早上用 can-utils 试了一下: cans
我正在运行一个带有两个 CAN channel 的程序(使用 TowerTech CAN Cape TT3201)。 两个 channel 是 can0 (500k) 和 can1 (125k)。 c
存储由序列字符组成的字符串的 %s 格式说明符可以存储整数序列吗?如果是的话..你能解释一下吗? 最佳答案 无论如何,数字都是用字符表示的,所以是的,您可以使用 "%s" 说明符读取数字并将其存储在
我是一名优秀的程序员,十分优秀!