- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我有一个 Android 应用程序可以从远程服务器检索数据,包括身份验证。远程服务器正在使用 Yii。我们的 iPhone 版本使用的是远程网络服务,完全没有问题。但是对于我们的Android:1)我们可以登录,服务器返回200; 2) 但是下一页当我们尝试调用另一个 api 来查询数据库时,它一直返回用户未登录的错误。
我做了什么:1.查看后台的用户session。是的,从 android 登录后,用户 session 显示为 Activity 状态。2. 使用与 Firefox 的 POSTER 相同的 API 调用。是的,它可以检索数据。
可能出了什么问题?有人可以帮忙吗?非常感谢!
这是我的登录密码:
package ...
import ...
public class Login extends Activity implements OnClickListener {
EditText etUser, etPass;
Button bLogin, btnCancel;
//Create string variables that will have the input assigned to them
String username, password;
//Create a HTTPClient as the form container
HttpClient httpclient;
//Use HTTP POST method
HttpPost httppost;
//Create an array list for the input data to be sent
ArrayList<NameValuePair> nameValuePairs;
//Create a HTTP Response and HTTP Entity
HttpResponse response;
org.apache.http.HttpEntity entity;
// protected static final String TAG = MainActivity.class.getSimpleName();
final String url = "..remote api...";
// JSON Node names
private static final String TAG_CONTACTS = "users";
// contacts JSONArray
JSONArray contacts = null;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.login);
initialise();
}
private void initialise() {
etUser = (EditText) findViewById(R.id.txtUname);
etPass = (EditText) findViewById(R.id.txtPwd);
bLogin = (Button) findViewById(R.id.sumit_login);
btnCancel = (Button) findViewById(R.id.btn_Cancel);
//Now to set an onClickListener
bLogin.setOnClickListener(this);
btnCancel.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View arg0) {
Intent intent = new Intent(getApplicationContext(), MainActivity.class);
startActivity(intent);
}
});
}
public void onClick(View v) {
// This is where we will be working now
if (etUser.getText().toString().length() == 0
|| etPass.getText().toString().length() == 0) {
Toast.makeText(getApplicationContext(),
"Please enter username and password",
Toast.LENGTH_SHORT).show();
} else {
new MyAsyncTask().execute();
}
}//END onClick()
private static String convertStreamToString(InputStream is) {
BufferedReader reader = new BufferedReader(new InputStreamReader(is));
StringBuilder sb = new StringBuilder();
String line = null;
try {
while ((line = reader.readLine()) != null) {
sb.append(line + "\n");
}
} catch (IOException e) {
e.printStackTrace();
} finally {
try {
is.close();
} catch (IOException e) {
e.printStackTrace();
}
}
return sb.toString();
}//END convertStreamToString()
private class MyAsyncTask extends AsyncTask<Void, Void, Integer>
{
ProgressDialog mProgressDialog;
@Override
protected void onPreExecute() {
super.onPreExecute();
mProgressDialog = new ProgressDialog(Login.this);
mProgressDialog.setMessage("Authenticating...");
mProgressDialog.setIndeterminate(false);
mProgressDialog.setCancelable(false);
mProgressDialog.show();
}
@Override
protected Integer doInBackground(Void... params) {
int repsonStatus = 0;
//Create new default HTTPClient
httpclient = new DefaultHttpClient();
//Create new HTTP POST with URL to php file as parameter
httppost = new HttpPost("... login api ...");
//Assign input text to strings
username = etUser.getText().toString();
password = etPass.getText().toString();
JSONParser jParser = new JSONParser();
//Next block of code needs to be surrounded by try/catch block for it to work
try {
//Create new Array List
// nameValuePairs = new ArrayList<NameValuePair>(2);
List<NameValuePair> nameValuePairs = new ArrayList<NameValuePair>();
//place them in an array list
nameValuePairs.add(new BasicNameValuePair("login", "login"));
nameValuePairs.add(new BasicNameValuePair("username", username));
nameValuePairs.add(new BasicNameValuePair("password", password));
nameValuePairs.add(new BasicNameValuePair("api_key", "service_api"));
//Add array list to http post
httppost.setEntity(new UrlEncodedFormEntity(nameValuePairs));
//assign executed form container to response
response = httpclient.execute(httppost); //response from the PHP file
Log.i("AirconServer -- header login", response.getAllHeaders().toString());
Log.i("postData", response.getStatusLine().toString());
HttpEntity entity_ = response.getEntity();
repsonStatus = response.getStatusLine().getStatusCode();
if(response.getStatusLine().getStatusCode() == 200){
Log.i("AirconService - ", "LOGIN SUCCESSFUL!");
}
} else {
Toast.makeText(getApplicationContext(),
"Invalid Username or password.",
Toast.LENGTH_SHORT).show();
}
} catch(Exception e){
e.printStackTrace();
}
return repsonStatus;
}
@Override
protected void onPostExecute(Integer result) {
mProgressDialog.dismiss();
if(result == 200) {
Intent intent = new Intent(getApplicationContext(), MainMenuActivity.class);
startActivity(intent);
} else {
Toast.makeText(getApplicationContext(),
"Invalid Username or password.",
Toast.LENGTH_SHORT).show();
}
}
}
}
这是另一个调用的代码,它在用户已经登录的情况下仍然要求登录。
public class GetMybookings extends ListActivity {
int TIMEOUT_MILLISEC = 10000;
ArrayList<jobs> bookings = new ArrayList<jobs>();
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
}
@Override
public void onStart() {
super.onStart();
final Calendar c = Calendar.getInstance();
int mYear = c.get(Calendar.YEAR);
final String url = "... api ...";
new MybookingTask().execute(url);
}
@Override
protected void onListItemClick(android.widget.ListView l, android.view.View v, int position, long id) {
if (this.bookings == null) {
return;
}
startActivity(new Intent(Intent.ACTION_VIEW));
}
private void refreshResults(ArrayList<jobs> books) {
setListAdapter(new Mybookings(this,books));
}
private class MybookingTask extends AsyncTask<String, Void, ArrayList<jobs>> {
ProgressDialog mProgressDialog;
@Override
protected void onPreExecute() {
super.onPreExecute();
mProgressDialog = new ProgressDialog(GetMybookings.this);
mProgressDialog.setMessage("Loading Bookings...");
mProgressDialog.setIndeterminate(false);
mProgressDialog.setCancelable(false);
mProgressDialog.show();
}
protected ArrayList<jobs> doInBackground(String... urls) {
try {
HttpParams httpParams = new BasicHttpParams();
HttpConnectionParams.setConnectionTimeout(httpParams, TIMEOUT_MILLISEC);
HttpConnectionParams.setSoTimeout(httpParams, TIMEOUT_MILLISEC);
HttpClient httpClient = new DefaultHttpClient();
HttpGet httpGet = new HttpGet(urls[0]);
HttpResponse response = null;
try {
ResponseHandler<String> responseHandler = new BasicResponseHandler();
String responseBody = httpClient.execute(httpGet, responseHandler);
response = httpClient.execute(httpGet);
Log.i("AirconService GetMyBookings -- header login", response.getAllHeaders().toString());
Log.i("postData", response.getStatusLine().toString());
Log.i("AirconService GetMyBookings -- response data", response.getEntity().toString());
Log.i("AirconService GetMyBookings-- response data", response.toString());
HttpEntity entity = response.getEntity();
String responseString = new String();
if(entity != null) {
responseString = EntityUtils.toString(entity);
Log.i("WHAT???", "??? responseString is: " + responseString);
}
} catch(ClientProtocolException e) {
e.printStackTrace();
} catch(Throwable t) {
t.printStackTrace();
}
return null;
}
protected void onPostExecute(ArrayList<jobs> result) {
mProgressDialog.dismiss();
refreshResults(result);
}
}
}
已更新
我试过 Anand 的解决方案:它有效!!!
通用.java:
import ...
public class Common {
public static CookieStore cookieStore = new BasicCookieStore();
}
登录码:
public class Login extends Activity implements OnClickListener {
static HttpContext localContext = new BasicHttpContext();
...
protected Integer doInBackground(Void... params) {
localContext.setAttribute(ClientContext.COOKIE_STORE, Common.cookieStore);
//Create new default HTTPClient
httpclient = new DefaultHttpClient();
//Create new HTTP POST with URL to php file as parameter
httppost = new HttpPost(... api ...);
登录后的第二次调用(在单独的类中):
public class GetMybookings extends ListActivity {
static HttpContext localContext = new BasicHttpContext();
....
protected ArrayList<jobs> doInBackground(String... urls) {
try {
HttpClient httpClient = new DefaultHttpClient();
HttpGet httpGet = new HttpGet(... api ....);
HttpResponse response = null;
try {
localContext.setAttribute(ClientContext.COOKIE_STORE, Common.cookieStore);
response = httpClient.execute(httpGet, localContext);
最佳答案
试试这个对我有用:
// Create a local instance of cookie store
public static CookieStore cookieStore = new BasicCookieStore();
// Create local HTTP context
static HttpContext localContext = new BasicHttpContext();
// Bind custom cookie store to the local context
localContext.setAttribute(ClientContext.COOKIE_STORE, cookieStore);
// Pass local context as a parameter
HttpResponse httpResponse = client.execute(request, localContext);
List<Cookie> cookies = cookieStore.getCookies();
for (int i = 0; i < cookies.size(); i++) {
MLog.d("LOCAL COOKIES: ", ""+ cookies.get(i));
}
HttpEntity entity = httpResponse.getEntity();
尝试使用这个方法:
// Create a local instance of cookie store
public static CookieStore cookieStore = new BasicCookieStore();
// Create local HTTP context
static HttpContext localContext = new BasicHttpContext();
private synchronized void executeRequest(String url) {
HttpPost request = new HttpPost(url);
List<NameValuePair> params = new ArrayList<NameValuePair>();
//place them in an array list
params.add(new BasicNameValuePair("login", "login"));
params.add(new BasicNameValuePair("username", username));
params.add(new BasicNameValuePair("password", password));
params.add(new BasicNameValuePair("api_key", "service_api"));
request.setEntity(new UrlEncodedFormEntity(params, HTTP.UTF_8));
HttpClient client = new DefaultHttpClient();
HttpResponse httpResponse;
// Bind custom cookie store to the local context
localContext.setAttribute(ClientContext.COOKIE_STORE, cookieStore);
try{
// Pass local context as a parameter
httpResponse = client.execute(request, localContext);
List<Cookie> cookies = cookieStore.getCookies();
for (int i = 0; i < cookies.size(); i++) {
Log.d("LOCAL COOKIES: ", ""+ cookies.get(i));
}
HttpEntity entity = httpResponse.getEntity();
if (entity != null) {
InputStream instream = entity.getContent();
String res = convertStreamToString(instream);
instream.close();
}
} catch (Exception e) {
client.getConnectionManager().shutdown();
e.printStackTrace();
}
}
关于Android - 远程登录成功但不保留登录状态,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14620520/
我正在通读 Windows Phone 7.5 Unleashed,有很多代码看起来像这样(在页面的代码隐藏中): bool loaded; protected override void OnNav
在cgi服务器中,我这样返回 print ('Status: 201 Created') print ('Content-Type: text/html') print ('Location: htt
我正在查看 esh(easy shell)的实现,无法理解在这种情况下什么是 22 和 9 信号。理想情况下,有一个更具描述性的常量,但我找不到列表。 最佳答案 信号列表及其编号(包括您看到的这两个)
我的Oozie Hive Action 永远处于运行模式。 oozie.log文件中没有显示错误。
我正在编写一个使用 RFCOMM 通过蓝牙连接到设备的 Android 应用程序。我使用 BluetoothChat 示例作为建立连接的基础,大部分时间一切正常。 但是,有时由于出现套接字已打开的消息
我有一个云调度程序作业,它应该每小时访问我的 API 以更新一些价格。这些作业大约需要 80 秒才能运行。 这是它的作用: POST https://www.example.com/api/jobs/
我正在 Tomcat 上访问一个简单的 JSP 页面: 但是当我使用 curl 测试此页面时,我得到了 200 响应代码而不是预期的 202: $ curl -i "http://localhos
有时 JAR-RS 客户端会发送错误的语法请求正文。服务器应响应 HTTP status 400 (Bad Request) , 但它以 HTTP status 500 (Internal Serve
我正在尝试通过 response.send() 发送一个整数,但我不断收到此错误 express deprecated res.send(status): Use res.sendStatus(sta
我已经用 Excel 和 Java 做过很多次了……这次我需要用 Stata 来做,因为保存变量更方便'labels .如何将 dataset_1 重组为下面的 dataset_2? 我需要转换以下
我正在创建一个应用程序,其中的对象具有状态查找功能。为了提供一些上下文,让我们使用以下示例。 帮助台应用程序,其中创建作业并通过以下工作流程移动: 新 - 工作已创建但未分配 进行中 - 分配给工作人
我想在 Keras 中运行 LSTM 并获得输出和状态。在 TF 中有这样的事情 with tf.variable_scope("RNN"): for time_step in range
有谁知道 Scala-GWT 的当前状态 项目? 那里的主要作者 Grzegorz Kossakowski 似乎退出了这个项目,在 Spring 中从事 scalac 的工作。 但是,在 interv
我正在尝试编写一个 super 简单的 applescript 来启动 OneDrive App , 或确保打开,当机器的电源设置为插入时,将退出,或确保关闭,当电源设置为电池时。 我无法找到如何访问
目前我正在做这样的事情 link.on('click', function () { if (link.attr('href') !== $route.current.originalPath
是否可以仅通过查看用户代理来检测浏览器上是否启用/禁用 Javascript。 如果是,我应该寻找什么。如果否,检测用户浏览器是否启用/禁用 JavaScript 的最佳方法是什么 最佳答案 不,没有
Spring 和 OSGi 目前的开发状况如何? 最近好像有点安静了。 文档的最新版本 ( http://docs.spring.io/osgi/ ) 来自 2009 年。 我看到一些声明 Sprin
我正在从主函数为此类创建一个线程,但即使使用 Thread.currentThread().interrupt() 中断它,输出仍然包含“Still Here”行。 public class Writ
为了满足并发要求,我想知道如何在 Godog 中的多个步骤之间传递参数或状态。 func FeatureContext(s *godog.Suite) { // This step is ca
我有一个UIButton子类,它不使用UIImage背景,仅使用背景色。我注意到的一件事是,当您设置按钮的背景图像时,有一个默认的突出显示状态,当按下按钮时,该按钮会稍微变暗。 这是我当前的代码。
我是一名优秀的程序员,十分优秀!