注册和登陆大多都是一些用户名和密码的验证,所以放在一起写,注册代码:

String account = accountEdit.getText().toString().trim();
String password = passwordEdit.getText().toString().trim();
String yanzheng = yanzhengma.getText().toString().trim();
if(account.equals("")||password.equals("")||yanzheng.equals("")) {
if (account.equals(""))
Toast.makeText(this, "请填写用户名!", Toast.LENGTH_SHORT).show();
else if(password.equals(""))
Toast.makeText(this, "请填写用户密码!", Toast.LENGTH_SHORT).show();
else if(yanzheng.equals(""))
Toast.makeText(this, "请点击获取验证码!", Toast.LENGTH_SHORT).show();
} else if(a != Integer.valueOf(yanzheng)){
Toast.makeText(this, "验证码输入错误!", Toast.LENGTH_SHORT).show();
} else if (account.length() > 6 || account.length() < 2) {
Toast.makeText(this, "请输入2-6位用户名!", Toast.LENGTH_SHORT).show();
accountEdit.setText("");
} else if (password.length() > 8 || password.length() < 4) {
Toast.makeText(this, "请输入4-8位密码!", Toast.LENGTH_SHORT).show();
passwordEdit.setText("");
} else {
//存储
BmobUser us = new BmobUser();
us.setUsername(account);
us.setPassword(password);
//检查网络连接
if(!NetWork.isNetConnection(this)){
Toast.makeText(this,"无网络连接!",Toast.LENGTH_SHORT).show();
return;
}else{
us.signUp(new SaveListener() {
@Override
public void done(BmobUser re, BmobException e) {
if(e==null){
Toast.makeText(Register.this, "注册成功!", Toast.LENGTH_SHORT).show();
}else{
Toast.makeText(Register.this, "用户名已存在,请直接登录!", Toast.LENGTH_SHORT).show();
}
}
});
//跳转到登录界面
Intent intent2 = new Intent(Register.this,login.class);
intent2.putExtra("account", account);
intent2.putExtra("password", password);
startActivity(intent2);
finish();
}
}

对于用户名和密码的一些判断,使用signUp来进行用户注册,注册成功后会利用intent传递用户参数给登录界面。

下面是登陆界面的初始化代码,本文使用LitePal进行本地数据库存储用户信息,并将用户的用户名和密码使用SharedPreferences文件存储,这里可以使用MD5进行加密,但我没写:

//数据库初始化
LitePal.initialize(this);
LitePal.getDatabase();
// 注册订阅者
EventBus.getDefault().register(this);
//初始化bmob
Bmob.initialize(this, "d4dafd6854343ba7b42a4c347757c7e6");
BmobIM.init(this);
BmobIM.registerDefaultMessageHandler(new ImMessageHandler());
//TODO 集成:1.4、初始化数据服务SDK、初始化设备信息并启动推送服务
// 使用推送服务时的初始化操作
BmobInstallationManager.getInstance().initialize(new InstallationListener() {
@Override
public void done(BmobInstallation bmobInstallation, BmobException e) {}});
// 启动推送服务
BmobPush.startWork(this);

接下来判断复选框(是否记住密码)以及是否有参数传递过来:

//判断是否选中
if(isRemember){
String account = pref.getString("account","");
String password = pref.getString("password","");
accountEdit.setText(account);
passwordEdit.setText(password);
rememberPass.setChecked(true);
}
try {
Intent intent0 = getIntent();
String acc = intent0.getStringExtra("account");
String pass = intent0.getStringExtra("password");
//判断是否记住
if(isRemember) {
String acc1 = accountEdit.getText().toString().trim();
String pass1 = passwordEdit.getText().toString().trim();
editor = pref.edit();
if(rememberPass.isChecked()){
editor.putBoolean("remember",true);
editor.putString("account",acc1);
editor.putString("password",pass1);
} else {
editor.clear();
}
editor.apply();
}
//判断传递值是否为空
if(!(acc.equals("")&&pass.equals(""))){
accountEdit.setText(acc);
passwordEdit.setText(pass);
}
}catch (Exception e) {
Log.i(TAG, "onCreate: "+e);
}

当用户点击登陆按钮,调用login方法判断用户是否存在于服务器中:

//检查网络连接
if(!NetWork.isNetConnection(this)){
Toast.makeText(this,"无网络连接!",Toast.LENGTH_SHORT).show();
return;
}else{
// 登录验证
us.login(new SaveListener() {
@Override
public void done(BmobUser bmobUser, BmobException e) {
if(e==null){
Intent intent1 = new Intent(login.this,MainActivity.class);
startActivity(intent1);
finish();
}else{
Toast.makeText(login.this,"用户名或密码错误,请重新登陆!",Toast.LENGTH_SHORT).show();
}
}
});
}

用户登录成功之后就会跳转到MainActivity了。

