FQL查询相当于SQL查询,利用FQL查询,我们可以得到更多关于自己或者朋友的信息
strings.xml 文件
<?xml version="1.0" encoding="utf-8"?>
<resources>
<string name="app_name">FirstFacebook</string>
<string name="hello_world">Hello world!</string>
<string name="menu_settings">Settings</string>
<string name="app_id">494262210644963</string>
<string name="send_request">Send Request</string>
<string name="query">Query</string>
<string name="multiQuery">Multi-query</string>
</resources>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
tools:context=".MainActivity" >
<com.facebook.widget.LoginButton
android:id="@+id/login_button"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal"
android:layout_marginBottom="30dp"
android:layout_marginTop="30dp" />
<Button
android:id="@+id/queryButton"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="30dp"
android:gravity="center"
android:text="@string/query"
android:textStyle="bold"
android:visibility="invisible" />
<Button
android:id="@+id/multiQueryButton"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="30dp"
android:gravity="center"
android:text="@string/multiQuery"
android:textStyle="bold"
android:visibility="invisible" />
</LinearLayout>
package com.thirdfacebook;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import android.content.pm.PackageInfo;
import android.content.pm.PackageManager;
import android.content.pm.PackageManager.NameNotFoundException;
import android.content.pm.Signature;
import android.os.Bundle;
import android.support.v4.app.FragmentActivity;
import android.util.Base64;
import android.util.Log;
import android.view.Menu;
public class MainActivity extends FragmentActivity {
private MainFragment mainFragment;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
if (savedInstanceState == null) {
// Add the fragment on initial activity setup
mainFragment = new MainFragment();
getSupportFragmentManager()
.beginTransaction()
.add(android.R.id.content, mainFragment)
.commit();
} else {
// Or set the fragment from restored state info
mainFragment = (MainFragment) getSupportFragmentManager()
.findFragmentById(android.R.id.content);
}
/**
* 打印哈希值
*/
try {
PackageInfo info = getPackageManager().getPackageInfo(
"com.firstfacebook",
PackageManager.GET_SIGNATURES);
for (Signature signature : info.signatures) {
MessageDigest md = MessageDigest.getInstance("SHA");
md.update(signature.toByteArray());
Log.i("KeyHash:", Base64.encodeToString(md.digest(), Base64.DEFAULT));
}
} catch (NameNotFoundException e) {
} catch (NoSuchAlgorithmException e) {
}
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.activity_main, menu);
return true;
}
}
package com.thirdfacebook;
import java.util.Arrays;
import org.json.JSONArray;
import org.json.JSONObject;
import android.content.Intent;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.Button;
import android.widget.Toast;
import com.facebook.FacebookException;
import com.facebook.FacebookOperationCanceledException;
import com.facebook.FacebookRequestError;
import com.facebook.HttpMethod;
import com.facebook.Request;
import com.facebook.Response;
import com.facebook.Session;
import com.facebook.SessionState;
import com.facebook.UiLifecycleHelper;
import com.facebook.model.GraphObject;
import com.facebook.model.GraphUser;
import com.facebook.widget.LoginButton;
import com.facebook.widget.WebDialog;
import com.facebook.widget.WebDialog.OnCompleteListener;
public class MainFragment extends Fragment {
private static final String TAG = "MainFragment";
private UiLifecycleHelper uiHelper;
private Button queryButton;
private Button multiQueryButton;
private Session.StatusCallback callback = new Session.StatusCallback() {
@Override
public void call(Session session, SessionState state,
Exception exception) {
onSessionStateChange(session, state, exception);
}
};
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
uiHelper = new UiLifecycleHelper(getActivity(), callback);
uiHelper.onCreate(savedInstanceState);
}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.activity_main, container, false);
LoginButton authButton = (LoginButton) view
.findViewById(R.id.login_button);
authButton.setFragment(this);
authButton.setReadPermissions(Arrays
.asList("email","user_likes", "user_status"));
queryButton = (Button) view.findViewById(R.id.queryButton);
multiQueryButton = (Button) view.findViewById(R.id.multiQueryButton);
/*
* {
data: [
{
pic_square: "https://fbcdn-profile-a.akamaihd.net/hprofile-ak-prn1/41666_1424840234_9458_q.jpg",
uid: 1424840234,
name: "Christine Abernathy"
},
{
pic_square: "https://fbcdn-profile-a.akamaihd.net/hprofile-ak-ash4/211464_100002650977863_2642718_q.jpg",
uid: 100002650977863,
name: "James Forton"
}
]
}
*/
queryButton.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
String fqlQuery = "SELECT uid, name, pic_square FROM user WHERE uid IN " +
"(SELECT uid2 FROM friend WHERE uid1 = me() LIMIT 25)";
Bundle params = new Bundle();
params.putString("q", fqlQuery);
Session session = Session.getActiveSession();
Request request = new Request(session,
"/fql",
params,
HttpMethod.GET,
new Request.Callback(){
public void onCompleted(Response response) {
try {
GraphObject graphObject = response.getGraphObject();
FacebookRequestError error = response.getError();
if (graphObject != null) {
// Check if there is extra data
if (graphObject.getProperty("data") != null) {
JSONArray dataArray = new JSONArray(graphObject.getProperty("data").toString());
for(int i=0;i<=dataArray.length();i++){
JSONObject dataObject = (JSONObject)dataArray.get(i);
String pic = dataObject.getString("pic_square");//头像
String uid = dataObject.getString("uid");//id
String name = dataObject.getString("name");//名字
Toast.makeText(MainFragment.this.getActivity(), pic+"\n"+uid+"\n"+name, Toast.LENGTH_SHORT).show();
}
}else if (error != null) {
}
}
Log.i(TAG, "Result: " + response.toString());
} catch (Exception e) {
e.printStackTrace();
}
}
});
Request.executeBatchAsync(request);
}
});
/*
* 数据模版
* {
data: [
{
fql_result_set: [
{
uid2: "1424840234"
},
{
uid2: "100002650977863"
}
],
name: "friends"
},
{
fql_result_set: [
{
pic_square: "https://fbcdn-profile-a.akamaihd.net/hprofile-ak-prn1/41666_1424840234_9458_q.jpg",
uid: 1424840234,
name: "Christine Abernathy"
},
{
pic_square: "https://fbcdn-profile-a.akamaihd.net/hprofile-ak-ash4/211464_100002650977863_2642718_q.jpg",
uid: 100002650977863,
name: "James Forton"
}
],
name: "friendinfo"
}
]
}
*/
multiQueryButton.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
/* String fqlQuery = "{" +
"'friends':'SELECT uid2 FROM friend WHERE uid1 = me() LIMIT 25'," +
"'friendinfo':'SELECT uid, name, pic_square FROM user WHERE uid IN " +
"(SELECT uid2 FROM #friends)'," +
"}";*/
String fqlQuery = "SELECT uid,name,email FROM user WHERE uid = me()";
Bundle params = new Bundle();
params.putString("q", fqlQuery);
Session session = Session.getActiveSession();
Request request = new Request(session,
"/fql",
params,
HttpMethod.GET,
new Request.Callback(){
public void onCompleted(Response response) {
Toast.makeText(MainFragment.this.getActivity(), response.toString(), Toast.LENGTH_SHORT).show();
Log.i(TAG, "Result: " + response.toString());
}
});
Request.executeBatchAsync(request);
}
});
return view;
}
private void onSessionStateChange(Session session, SessionState state,
Exception exception) {
if (state.isOpened()) {
sendRequestButton.setVisibility(View.VISIBLE);
queryButton.setVisibility(View.VISIBLE);
multiQueryButton.setVisibility(View.VISIBLE);
makeMeRequest(session);
Log.i(TAG, "Logged in...");
} else if (state.isClosed()) {
sendRequestButton.setVisibility(View.INVISIBLE);
queryButton.setVisibility(View.INVISIBLE);
multiQueryButton.setVisibility(View.INVISIBLE);
Log.i(TAG, "Logged out...");
}
}
/**
* 获取登录信息
* @param session
*/
private void makeMeRequest(final Session session) {
// Bundle params1 = new Bundle();
// params1.putString("fields","picture");
// Log.v("sss", authenticatedFacebook.request("me"));
// JSONObject jObject = new JSONObject(authenticatedFacebook.request("me"));
// String id=jObject.getString("id");
// String name=jObject.getString("name");
// String email=jObject.getString("email");
// try {
// URL img_value = new URL("http://graph.facebook.com/"+id+"/picture?type=large");
// Bitmap mIcon1 = BitmapFactory.decodeStream(img_value.openConnection().getInputStream());
// } catch (Exception e) {
// e.printStackTrace();
// }
// Make an API call to get user data and define a
// new callback to handle the response.
Request request = Request.newMeRequest(session,
new Request.GraphUserCallback() {
@Override
public void onCompleted(GraphUser user, Response response) {
// If the response is successful
if (session == Session.getActiveSession()) {
if (user != null) {
try {
Toast.makeText(MainFragment.this.getActivity(),user.getProperty("email")+"", Toast.LENGTH_LONG).show();
} catch (Exception e) {
e.printStackTrace();
}
}
}
if (response.getError() != null) {
// Handle errors, will do so later.
}
}
});
request.executeAsync();
}
@Override
public void onResume() {
super.onResume();
// For scenarios where the main activity is launched and user
// session is not null, the session state change notification
// may not be triggered. Trigger it if it's open/closed.
Session session = Session.getActiveSession();
if (session != null && (session.isOpened() || session.isClosed())) {
onSessionStateChange(session, session.getState(), null);
}
uiHelper.onResume();
}
@Override
public void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
uiHelper.onActivityResult(requestCode, resultCode, data);
}
@Override
public void onPause() {
super.onPause();
uiHelper.onPause();
}
@Override
public void onDestroy() {
super.onDestroy();
uiHelper.onDestroy();
}
@Override
public void onSaveInstanceState(Bundle outState) {
super.onSaveInstanceState(outState);
uiHelper.onSaveInstanceState(outState);
}
}
AndroidMainfest.xml
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.thirdfacebook"
android:versionCode="1"
android:versionName="1.0" >
<uses-sdk
android:minSdkVersion="8"
android:targetSdkVersion="16" />
<uses-permission android:name="android.permission.INTERNET"/>
<application
android:allowBackup="true"
android:icon="@drawable/ic_launcher"
android:label="@string/app_name"
android:theme="@style/AppTheme" >
<activity
android:name="com.thirdfacebook.MainActivity"
android:label="@string/app_name" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<activity android:name="com.facebook.LoginActivity"/>
<meta-data android:name="com.facebook.sdk.ApplicationId" android:value="@string/app_id"/>
</application>
</manifest>