- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我知道共享首选项是如何工作的,但我只是不知道在下面的代码中的哪里插入代码以保存用户数据。我有一个登录,后台任务可以完成所有工作和注册。我希望应用程序打开用户登录时到启动页面。无法从其他答案中找出
登录.java
Button bttnLogin;
EditText loginEmail, loginPassword;
TextView regLink;
AlertDialog.Builder alert;
@Override
protected void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_login);
loginEmail = (EditText) findViewById(R.id.email);
loginPassword = (EditText) findViewById(R.id.password);
regLink = (TextView) findViewById(R.id.regLink);
regLink.setOnClickListener(new View.OnClickListener()
{
@Override
public void onClick(View v)
{
startActivity(new Intent(Login.this, Register.class));
}
});
bttnLogin = (Button) findViewById(R.id.bttnLogin);
bttnLogin.setOnClickListener(new View.OnClickListener()
{
@Override
public void onClick(View v)
{
if (loginEmail.getText().toString().equals("") || loginPassword.getText().toString().equals(""))
{
alert = new AlertDialog.Builder(Login.this);
alert.setTitle("Login Failed");
alert.setMessage("Try again");
alert.setPositiveButton("OK", new DialogInterface.OnClickListener()
{
@Override
public void onClick(DialogInterface dialog, int which)
{
dialog.dismiss();
}
});
AlertDialog alertDialog = alert.create();
alertDialog.show();
} else //if user provides proper data
{
BackgroundTask backgroundTask = new BackgroundTask(Login.this);
backgroundTask.execute("login", loginEmail.getText().toString(), loginPassword.getText().toString());
}
}
});
注册.java
private Button regButton;
public EditText regName;
public EditText regEmail;
public EditText regPassword;
public EditText conPassword;
private AlertDialog.Builder alert;
@Override
protected void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_register);
regName = (EditText) findViewById(R.id.name);
regEmail = (EditText) findViewById(R.id.email);
regPassword = (EditText) findViewById(R.id.password);
conPassword = (EditText) findViewById(R.id.conPassword);
regButton = (Button) findViewById(R.id.regButton);
regButton.setOnClickListener(this);
}
@Override
public void onClick(View v)
{
if (regName.getText().toString().equals("") || regEmail.getText().toString().equals("") || regPassword.getText().toString().equals("") || conPassword.getText().toString().equals(""))
{
alert = new AlertDialog.Builder(Register.this);
alert.setTitle("Something not quite right");
alert.setMessage("Please fill in all the fields");
alert.setPositiveButton("OK", new DialogInterface.OnClickListener()
{
@Override
public void onClick(DialogInterface dialog, int which)
{
dialog.dismiss();
}
});
AlertDialog alertDialog = alert.create();
alertDialog.show();
} else if (!(regPassword.getText().toString().equals(conPassword.getText().toString())))
{
alert = new AlertDialog.Builder(Register.this);
alert.setTitle("Passwords do not match");
alert.setMessage("Try Again");
alert.setPositiveButton("OK", new DialogInterface.OnClickListener()
{
@Override
public void onClick(DialogInterface dialog, int which)
{
dialog.dismiss();
conPassword.setText("");
regPassword.setText("");
}
});
AlertDialog alertDialog = alert.create();
alertDialog.show();
}
else //if user provides proper data
{
BackgroundTask backgroundTask = new BackgroundTask(Register.this);
backgroundTask.execute("register", regName.getText().toString(), regEmail.getText().toString()
, regPassword.getText().toString(), conPassword.getText().toString());
}
背景任务.java
public class BackgroundTask extends AsyncTask<String,Void,String>
{
private Context context;
private Activity activity;
private String reg_url = "http://blaah.com/register.php";
private String login_url = "http://blaah.com/login.php";
private AlertDialog.Builder builder;
private ProgressDialog progressDialog;
public BackgroundTask(Context context)
{
this.context = context;
activity = (Activity) context;
}
@Override
protected void onPreExecute()
{
builder = new AlertDialog.Builder(activity);
progressDialog = new ProgressDialog(context);
progressDialog.setTitle("Please wait");
progressDialog.setMessage("Connecting to Server...");
progressDialog.setIndeterminate(true);
progressDialog.setCancelable(false);
progressDialog.show();
}
@Override
protected String doInBackground(String... params)
{
String method = params[0];
if (method.equals("register"))
{
try
{
URL url = new URL(reg_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 name = params[1];
String email = params[2];
String username = params[3];
String password = params[4];
String data = URLEncoder.encode("name", "UTF-8") + "=" + URLEncoder.encode(name, "UTF-8") + "&" +
URLEncoder.encode("email", "UTF-8") + "=" + URLEncoder.encode(email, "UTF-8") + "&" +
URLEncoder.encode("password", "UTF-8") + "=" + URLEncoder.encode(password, "UTF-8");
bufferedWriter.write(data);
bufferedWriter.flush();
bufferedWriter.close();
outputStream.close();
InputStream inputStream = httpURLConnection.getInputStream();
BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(inputStream));
StringBuilder stringBuilder = new StringBuilder();
String line = "";
while ((line = bufferedReader.readLine()) != null)
{
stringBuilder.append(line).append("\n");
}
httpURLConnection.disconnect();
Thread.sleep(8000);
return stringBuilder.toString().trim();
} catch (MalformedURLException e)
{
e.printStackTrace();
} catch (IOException e)
{
e.printStackTrace();
} catch (InterruptedException e)
{
e.printStackTrace();
}
}
else if (method.equals("login"))
{
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 username,password;
username = params[1];
password = params [2];
String data = URLEncoder.encode("email", "UTF-8") + "=" + URLEncoder.encode(username, "UTF-8") + "&" +
URLEncoder.encode("password", "UTF-8") + "=" + URLEncoder.encode(password, "UTF-8");
bufferedWriter.write(data);
bufferedWriter.flush();
bufferedWriter.close();
outputStream.close();
InputStream inputStream = httpURLConnection.getInputStream();
BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(inputStream));
StringBuilder stringBuilder = new StringBuilder();
String line = "";
while ((line = bufferedReader.readLine()) != null)
{
stringBuilder.append(line + "\n");
}
httpURLConnection.disconnect();
Thread.sleep(5000);
return stringBuilder.toString().trim();
} catch (MalformedURLException e)
{
e.printStackTrace();
} catch (ProtocolException e)
{
e.printStackTrace();
} catch (UnsupportedEncodingException e)
{
e.printStackTrace();
} catch (IOException e)
{
e.printStackTrace();
} catch (InterruptedException e)
{
e.printStackTrace();
}
}
return null;
}
@Override
protected void onProgressUpdate(Void... values)
{
super.onProgressUpdate(values);
}
@Override
protected void onPostExecute(String json)
{
try
{
progressDialog.dismiss();
Log.v("JSON", json);
JSONObject jsonObject = new JSONObject(json);
JSONArray jsonArray = jsonObject.getJSONArray("server_response");
JSONObject jsonobject = jsonArray.getJSONObject(0);
String code = jsonobject.getString("code");
String message = jsonobject.getString("message");
if(code.equals("reg_true"))
{
showDialog("Sucessful registration.Thank you.Enjoy_AS!", message, code);
}
else if (code.equals("reg_false"))
{
showDialog("User Already exists", message, code);
}
else if (code.equals("login_true"))
{
Toast.makeText(context, "You are logged in", Toast.LENGTH_LONG).show();
Intent intent = new Intent(activity, SplashScreen.class);
activity.startActivity(intent);
} else if (code.equals("login_false"))
{
showDialog("Login Error", message, code);
}
} catch (JSONException e){
e.printStackTrace();
}
}
public void showDialog(String title,String message,String code)
{
builder.setTitle(title);
if (code.equals("reg_true") || code.equals("reg_false"))
{
builder.setMessage(message);//message form server
builder.setPositiveButton("OK", new DialogInterface.OnClickListener()
{
@Override
public void onClick(DialogInterface dialog, int which)
{
dialog.dismiss();
activity.finish();
}
});
}
else if (code.equals("login_false"))
{
builder.setMessage(message);
builder.setPositiveButton("OK", new DialogInterface.OnClickListener()
{
@Override
public void onClick(DialogInterface dialog, int which)
{
EditText loginEmail, loginPassword;
loginEmail = (EditText) activity.findViewById(R.id.email);
loginPassword = (EditText) activity.findViewById(R.id.password);
loginEmail.setText("");
loginPassword.setText("");
dialog.dismiss();
}
});
}
AlertDialog alertDialog = builder.create();
alertDialog.show();
}
}
启动画面我希望应用程序打开
final String TAG = this.getClass().getName();
private static int SPLASH_TIME_OUT = 4000;
private TextView saying;
@Override
protected void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
//this.requestWindowFeature(Window.FEATURE_NO_TITLE);
supportRequestWindowFeature(Window.FEATURE_NO_TITLE);
getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN,
WindowManager.LayoutParams.FLAG_FULLSCREEN);
setContentView(R.layout.activity_splash_screen);
saying = (TextView) findViewById(R.id.saying);
Typeface mainHead = Typeface.createFromAsset(getAssets(), "fonts/emporo.TTF");
saying.setTypeface(mainHead);
//Set text custom font for subhead text
new Handler().postDelayed(new Runnable()
{
@Override
public void run()
{
// This method will be executed once the timer is over
// Start your app main activity
Intent i = new Intent(SplashScreen.this, HomeScreen.class);
startActivity(i);
// close this activity
finish();
}
}, SPLASH_TIME_OUT);
}
}
最佳答案
这是我在我的每个 Android 应用程序中使用的 SharedPreferences
import android.content.Context;
import android.content.SharedPreferences;
/**
* Created by Jimit Patel on 30/07/15.
*/
public class Prefs {
private static final String TAG = Prefs.class.getSimpleName();
private static final String MY_APP_PREFS = "my_app";
/**
* <p>Provides Shared Preference object</p>
* @param context
* @return
*/
private static SharedPreferences getPrefs(Context context) {
return context.getSharedPreferences(MY_APP_PREFS, Context.MODE_PRIVATE);
}
/**
* <p>Saves a string value for a given key in Shared Preference</p>
* @param context
* @param key
* @param value
*/
public static void setString(Context context, String key, String value) {
getPrefs(context).edit().putString(key, value).apply();
}
/**
* <p>Saves integer value for a given key in Shared Preference</p>
* @param context
* @param key
* @param value
*/
public static void setInt(Context context, String key, int value) {
getPrefs(context).edit().putInt(key, value).apply();
}
/**
* <p>Saves float value for a given key in Shared Preference</p>
* @param context
* @param key
* @param value
*/
public static void setFloat(Context context, String key, float value) {
getPrefs(context).edit().putFloat(key, value).apply();
}
/**
* <p>Saves long value for a given key in Shared Preference</p>
* @param context
* @param key
* @param value
*/
public static void setLong(Context context, String key, long value) {
getPrefs(context).edit().putLong(key, value).apply();
}
/**
* <p>Saves boolean value for a given key in Shared Preference</p>
* @param context
* @param key
* @param value
*/
public static void setBoolean(Context context, String key, boolean value) {
getPrefs(context).edit().putBoolean(key, value).apply();
}
/**
* Provides string from the Shared Preferences
* @param context
* @param key
* @param defaultValue
* @return
*/
public static String getString(Context context, String key, String defaultValue) {
return getPrefs(context).getString(key, defaultValue);
}
/**
* Provides int from Shared Preferences
* @param context
* @param key
* @param defaultValue
* @return
*/
public static int getInt(Context context, String key, int defaultValue) {
return getPrefs(context).getInt(key, defaultValue);
}
/**
* Provides boolean from Shared Preferences
* @param context
* @param key
* @param defaultValue
* @return
*/
public static boolean getBoolean(Context context, String key, boolean defaultValue) {
return getPrefs(context).getBoolean(key, defaultValue);
}
/**
* Provides float value from Shared Preferences
* @param context
* @param key
* @param defaultValue
* @return
*/
public static float getFloat(Context context, String key, float defaultValue) {
return getPrefs(context).getFloat(key, defaultValue);
}
/**
* Provides long value from Shared Preferences
* @param context
* @param key
* @param defaultValue
* @return
*/
public static long getLong(Context context, String key, long defaultValue) {
return getPrefs(context).getLong(key, defaultValue);
}
public static void clearPrefs(Context context) {
getPrefs(context).edit().clear().commit();
}
}
要使用它,你可以只使用它的那些功能
关于android - 共享偏好,它们去哪里了?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36768955/
只是想知道是否有可能找出谁从 Windows 共享中读取了文件(最好使用 .NET,但 win32 native 可以)? 我想做的是创建类似 awstats 的东西对于 Windows 共享,这样我
是否可以列出 Intent.ACTION_SEND ?我的意思是我需要知道是否有人通过 action_send 在 Facebook 上分享或在 Twitter 上发推文。 最佳答案 也许你想要一个更
我正在使用 Google Apps 应用程序。实际上,我想在不使用密码的情况下访问另一个 ID。我使用了 OAuth,它运行良好。但我无法分享特定人的日历。我尝试了以下代码。 GoogleOAuthP
我怎样才能只创建模拟器...可能吗?我知道,设备需要分发证书。 最佳答案 您只需将应用程序目录从 iPhone 模拟器复制到另一个实例/操作系统版本,它就应该可以工作。 因此,如果您想分发 3.1.3
我想使用多阶段构建来避免每次构建应用程序时都下载我的 Java 项目所需的所有 Maven 依赖项。 我正在考虑在第一阶段解决 Maven 依赖项,然后在第二阶段构建应用程序,这将需要访问在前一阶段下
我正在寻找保护用户下载内容的初步想法。用户下载充满有趣资源的 zip 文件,这些资源被提取到本地文件系统中以供应用程序使用。我的目标是防止用户通过互联网将下载的资源共享给其他用户(假设他们获得了对文件
我想知道在具有移动和桌面版本的网站上共享身份验证、 session 管理等的最佳方法是什么。我们正在运行 Tomcat,并且更愿意将移动站点和桌面站点的应用程序保持在不同的节点上。 我看过类似的帖子,
我发现了这个单例的实现。我怎样才能创建指向它的指针或共享指针?` 为什么这不起作用?自动测试 = Singleton::Instance(); class Singleton { public: st
我有一个 heroku 项目,我想与其他人分享。作为the instructions describe ,我使用 virtualenv 来管理环境和依赖项。有没有办法在新机器上从 requiremen
Maven 将所有 jar 存储在本地存储库 ~/.m2/repository/ 下。用户多时占用空间大。 那么,是否可以由多个用户共享这个本地存储库,或许在不同的目录结构下? 最佳答案 简单的回答
为什么共享 worker 在重新加载页面时死了?应该是复活了我该如何解决这个问题? 重装前 重新加载后(在example.com上按F5) parent worker var port = new S
我正在开发多个小型应用程序,这些应用程序将共享通用和共享模块和 Assets 。 关于如何创建项目结构的部分在这里回答:https://stackoverflow.com/a/61254557/135
我在 RHEL 上安装了 jenkins (localhost:8080),我能够成功地构建代码 现在,我想设置主/从代理。 我的笔记本电脑将充当“Master Jenkins”,而我同事的笔记本电脑
我有这种方法可以根据我使用的 EXTRA_STREAM 共享文本文件或图片。我有这两个我可以选择 i.putExtra(Intent.EXTRA_STREAM, uri); i.putExtra(In
我正在使用 R 中的一个数据分析项目,我正在使用 R 中的敏感私有(private)数据进行一些逻辑和多级建模。我爱上了 。预订 包,我已经创建了一本关于我们的工作流程和分析管道的相当广泛的书。问题是
我正在构建的应用程序需要在 UITabBarController 框架内为多个 View (及其 subview )显示共享的自定义 UIToolbar。自定义工具栏的内容在所有 View 中都是相同
我有多个应用程序,我想共享相同的 eslint 配置: - project_root/ - app1/ - node_modules/ - eslint.rc
我有多个 Electron 应用程序。一个是主应用程序,其他几个功能应用程序。主应用程序上的按钮很少,这将导致功能应用程序打开。这里的问题是每个应用程序都有一个主进程,该进程导致要利用更多的CPU。是
我正在开发一个 Node.js 后端,它通过 websocket 与一些桌面客户端进行通信,而服务器端的通信是从 Web 前端发起的。一切正常,因为我将 SockJS Connection 实例存储在
我对托管多个网站的服务器上的多个用户帐户使用私有(private) SSH key 和无密码条目。 我为每个用户帐户使用相同的私钥。 (因为我很懒?或者那是“正确”的方式)。 我现在想授权该国不同地区
我是一名优秀的程序员,十分优秀!