C# 在ASP.NET Facebook应用程序中将照片上载到Facebook
我一直在为此绞尽脑汁,阅读所有我能找到的可用文档,但仍然找不到解决方案,所以我在这里发布 首先,我从这里开始,这是Facebook关于通过Graph API发布照片的官方指南 因为它是用PHP编写的,所以我用ASP.NET C#重写了它。代码的工作原理是照片上传成功,我得到了带有照片ID的JSON响应 我需要一种方法读回这个ID,所以我想我必须从服务器端上传。然而,这意味着用户需要先上传到我的服务器,然后我的代码会将其发送到Facebook的API 我的问题是:有没有一种方法可以在不先将文件保存到服务器磁盘的情况下执行此操作?因为此时我上传了文件的数据缓冲区,我能把它发送到Graph API吗?我发现先保存文件,然后再上传是多余的 我曾想过使用Javascript/AJAX实现这一点,但似乎也没有办法。Facebook的Javascript API没有提供这方面的功能 我还试图查看各种库,但文档相当缺乏。我也查看了,但它假设我已经有一个文件要上传 这里的专家可以发布一些这样做的示例代码(如果可能的话),或者为我指出我需要的正确方向。在我们讨论这个问题时,有没有办法触发Facebook的照片上传对话框,或者我必须从头开始建立自己的照片上传对话框C# 在ASP.NET Facebook应用程序中将照片上载到Facebook,c#,asp.net,facebook,facebook-apps,photo-upload,C#,Asp.net,Facebook,Facebook Apps,Photo Upload,我一直在为此绞尽脑汁,阅读所有我能找到的可用文档,但仍然找不到解决方案,所以我在这里发布 首先,我从这里开始,这是Facebook关于通过Graph API发布照片的官方指南 因为它是用PHP编写的,所以我用ASP.NET C#重写了它。代码的工作原理是照片上传成功,我得到了带有照片ID的JSON响应 我需要一种方法读回这个ID,所以我想我必须从服务器端上传。然而,这意味着用户需要先上传到我的服务器,然后我的代码会将其发送到Facebook的API 我的问题是:有没有一种方法可以在不先将文件保
事先非常感谢。好的,经过一些修补,我想我找到了解决办法 在aspx中
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="upload.aspx.cs" Inherits="photocontest_upload" %>
<!DOCTYPE HTML>
<html lang="en">
<head runat="server">
<title></title>
</head>
<body>
<form id="form1" runat="server">
<div>
File: <asp:FileUpload ID="fileUpload" runat="server" /><br />
Caption: <asp:TextBox ID="caption" runat="server"></asp:TextBox><br />
<asp:Button id="btnSubmit" runat="server" onclick="btnSubmit_Click" text="Upload" />
</div>
</form>
<asp:Literal ID="msg" runat="server"></asp:Literal>
</body>
</html>
文件:“+
“”;
}
}
}
这似乎可行,但我仍然没有关于FacebookMediaObject和facebookClient()参数应该是什么的详细信息。有人知道我在哪里可以获得Facebook C#SDK的完整文档吗?谢谢
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.IO;
using Facebook;
public partial class photocontest_upload : System.Web.UI.Page
{
protected string access_token = "";
protected string form_url = "";
protected void Page_Load(object sender, EventArgs e)
{
string app_id = "your_app_id";
string app_secret = "your_app_secret";
string post_login_url = "your_post_login_url";
string code = Request["code"] ?? "";
if (code == "")
{
string dialog_url = "http://www.facebook.com/dialog/oauth?" + "client_id=" + app_id + "&redirect_uri=" + Server.UrlEncode(post_login_url) + "&scope=publish_stream";
Response.Redirect(dialog_url);
}
else
{
string token_url = "https://graph.facebook.com/oauth/access_token?client_id=" + app_id + "&redirect_uri=" + Server.UrlEncode(post_login_url) + "&client_secret=" + app_secret + "&code=" + code;
string response = InstaSharp.HttpClient.GET(token_url);
access_token = HttpUtility.ParseQueryString(response).Get("access_token");
form_url = "https://graph.facebook.com/me/photos?access_token=" + access_token;
}
}
protected void btnSubmit_Click(object sender, EventArgs e)
{
if (fileUpload.HasFile)
{
FacebookClient facebookClient = new FacebookClient(access_token);
FacebookMediaObject mediaObject = new FacebookMediaObject
{
FileName = "file.jpg",
ContentType = "image/jpeg"
};
mediaObject.SetValue(fileUpload.FileBytes);
IDictionary<string, object> upload = new Dictionary<string, object>();
upload.Add("name", caption.Text);
upload.Add("@file.jpg", mediaObject);
dynamic res = facebookClient.Post("/me/photos", upload) as JsonObject;
form1.Visible = false;
msg.Text = "<p>Photo uploaded successfully. " +
"<a href=\"https://www.facebook.com/photo.php?fbid=" + res.id + "\">View on facebook</a><p>" +
"<p><a href=\"upload.aspx\">Back</a>";
}
}
}