- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的 android 应用程序有问题。如果我使用我的“应用程序帐户”访问就可以了。
否则,如果我使用我的 Facebook 帐户凭证访问,我的上下文为空。
如何解决?
下面是我的代码。提前谢谢你。
public class Login extends AppCompatActivity {
Context ctx;
private LoginButton loginButtonFb;
private TextView info;
private CallbackManager callbackManager;
EditText ET_NAME, ET_PASS;
String login_name, login_pass;
static final String USERNAME = "USER_NAME";
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
FacebookSdk.sdkInitialize(getApplicationContext());
setContentView(R.layout.activity_login);
callbackManager = CallbackManager.Factory.create();
loginButtonFb = (LoginButton)findViewById(R.id.login_button_fb);
loginButtonFb.setReadPermissions("user_friends");
ET_NAME = (EditText) findViewById(R.id.user_name);
ET_PASS = (EditText) findViewById(R.id.user_pass);
info = (TextView)findViewById(R.id.info);
loginButtonFb.registerCallback(callbackManager, new FacebookCallback<LoginResult>() {
@Override
public void onSuccess(LoginResult loginResult) {
new GraphRequest(
AccessToken.getCurrentAccessToken(),
loginResult.getAccessToken().getUserId(),
null,
HttpMethod.GET,
new GraphRequest.Callback() {
public void onCompleted(GraphResponse response) {
try {
JSONObject data = response.getJSONObject();
String idFb = data.getString("id");
String nameFb = data.getString("name");
String method = "loginFb";
BackgroundTask backgroundTask = new BackgroundTask(ctx);
backgroundTask.execute(method, nameFb, idFb);
} catch (JSONException e) {
e.printStackTrace();
}
}
}
).executeAsync();
}
@Override
public void onCancel() {
info.setText("Login attempt canceled.");
}
@Override
public void onError(FacebookException e) {
info.setText("Login attempt failed.");
}
});
}
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
callbackManager.onActivityResult(requestCode, resultCode, data);
}
public void userReg(View view){
Intent intent = new Intent(this, Registration.class);
startActivity(intent);
}
private class BackgroundTask extends AsyncTask<String, Void, String> {
Context ctx;
BackgroundTask(Context ctx){
this.ctx = ctx;
}
@Override
protected String doInBackground(String... params) {
String method = params[0];
if (method.equals("login")){
String login_url = "http://192.168.1.118:80/webappdb/login.php";
String login_name = params[1];
String login_pass = params[2];
try {
URL url = new URL(login_url);
HttpURLConnection httpURLConnection = (HttpURLConnection) url.openConnection();
httpURLConnection.setRequestMethod("POST");
httpURLConnection.setDoOutput(true);
httpURLConnection.setDoInput(true);
OutputStream outputStream = httpURLConnection.getOutputStream();
BufferedWriter bufferedWriter = new BufferedWriter(new OutputStreamWriter(outputStream, "UTF-8"));
String data = URLEncoder.encode("login_name", "UTF-8") + "=" + URLEncoder.encode(login_name, "UTF-8") + "&" +
URLEncoder.encode("login_pass", "UTF-8") + "=" + URLEncoder.encode(login_pass, "UTF-8");
bufferedWriter.write(data);
bufferedWriter.flush();
bufferedWriter.close();
outputStream.close();
InputStream inputStream = httpURLConnection.getInputStream();
BufferedReader bufferedReader = new BufferedReader((new InputStreamReader(inputStream, "iso-8859-1")));
String response = "";
String line = "";
while((line = bufferedReader.readLine()) != null){
response += line;
}
bufferedReader.close();
inputStream.close();
httpURLConnection.disconnect();
return response;
} catch (MalformedURLException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
else if(method.equals("loginFb")){
String login_name = params[1];
String id = params[2];
String loginFb_url = "http://192.168.1.118:80/webappdb/loginFb.php";
try {
URL url = new URL(loginFb_url);
HttpURLConnection httpURLConnection = (HttpURLConnection) url.openConnection();
httpURLConnection.setRequestMethod("POST");
httpURLConnection.setDoOutput(true);
httpURLConnection.setDoInput(true);
OutputStream outputStream = httpURLConnection.getOutputStream();
BufferedWriter bufferedWriter = new BufferedWriter(new OutputStreamWriter(outputStream, "UTF-8"));
String data = URLEncoder.encode("login_nameFb", "UTF-8") + "=" + URLEncoder.encode(login_name, "UTF-8") + "&" +
URLEncoder.encode("id", "UTF-8") + "=" + URLEncoder.encode(id, "UTF-8");
bufferedWriter.write(data);
bufferedWriter.flush();
bufferedWriter.close();
outputStream.close();
InputStream inputStream = httpURLConnection.getInputStream();
BufferedReader bufferedReader = new BufferedReader((new InputStreamReader(inputStream, "iso-8859-1")));
String response = "";
String line = "";
while((line = bufferedReader.readLine()) != null){
response += line;
}
bufferedReader.close();
inputStream.close();
httpURLConnection.disconnect();
return response;
} catch (MalformedURLException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
return null;
}
@Override
protected void onPostExecute(String result) {
if(result.equals("Login failed, try again.")){
Toast.makeText(ctx, result, Toast.LENGTH_LONG).show();
}
if (result.equals("Login success!")){
Intent intent = new Intent(ctx,UserProfile.class);
intent.putExtra(USERNAME, login_name);
startActivity(intent);
Toast.makeText(ctx, result, Toast.LENGTH_LONG).show();
}
}
}
public void userLogin(View view){
login_name = ET_NAME.getText().toString();
login_pass = ET_PASS.getText().toString();
String method = "login";
BackgroundTask backgroundTask = new BackgroundTask(this);
backgroundTask.execute(method, login_name, login_pass);
}
}
gamingproject.sellmybooks E/AndroidRuntime: FATAL EXCEPTION: main
Process: gamingproject.sellmybooks, PID: 30637
java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.String android.content.Context.getPackageName()' on a null object reference
at android.content.ComponentName.<init>(ComponentName.java:77)
at android.content.Intent.<init>(Intent.java:4144)
at gamingproject.sellmybooks.Login$BackgroundTask.onPostExecute(Login.java:228)
at gamingproject.sellmybooks.Login$BackgroundTask.onPostExecute(Login.java:123)
at android.os.AsyncTask.finish(AsyncTask.java:632)
at android.os.AsyncTask.access$600(AsyncTask.java:177)
at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:645)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:135)
at android.app.ActivityThread.main(ActivityThread.java:5536)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1397)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1192)
最佳答案
在您的登录 Activity 中,更改'上下文 ctx' 到 '上下文 mContext'当 onCreate() 开始时,做
mContext = this;
像那样:
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
mContext = this;
...
}
在您的方法 userLogin 上,发送“mContext”
public void userLogin(View view){
login_name = ET_NAME.getText().toString();
login_pass = ET_PASS.getText().toString();
String method = "login";
BackgroundTask backgroundTask = new BackgroundTask(mContext);
backgroundTask.execute(method, login_name, login_pass);
}
关于java - 使用 BackgroundTask 和 Facebook 的上下文,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36056736/
这个问题在这里已经有了答案: Can't endBackgroundTask: no background task exists with identifier, or it may have al
我的问题是,deferral.complete() 方法到底是做什么的,这个方法调用事件 task.Compledet,还是有办法调用一个我的类 BackgroundSyncer 中 Backgrou
我有一个简短的问题,如果我更新包含 BackgroundTask 的应用程序,我是否需要在更新后注销并重新注册该任务?我遇到过在某些用户设备上更新后 BackgroundTask 不再工作,用户必须禁
这个话题让我很头疼。我正在开发一个需要定期轮询网络服务器以检查新数据的应用程序。根据返回的信息,我希望向用户推送一个本地通知。 我知道这种方法与 Apple 描述的方法略有不同,在 Apple 中,远
我正在构建一个 Web 服务,用于使用 CherryPy 对数据进行迭代批处理。理想的工作流程如下: 用户将数据发布到服务进行处理 当处理作业空闲时,它收集排队的数据并开始另一个迭代 在处理作业时,用
我正在使用 Windows Phone 8.1 和 C#。 按照 Microsoft 的 MSDN 示例(位于:http://code.msdn.microsoft.com/windowsapps/B
当应用程序暂时进入后台时,我试图维护一个 MultipeerConnectivity“ session ”,所以我考虑过使用后台任务,因为我在这里见过几次......问题是我不知道如何“维护”与 UI
嘿,我是通用 Windows 平台和相关 API 的新手。我正在尝试使用 JS 构建 UWP 应用程序。 问题 1:我将如何初始化和监听后台任务(在 js 中)? 问题 2:如果可能的话,后台任务如何
我正在尝试使用使用场景(也是新的)的新应用程序来实现新的 iOS 13 后台任务功能。没有很多例子,但我发现的那些没有使用 SceneDelegate,而是所有的逻辑都包含在 AppDelegate
我想在后台任务的线程中做一些事情,所以我尝试使用 Task.Run() 但它不起作用。 任何人都可以告诉我另一种在后台任务中创建线程的方法。 这是我的代码: public sealed clas
我的 android 应用程序有问题。如果我使用我的“应用程序帐户”访问就可以了。 否则,如果我使用我的 Facebook 帐户凭证访问,我的上下文为空。 如何解决? 下面是我的代码。提前谢谢你。 登
如果我只能将一个触发器(使用 SetTrigger() 方法)设置为后台任务或多个,我无法在 MSDN 文档中找到。如果我想在计时器上触发任务并以编程方式触发任务,因此我需要 TimerTrigger
我正在 Windows 运行时组件中实现 IBackgroundTask,我想向其中注入(inject)记录器依赖项,但应用程序在调用后台任务时退出。它甚至不会进入构造函数。我将 Ninject 用作
我有一个使用类似于此示例代码的计时器的应用程序: Sample Code for BackgroundTasks 特别是带有计时器的部分。因此,当我在调试器中启动应用程序时,我的代码按预期运行。事件每
我有一个现在似乎无法构建的 UWP 应用。奇怪的是我有另一个与它非常相似的项目,但它构建得很好。后台任务不是音频背景任务。是什么突然导致了这种情况? Validation error. error 8
我正在使用 Scenario4 测试背景示例,它从不调用运行,我正在按照这些步骤操作,这就是我所看到的: 1.- 调用之后 BackgroundTaskRegistration task = buil
我有一个要移植到 8.1 的 Windows Phone 8.0 应用程序。在 8.0 中,我非常依赖 BackgroundWorker 来执行我不想消耗 UI 线程的任务。 我会创建 Backgro
我发现这个方法在模拟器上被调用,但在真正的 watch 设备上,它从来没有被调用过。苹果的简单代码和我的测试。 我想知道是我的错误还是苹果的。 我的代码 - class InterfaceContro
我只有一个带有 1 个按钮的应用程序,并且附加了 ViewController : import UIKit class ViewController: UIViewController {
我有以下代码可以从我的通用应用程序调用,它运行良好 // create our request with our data var data = new JsonObject(); data.Add(
我是一名优秀的程序员,十分优秀!