Bmob用户功能详解(一)

来源:互联网 发布:iphone4s连不上网络 编辑:程序博客网 时间:2024/06/05 09:46

在开发应用程序的时候,很多情况下我们需要进行用户注册、登录、修改密码等等一系列和用户相关的功能。那么要实现这些功能比较普遍的做法是,有一个服务器端,包括数据库设计、服务器部署、业务逻辑接口编写、服务端与客户端的联调等等许多繁琐的工作。

那么如果作为一个普通的个人开发者有没有比较简单的方法来快速实现这些功能呢?答案当然是可以的啦 :)下面我们就来看看怎么使用Bmob提供的服务来非常方便的实现这些功能。

在讲解前需要注意的一些地方,这里我只讲怎么使用BmobAndroidSDK实现用户登录、注册等功能操作,至于怎么在自己的项目中嵌入BmobAndroidSDK,可以去Bmob官方文档的快速入门中按照说明自行完成。

注册

首先我们创建一个简单的注册界面,主要包含三个界面元素,两个输入框(用户名、密码),一个按钮(注册)。界面如下:
这里写图片描述

在SignUpActivity中的代码如下:

<code class="hljs java has-numbering"><span class="hljs-javadoc">/** * 注册界面 */</span><span class="hljs-keyword">public</span> <span class="hljs-class"><span class="hljs-keyword">class</span> <span class="hljs-title">SignUpActivity</span> <span class="hljs-keyword">extends</span> <span class="hljs-title">AppCompatActivity</span> <span class="hljs-keyword">implements</span> <span class="hljs-title">View</span>.<span class="hljs-title">OnClickListener</span>{</span>    EditText etUsername,etPassword;    Button btnSignUp;    <span class="hljs-annotation">@Override</span>    <span class="hljs-keyword">protected</span> <span class="hljs-keyword">void</span> <span class="hljs-title">onCreate</span>(Bundle savedInstanceState) {        <span class="hljs-keyword">super</span>.onCreate(savedInstanceState);        setContentView(R.layout.activity_sign_up);        <span class="hljs-comment">// 获取界面中的相关View</span>        etUsername = (EditText) findViewById(R.id.editUserName);        etPassword = (EditText) findViewById(R.id.editPassword);        btnSignUp = (Button) findViewById(R.id.btnSignUp);        <span class="hljs-comment">// 设置登录按钮点击事件</span>        btnSignUp.setOnClickListener(<span class="hljs-keyword">this</span>);    }    <span class="hljs-annotation">@Override</span>    <span class="hljs-keyword">public</span> <span class="hljs-keyword">void</span> <span class="hljs-title">onClick</span>(View v) {        <span class="hljs-comment">// 获取用户输入的用户名和密码</span>        String username = etUsername.getText().toString();        String password = etPassword.getText().toString();        <span class="hljs-comment">// 非空验证</span>        <span class="hljs-keyword">if</span>(TextUtils.isEmpty(username) || TextUtils.isEmpty(password)){            Toast.makeText(<span class="hljs-keyword">this</span>, <span class="hljs-string">"用户名或密码不能为空"</span>, Toast.LENGTH_SHORT).show();            <span class="hljs-keyword">return</span>;        }        <span class="hljs-comment">// 使用BmobSDK提供的注册功能</span>        BmobUser user = <span class="hljs-keyword">new</span> BmobUser();        user.setUsername(username);        user.setPassword(password);        user.signUp(<span class="hljs-keyword">this</span>, <span class="hljs-keyword">new</span> SaveListener() {            <span class="hljs-annotation">@Override</span>            <span class="hljs-keyword">public</span> <span class="hljs-keyword">void</span> <span class="hljs-title">onSuccess</span>() {                Toast.makeText(SignUpActivity.<span class="hljs-keyword">this</span>, <span class="hljs-string">"注册成功"</span>, Toast.LENGTH_SHORT).show();            }            <span class="hljs-annotation">@Override</span>            <span class="hljs-keyword">public</span> <span class="hljs-keyword">void</span> <span class="hljs-title">onFailure</span>(<span class="hljs-keyword">int</span> i, String s) {                Toast.makeText(SignUpActivity.<span class="hljs-keyword">this</span>, <span class="hljs-string">"注册失败"</span>, Toast.LENGTH_SHORT).show();            }        });    }}</code>

注册的代码很简单,首先将用户输入的用户名和密码set到user对象中,然后调用signUp方法进行注册。在SaveListener回调监听中处理服务器返回的注册结果,onSuccess方法表示注册成功,onFailure方法表示注册失败,并且参数s表示失败原因。

这是在客户端的注册功能实现,事实上在Bmob后台的User表中会保存用户的注册信息,举例,如果我们注册一个用户,用户名为稻草人,密码为123456,当SaveListener回调触发了onSuccess方法后,可以在Bmob后台User表中看到一条用户信息存在,如下:
这里写图片描述

登录

完成了注册后,接下来说说用户登录。首先来设计一个简单的用户登录界面如下:
这里写图片描述

然后在LoginActivity中实现登录操作,代码如下:

<code class="hljs java has-numbering"><span class="hljs-javadoc">/** * 登录界面 */</span><span class="hljs-keyword">public</span> <span class="hljs-class"><span class="hljs-keyword">class</span> <span class="hljs-title">LoginActivity</span> <span class="hljs-keyword">extends</span> <span class="hljs-title">AppCompatActivity</span> <span class="hljs-keyword">implements</span> <span class="hljs-title">View</span>.<span class="hljs-title">OnClickListener</span>{</span>    EditText etUsername,etPassword;    Button btnLogin;    <span class="hljs-annotation">@Override</span>    <span class="hljs-keyword">protected</span> <span class="hljs-keyword">void</span> <span class="hljs-title">onCreate</span>(Bundle savedInstanceState) {        <span class="hljs-keyword">super</span>.onCreate(savedInstanceState);        setContentView(R.layout.activity_login);        <span class="hljs-comment">// 获取界面中的相关View</span>        etUsername = (EditText) findViewById(R.id.editUserName);        etPassword = (EditText) findViewById(R.id.editPassword);        btnLogin = (Button) findViewById(R.id.btnLogin);        <span class="hljs-comment">// 设置登录按钮点击事件</span>        btnLogin.setOnClickListener(<span class="hljs-keyword">this</span>);    }    <span class="hljs-annotation">@Override</span>    <span class="hljs-keyword">public</span> <span class="hljs-keyword">void</span> <span class="hljs-title">onClick</span>(View v) {        <span class="hljs-comment">// 获取用户输入的用户名和密码</span>        String username = etUsername.getText().toString();        String password = etPassword.getText().toString();        <span class="hljs-comment">// 非空验证</span>        <span class="hljs-keyword">if</span>(TextUtils.isEmpty(username) || TextUtils.isEmpty(password)){            Toast.makeText(<span class="hljs-keyword">this</span>, <span class="hljs-string">"用户名或密码不能为空"</span>, Toast.LENGTH_SHORT).show();            <span class="hljs-keyword">return</span>;        }        <span class="hljs-comment">// 使用BmobSDK提供的登录功能</span>        BmobUser user = <span class="hljs-keyword">new</span> BmobUser();        user.setUsername(username);        user.setPassword(password);        user.login(<span class="hljs-keyword">this</span>, <span class="hljs-keyword">new</span> SaveListener() {            <span class="hljs-annotation">@Override</span>            <span class="hljs-keyword">public</span> <span class="hljs-keyword">void</span> <span class="hljs-title">onSuccess</span>() {                Toast.makeText(LoginActivity.<span class="hljs-keyword">this</span>, <span class="hljs-string">"登录成功"</span>, Toast.LENGTH_SHORT).show();            }            <span class="hljs-annotation">@Override</span>            <span class="hljs-keyword">public</span> <span class="hljs-keyword">void</span> <span class="hljs-title">onFailure</span>(<span class="hljs-keyword">int</span> i, String s) {                Toast.makeText(LoginActivity.<span class="hljs-keyword">this</span>, <span class="hljs-string">"登录失败"</span>, Toast.LENGTH_SHORT).show();            }        });    }}</code>

可以看出和注册界面的代码差不多相同,区别只在于使用BmobSDK调用的方法不同,在这里是调用的BmobUser对象中的login方法来进行登录操作。

其实从以上的注册、登录界面中的代码可以看出,使用BmobSDK来实现用户的注册、登录操作是非常简单的,我们不需要关心任何后端的事情,以及在客户端可能需要关心的与服务器接口对应的网络请求操作等等。

总结

以上讲了使用BmobSDK中提供的BmobUser对象来实现注册、登录功能。这也是BmobSDK中用户模块最基本的实现,但是在实际的业务开发中可能还涉及到其他相对比较复杂的业务实现,比如:

  • 用户资料不仅仅只是包含用户名和密码,还会有用户头像、昵称、性别、年龄等等其他属性。
  • 使用手机号作为用户名注册时需要通过短信验证码验证。
  • 使用邮箱作为用户名注册时需要发送激活邮件给用户,用户点击激活链接来激活账号。
  • 更新用户信息
  • 修改密码
  • 退出登录
  • ……

后面我会继续深入的讲解怎么使用BmobSDK来实现这些比较复杂的业务功能,希望大家关注。


本文转载自:http://blog.csdn.net/ynwewrfjhh/article/details/50379879

0 0
原创粉丝点击