- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
如果我理解正确,要从我的桌面应用程序进行 API 调用(让我们从现在开始在 OAuth2 标准中调用它)我需要获得一个 access_token,它是一个结合了应用程序 ID 和用户的,我想访问的数据,id('资源所有者')。
按照身份验证指南 ( developers.facebook.com/docs/authentication/ ) 上的客户端流程,我知道我需要将请求发送到 h**ps://www.facebook.com/dialog/oauth?client_id=YOUR_APP_ID&redirect_uri=http://example .com&response_type= token 。结果,页面将被重定向到 h**p://example.com/#access_token=XXX。如果客户端是纯桌面应用,那么redirect_uri可以是h**p://www.facebook.com/connect/login_success.html。由于客户端拥有 Web 控件,因此可以轻松地从重定向地址中提取 access_token。
客户端流程包含 3 个 OAuth 步骤:
为什么我认为最后一步是安全失败?首先,app id和redirect_uri都是公开信息,任何人都可以获得。其次,redirect_uri 可以是 h**p://www.facebook.com/connect/login_success.html。
让我们看看下面的场景。桌面应用程序 EVE 向用户显示一个 Web 控件,用户可以在其中登录 facebook 并授予 EVE 一些基本权限。资源所有者没有理由怀疑任何事情。接下来,EVE Conceal 了 Web 控件,并尝试在其上加载 h**ps://www.facebook.com/dialog/oauth?client_id=OTHER_APP_ID&redirect_uri=http://www。 facebook.com/connect/login_success.html&response_type=token。该应用程序可以尝试使用最流行的 facebook 应用程序应用程序 ID 加载此 url。如果用户之前授权了 OTHER_APP,应用程序将收到成功消息,因为登录对话框和权限对话框都不会显示。这将为 EVE 提供 access_token 以访问资源所有者授予 OTHER_APP 而不是 EVE 的资源所有者的所有资源。
那么,这是一个安全漏洞吗?我错过了以下内容吗?
(更新)
显然,对于桌面应用程序,安全问题是无关紧要的,因为应用程序已经有了用户名和 facebook session ,甚至用户名和密码,它可以对用户帐户做任何事情。
(更新)对于在网络浏览器中运行的 JavaScript 应用程序,redirect_uri 确实有效! (请参阅 hnrt 的回答和评论)。
当前问题:唯一剩下的谜团是客户端身份验证如何在 iPhone 和 Android 应用程序上工作?安全整体与使用桌面应用程序时的安全整体相似吗?越狱的 iPhone 或 root 的 Android 有什么区别吗?
干杯!
最佳答案
如果我理解正确,您的场景将要求用户已经使用 EVE 可用于与 Facebook 交谈的相同 Web 控件对其他应用程序进行身份验证。如果真是这样,那么已经存在更大的安全问题 :) EVE 可以劫持整个 session 及其所有身份验证 token 。
[更新] 关于 Javascript 应用程序,same origin policy阻止 EVE 访问 /dialog/oauth?client_id=OTHER_APP
请求的回复。访问数据的唯一方法是在 redirect_uri
处等待并解析重定向的请求。这里“站点 url”保护开始了。
我不确定在 iPhone 和 Android 应用程序中是如何工作的,但如果他们的 Web 控件允许访问其他应用程序的身份验证数据 (=cookies),我会感到非常惊讶。
关于security - Facebook 使用 redirect_uri 的客户端身份验证流程是否已损坏?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4868425/
我为我们的业务创建了一个 Facebook 页面,我创建了一个 Facebook 应用程序来获取 AppID,以便在 Facebook 插件中使用它。 我注意到 Facebook 应用程序的页面看起来
是否有可能知道哪个 Facebook 用户点击了我的应用用户在 Facebook 上分享的链接? 为了清楚起见,让我改写一下:我想知道我的应用用户的哪些 friend 点击了他的共享链接。 感谢任何提
我正在浏览 facebook pixel,对 facebook pixel 如何知道哪个转化来自哪个 facebook 广告感到很困惑? 假设我有这个 url http://example.com安装
我正在开发 sucsongmoi.net(越南语),当浏览者从他们的墙上分享网站链接时,一些链接 facebook 获得描述和图像,一些链接 facebook 无法获得描述和图像。 例如:分享 suc
一位同事错误地设置了个人 Facebook 页面;它应该是一个企业 Facebook 页面。 个人页面上有几个 friend 需要重定向到正确的 Facebook 业务页面。 我可以将用户从错误的个人
在 Facebook 上,当您转到“编辑我的个人资料”>“艺术和娱乐”时,会有一个“电影”自动完成小部件,它会在您输入电影时推荐电影。 因此,如果您输入“Jones”,它将开始建议: 印第安纳琼斯 布
我在我的网页上使用 Facebook 登录。首次登录时,Facebook 登录应用程序会请求获取用户数据的权限。 有什么方法可以改善这个问题,以请求喜欢我的 Facebook 页面的许可?用户点击后,
我需要知道是否可以将现有的 Facebook 页面(类别:应用程序页面)链接到 Facebook 应用程序?当我进入 Facebook 应用程序设置时,他们建议创建一个新页面。但我需要的只是链接到现有
我的网站应用程序具有通过 Facebook 登录进行登录的功能。为此,我的应用程序出现在 Facebook 上。使用 Facebook 登录工作正常。 但应用程序具有将 Facebook 帐户链接和取
我正在制作一个应用程序,让人们可以在 Facebook 上与特定的 friend 分享内容。示例:Alice 使用我的应用程序,她与 Bob 分享了一篇文章,Bob 是她的 Facebook 好友。现
我正在按照列出的说明进行操作 http://docs.appcelerator.com/platform/latest/#!/api/Modules.Facebook 并查看 Arrow 示例目录中的
假设我有一个餐厅的商业网站,一位顾客为一大群人预订了一张 table 。有没有一种方法可以让客户有机会在餐厅网站上创建 Facebook 事件,作为预订流程的一部分。我知道客户必须以某种方式从餐厅网站
我想让我的用户将他们的用户帐户与 Facebook 或 Twitter 相关联,并允许他们使用他们的 Facebook/Twitter 帐户登录我的服务器,而不是使用传统的用户名/密码。与StackO
我们有一个面子书页面。我们添加了一个自定义 FBML 选项卡。现在我们要添加评论面子书插件。我尝试添加一个脚本,我从 Face book Social Plug in .代码是 之后我将此脚本放入自
大家好 请帮我找到关于以下的官方信息: 1) 什么是“FaceBook 登录” 2) 什么是“FaceBook Connect” 谢谢 最佳答案 你可以在那里找到你需要的一切: http://deve
这是最奇怪的事情。我有非常简单的 CF 代码,查看 cgi.HTTP_REFERER。简单地说,它查看推荐人。如果链接是从我们的主要网站域之外单击的,它会显示一些内容。否则,什么也不会发生。所以,如果
我还是 Facebook Graph API 的新手,正在尝试开始使用 Facebook 地点搜索。 (按位置搜索地点) https://graph.facebook.com/search?type=
我不想开设 Facebook 帐户,但我被要求为需要使用 Facebook API 的应用程序开发功能。有没有一种方法可以开发这些功能并使用 Facebook API,而无需开设个人 Facebook
我已经按照指示实现了 DotNetOpenAuth 提供的示例应用程序 here . 正如您在下面看到的,这要求用户安装此 facebook 应用程序。 我只是想让用户使用他们的 Facebook 登
我的主页上有标准的 Facebook 登录按钮,我不希望人们仅在用户单击登录按钮时使用他们的 Facebook 帐户自动登录我的网站。 如果用户未登录 Facebook,将出现一个弹出窗口询问他的凭据
我是一名优秀的程序员,十分优秀!