即时聊天APP(三) - 注册和登陆的更多相关文章

  1. 即时聊天APP(一)

    最新写了一个即时聊天的安卓Demo,是基于Bmob后端开发的app,由于Bmob有较大局限性,因此,我并没有按照开发文档来进行开发,只是简单写了一个基本的文字聊天,以后有时间我会自己写一个带服务端的即 ...

  2. 即时聊天APP(二) - MainActivity

    主活动包含三个Fragment,分别是会话.联系人和设置,初始布局隐藏所有碎片,然后把应该显示的显示出来: //隐藏所有Fragment private void hideAll(){ Fragmen ...

  3. 即时聊天APP(六) - 消息的接收以及EventBus使用

    通常我们在接收消息的时候会有声音和震动的提示,因此我也加了代码达到这样的效果,这就要用到EventBus了,当然这里我也用到了自定义的广播,所以首先在Mainfests文件中加入以下代码: <r ...

  4. 即时聊天APP(五) - 聊天界面

    设置界面没什么好说的,无非也就是加了个对话框来二次提醒用户,现在来讲讲聊天界面. 聊天界面初始化时会得到一个参数,就是对方的id,并设置在标题栏的位置,此界面也是使用RecyclerView来展示聊天 ...

  5. 即时聊天APP(四) - 联系人和会话

    联系人和会话界面使用的是RecyclerView进行滑动显示,并将好友列表存储至数据库,以供下次登录时使用,RecyclerView在后面我会详细介绍,这里略过. 联系人初始化时读取数据库并展示: / ...

  6. web 直播&即时聊天------阿里云、融云(三)

    经过前面的知识,基本已经把聊天室的功能搞定了,剩下的就是直播的问题了... 一如既往,阿里云的web demo也是少的可怜,只有一个web播放器(Prismplayer),所以这里主要就此播放器踩的坑 ...

  7. Node.js + Web Socket 打造即时聊天程序嗨聊

    前端一直是一块充满惊喜的土地,不仅是那些富有创造性的页面,还有那些惊赞的效果及不断推出的新技术.像node.js这样的后端开拓者直接将前端人员的能力扩大到了后端.瞬间就有了一统天下的感觉,来往穿梭于前 ...

  8. 开发一款即时通讯App,从这几步开始

    欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 本文由腾讯云视频发表于云+社区专栏 关注公众号"腾讯云视频",一键获取 技术干货 | 优惠活动 | 视频方案 " ...

  9. IdentityServer4 + SignalR Core +RabbitMQ 构建web即时通讯(三)

    IdentityServer4 + SignalR Core +RabbitMQ 构建web即时通讯(三) 后台服务用户与认证 新建一个空的.net core web项目Demo.Chat,端口配置为 ...

随机推荐

  1. centos7通过yum安装docker

    ##yum源安装#1.更新yumyum update #2.删除旧版本yum remove docker \docker-client \docker-client-latest \docker-co ...

  2. git使用WebHook实现自动构建

    说明 我们使用git进行版本管理常常会遇到这样的一个需求,希望git push的时候服务器上代码的代码也能自动更新,这次我使用了coding进行示范 一.编写git pull 更新脚本 auth_pu ...

  3. StudyAndroid.2 Activity生命周期

    onCreate(): 当我们点击activity的时候,系统会调用activity的oncreate()方法,在这个方法中我们会初始化当前布局setContentLayout()方法. onStar ...

  4. 危险的Hystrix线程池

    本文介绍Hystrix线程池的工作原理和参数配置,指出存在的问题并提供规避方案,阅读本文需要对Hystrix有一定的了解. 文本讨论的内容,基于hystrix 1.5.18: <dependen ...

  5. Unity进阶:用AssetBundle和Json做了一个玩家登陆界面

    版权申明: 本文原创首发于以下网站: 博客园『优梦创客』的空间:https://www.cnblogs.com/raymondking123 优梦创客的官方博客:https://91make.top ...

  6. Python实现的一些常见简单问题(持续更新)

    提纲: 1.汉诺塔 2.找到某个范围内的所有质数 3.杨辉三角 4.用闭包实现一个计数器,调用一次计数器加1 5.将类构造成可迭代对象,实现斐波那契数列 ...... 1.汉诺塔(汉诺塔) 用递归函数 ...

  7. Delphi - cxGrid字段类型设定为ComboBox 并实现动态加载Item

    cxGrid设定字段类型为ComboBox 在cxGrid中选中需要设定的字段: 单击F11调出属性控制面板,在Properties下拉选项中选中ComboBox,完成字段类型的设定. cxGrid ...

  8. HTTP 8中请求方式介绍

    HTTP请求方式中8种请求方法(简单介绍)   简单介绍 HTTP是超文本传输协议,其定义了客户端与服务器端之间文本传输的规范.HTTP默认使用80端口,这个端口指的是服务端的端口,而客户端使用的端口 ...

  9. Markdown实用技巧整理

    标题 段落 列表 引用 代码块 链接 图片 一.标题 一级标题 二级标题 三级标题 四级标题 五级标题 六级标题 二.段落 1.换行: 2.加粗: 3.分割线: 4.删除线: deprecated 5 ...

  10. Mac迅雷瘦身精简教程

    迅雷是个大家很熟悉的工具了,尽管吐槽的人不少,但相信大家也都是口嫌体直,边骂边用. 其实 macOS 版迅雷在界面上,相比于 Windows 的客户端来说,已经很克制了,但有些功能仍然对用户造成了干扰 ...