该登录界面一共实现三个功能:
1.实现登录
2.实现注册
3.实现记住密码
AndroidManifest.xml 文件:
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools">
<application
android:allowBackup="true"
android:dataExtractionRules="@xml/data_extraction_rules"
android:fullBackupContent="@xml/backup_rules"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:roundIcon="@mipmap/ic_launcher_round"
android:supportsRtl="true"
android:theme="@style/Theme.Smart_Campus"
tools:targetApi="31">
<activity
android:name=".MainActivity"
android:exported="true"
android:launchMode="standard">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<activity android:name=".loginActivity"/>
<activity android:name=".registeredActivity"/>
</application>
</manifest>
bean文件中的Account类:
package com.example.smart_campus.bean;
public class Account {
private int id;
private String account;
private String password;
public Account(int id, String account, String password) {
this.id = id;
this.account = account;
this.password = password;
}
public Account() {
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getAccount() {
return account;
}
public void setAccount(String account) {
this.account = account;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
}
db文件夹中的AccountService:
package com.example.smart_campus.db;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import com.example.smart_campus.bean.Account;
public class AccountService {
private DataBaseHelper dataBaseHelper;
public AccountService(Context context) {
dataBaseHelper = new DataBaseHelper(context);
}
//登录
public Boolean login(String account, String password){
SQLiteDatabase sqLiteDatabase = dataBaseHelper.getReadableDatabase();
String sql = "select * from Account where act = ? and pwd = ?";
Cursor cursor = sqLiteDatabase.rawQuery(sql,new String[]{account,password});
if (cursor.moveToFirst()) {
cursor.close();
return true;
} else {
return false;
}
}
//注册
public Boolean registered(Account account){
SQLiteDatabase sqLiteDatabase = dataBaseHelper.getReadableDatabase();
String sql = "insert into Account(act,pwd) values(?,?)";
Object[] obj = {account.getAccount(),account.getPassword()};
sqLiteDatabase.execSQL(sql,obj);
return true;
}
}
db文件夹中的DataBaseHelper:
package com.example.smart_campus.db;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import androidx.annotation.Nullable;
public class DataBaseHelper extends SQLiteOpenHelper {
public static final String DATABASE_NAME = "Smart_Campus.db";
public static final int DATABASE_VERSION = 1;
public static final String TABLE_NAME = "Account";
public static final String COLUMN_ID = "id";
public static final String COLUMN_Account = "act";
public static final String COLUMN_Password = "pwd";
public DataBaseHelper(@Nullable Context context) {
super(context, DATABASE_NAME, null, DATABASE_VERSION);
}
//创建数据库
@Override
public void onCreate(SQLiteDatabase db) {
String query = "CREATE TABLE " + TABLE_NAME +
" (" + COLUMN_ID + " INTEGER PRIMARY KEY AUTOINCREMENT, " +
COLUMN_Account + " VARCHAR(20), " +
COLUMN_Password + " VARCHAR(20))";
db.execSQL(query);
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
}
}
MainActivity:
package com.example.smart_campus;
import android.content.Intent;
import android.content.SharedPreferences;
import android.os.Bundle;
import android.preference.PreferenceManager;
import android.view.View;
import android.widget.Button;
import android.widget.CheckBox;
import android.widget.EditText;
import android.widget.Toast;
import androidx.annotation.Nullable;
import androidx.appcompat.app.AppCompatActivity;
import com.example.smart_campus.db.AccountService;
public class MainActivity extends AppCompatActivity {
private SharedPreferences sharedPreferences;
private SharedPreferences.Editor editor;
private CheckBox rememberPass;
@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Button button_login = findViewById(R.id.login);
EditText account = findViewById(R.id.account);
EditText password = findViewById(R.id.password);
AccountService accountService = new AccountService(this);
rememberPass = findViewById(R.id.reb_pwd);
sharedPreferences = PreferenceManager.getDefaultSharedPreferences(this);
boolean isRemember = sharedPreferences.getBoolean("remember_password", false);
if (isRemember) {
String reb_account = sharedPreferences.getString("account", "");
String reb_password = sharedPreferences.getString("password", "");
account.setText(reb_account);
password.setText(reb_password);
rememberPass.setChecked(true);
}
button_login.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
String act = account.getText().toString();
String pwd = password.getText().toString();
Boolean flag = accountService.login(act, pwd);
if (flag) {
editor = sharedPreferences.edit();
if (rememberPass.isChecked()) {
editor.putBoolean("remember_password", true);
editor.putString("account", act);
editor.putString("password", pwd);
} else {
editor.clear();
}
editor.commit();
Intent intent = new Intent(MainActivity.this, loginActivity.class);
startActivity(intent);
} else {
Toast.makeText(MainActivity.this, "账号或密码错误!", Toast.LENGTH_SHORT).show();
}
}
});
Button button_registered = findViewById(R.id.registered);
button_registered.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Intent intent = new Intent(MainActivity.this, registeredActivity.class);
startActivity(intent);
}
});
}
}
loginActivity
package com.example.smart_campus;
import android.os.Bundle;
import androidx.annotation.Nullable;
import androidx.appcompat.app.AppCompatActivity;
public class loginActivity extends AppCompatActivity {
@Override
public void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.login);
}
}
registeredActivity
package com.example.smart_campus;
import android.content.DialogInterface;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.widget.EditText;
import androidx.annotation.Nullable;
import androidx.appcompat.app.AlertDialog;
import androidx.appcompat.app.AppCompatActivity;
import com.example.smart_campus.bean.Account;
import com.example.smart_campus.db.AccountService;
public class registeredActivity extends AppCompatActivity {
@Override
public void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.registered);
}
public void myClick(View view){
if (view.getId() == R.id.reg){
AlertDialog.Builder builder = new AlertDialog.Builder(this);
EditText new_account = findViewById(R.id.new_account);
EditText new_pwd = findViewById(R.id.new_pwd);
EditText re_pwd = findViewById(R.id.re_pwd);
AccountService accountService = new AccountService(this);
if (!new_account.getText().toString().isEmpty() && new_pwd.getText().toString().equals(re_pwd.getText().toString())){
Account account = new Account();
account.setAccount(new_account.getText().toString());
account.setPassword(new_pwd.getText().toString());
accountService.registered(account);
builder.setTitle("提示");
builder.setMessage("注册成功");
builder.setPositiveButton("确定", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
Intent intent = new Intent(registeredActivity.this, MainActivity.class);
startActivity(intent);
}
});
builder.setNegativeButton("取消",null);
builder.show();
} else {
builder.setTitle("提示");
builder.setMessage("注册失败!新账号为空或新密码与确认密码不同");
builder.setNegativeButton("确认",null);
builder.show();
}
}
}
}
layout文件中的activity_main
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity"
android:orientation="vertical">
<TextView
android:layout_width="match_parent"
android:layout_height="50dp"
android:text="Hello Android"
android:textStyle="bold"
android:gravity="center"
android:textSize="30dp"
android:layout_marginTop="10dp"
/>
<EditText
android:id="@+id/account"
android:layout_width="200dp"
android:layout_height="48dp"
android:hint="请输入账号"
android:layout_gravity="center"
android:layout_marginTop="120dp"
/>
<EditText
android:id="@+id/password"
android:layout_width="200dp"
android:layout_height="48dp"
android:hint="请输入密码"
android:inputType="textPassword"
android:layout_gravity="center"
android:layout_marginTop="10dp"
/>
<CheckBox
android:id="@+id/reb_pwd"
android:layout_width="100dp"
android:layout_height="20dp"
android:layout_marginLeft="100dp"
android:text="记住密码"
/>
<Button
android:id="@+id/login"
android:layout_width="200dp"
android:layout_height="wrap_content"
android:text="登录"
android:layout_gravity="center"
android:onClick="btnClick"
android:layout_marginTop="10dp"
/>
<Button
android:id="@+id/registered"
android:layout_width="200dp"
android:layout_height="wrap_content"
android:text="注册"
android:layout_gravity="center"
android:onClick="btnClick"
/>
</LinearLayout>
layout中的login文件
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<TextView
android:id="@+id/login_text"
android:layout_width="match_parent"
android:layout_height="60dp"
android:text="登录成功!"
android:textSize="40dp"
android:gravity="center"
android:layout_gravity="center_vertical"
/>
</LinearLayout>
layout文件中的registered
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:gravity="center_horizontal">
<TextView
android:layout_width="match_parent"
android:layout_height="50dp"
android:text="Hello Android"
android:textStyle="bold"
android:gravity="center"
android:textSize="30dp"
android:layout_marginTop="10dp"
/>
<TextView
android:layout_width="match_parent"
android:layout_height="50dp"
android:layout_marginTop="30dp"
android:text="注册界面"
android:textStyle="bold"
android:gravity="center"
android:textSize="30dp"
/>
<EditText
android:id="@+id/new_account"
android:layout_width="200dp"
android:layout_height="48dp"
android:layout_marginTop="30dp"
android:hint="输入新账号"
android:layout_gravity="center"/>
<EditText
android:id="@+id/new_pwd"
android:layout_width="200dp"
android:layout_height="48dp"
android:layout_marginTop="10dp"
android:hint="输入新密码"
android:layout_gravity="center"/>
<EditText
android:id="@+id/re_pwd"
android:layout_width="200dp"
android:layout_height="48dp"
android:layout_marginTop="10dp"
android:hint="确认新密码"
android:layout_gravity="center"/>
<Button
android:id="@+id/reg"
android:layout_width="200dp"
android:layout_height="48dp"
android:layout_marginTop="30dp"
android:text="确认注册"
android:onClick="myClick"
/>
</LinearLayout> 我有一个用户工厂。我希望默认情况下确认用户。但是鉴于unconfirmed特征,我不希望它们被确认。虽然我有一个基于实现细节而不是抽象的工作实现,但我想知道如何正确地做到这一点。factory:userdoafter(:create)do|user,evaluator|#unwantedimplementationdetailshereunlessFactoryGirl.factories[:user].defined_traits.map(&:name).include?(:unconfirmed)user.confirm!endendtrait:unconfirmeddoenden
有没有办法在这个简单的get方法中添加超时选项?我正在使用法拉第3.3。Faraday.get(url)四处寻找,我只能先发起连接后应用超时选项,然后应用超时选项。或者有什么简单的方法?这就是我现在正在做的:conn=Faraday.newresponse=conn.getdo|req|req.urlurlreq.options.timeout=2#2secondsend 最佳答案 试试这个:conn=Faraday.newdo|conn|conn.options.timeout=20endresponse=conn.get(url
我想在Ruby中创建一个用于开发目的的极其简单的Web服务器(不,不想使用现成的解决方案)。代码如下:#!/usr/bin/rubyrequire'socket'server=TCPServer.new('127.0.0.1',8080)whileconnection=server.acceptheaders=[]length=0whileline=connection.getsheaders想法是从命令行运行这个脚本,提供另一个脚本,它将在其标准输入上获取请求,并在其标准输出上返回完整的响应。到目前为止一切顺利,但事实证明这真的很脆弱,因为它在第二个请求上中断并出现错误:/usr/b
我意识到这可能是一个非常基本的问题,但我现在已经花了几天时间回过头来解决这个问题,但出于某种原因,Google就是没有帮助我。(我认为部分问题在于我是一个初学者,我不知道该问什么......)我也看过O'Reilly的RubyCookbook和RailsAPI,但我仍然停留在这个问题上.我找到了一些关于多态关系的信息,但它似乎不是我需要的(尽管如果我错了请告诉我)。我正在尝试调整MichaelHartl'stutorial创建一个包含用户、文章和评论的博客应用程序(不使用脚手架)。我希望评论既属于用户又属于文章。我的主要问题是:我不知道如何将当前文章的ID放入评论Controller。
我的工作要求我为某些测试自动生成电子邮件。我一直在四处寻找,但未能找到可以快速实现的合理解决方案。它需要在outlook而不是其他邮件服务器中,因为我们有一些奇怪的身份验证规则,我们需要保存草稿而不是仅仅发送邮件的选项。显然win32ole可以做到这一点,但我找不到任何相当简单的例子。 最佳答案 假设存储了Outlook凭据并且您设置为自动登录到Outlook,WIN32OLE可以很好地完成此操作:require'win32ole'outlook=WIN32OLE.new('Outlook.Application')message=
华为OD机试题本篇题目:明明的随机数题目输入描述输出描述:示例1输入输出说明代码编写思路最近更新的博客华为od2023|什么是华为od,od薪资待遇,od机试题清单华为OD机试真题大全,用Python解华为机试题|机试宝典【华为OD机试】全流程解析+经验分享,题型分享,防作弊指南华为o
C#实现简易绘图工具一.引言实验目的:通过制作窗体应用程序(C#画图软件),熟悉基本的窗体设计过程以及控件设计,事件处理等,熟悉使用C#的winform窗体进行绘图的基本步骤,对于面向对象编程有更加深刻的体会.Tutorial任务设计一个具有基本功能的画图软件**·包括简单的新建文件,保存,重新绘图等功能**·实现一些基本图形的绘制,包括铅笔和基本形状等,学习橡皮工具的创建**·设计一个合理舒适的UI界面**注明:你可能需要先了解一些关于winform窗体应用程序绘图的基本知识,以及关于GDI+类和结构的知识二.实验环境Windows系统下的visualstudio2017C#窗体应用程序三.
//1.验证返回状态码是否是200pm.test("Statuscodeis200",function(){pm.response.to.have.status(200);});//2.验证返回body内是否含有某个值pm.test("Bodymatchesstring",function(){pm.expect(pm.response.text()).to.include("string_you_want_to_search");});//3.验证某个返回值是否是100pm.test("Yourtestname",function(){varjsonData=pm.response.json
在前面两节的例子中,主界面窗口的尺寸和标签控件显示的矩形区域等,都是用C++代码编写的。窗口和控件的尺寸都是预估的,控件如果多起来,那就不好估计每个控件合适的位置和大小了。用C++代码编写图形界面的问题就是不直观,因此Qt项目开发了专门的可视化图形界面编辑器——QtDesigner(Qt设计师)。通过QtDesigner就可以很方便地创建图形界面文件*.ui,然后将ui文件应用到源代码里面,做到“所见即所得”,大大方便了图形界面的设计。本节就演示一下QtDesigner的简单使用,学习拖拽控件和设置控件属性,并将ui文件应用到Qt程序代码里。使用QtDesigner设计界面在开始菜单中找到「Q
MIMO技术的优缺点优点通过下面三个增益来总体概括:阵列增益。阵列增益是指由于接收机通过对接收信号的相干合并而活得的平均SNR的提高。在发射机不知道信道信息的情况下,MIMO系统可以获得的阵列增益与接收天线数成正比复用增益。在采用空间复用方案的MIMO系统中,可以获得复用增益,即信道容量成倍增加。信道容量的增加与min(Nt,Nr)成正比分集增益。在采用空间分集方案的MIMO系统中,可以获得分集增益,即可靠性性能的改善。分集增益用独立衰落支路数来描述,即分集指数。在使用了空时编码的MIMO系统中,由于接收天线或发射天线之间的间距较远,可认为它们各自的大尺度衰落是相互独立的,因此分布式MIMO