android客户端向服务器端验证登陆方法的实现1
遇到的问题:一个条件查询与多个条件查询,所用到的方式不一样
参考文档: http://www.oschina.net/question/1160609_133366 mybatis多条件查询的一个错误
解决方案如下:
利用序列号的方式解决多个参数的查询问题。对象与数据库关系的映射层。我们也可以用hashmap实现。
层次结构如下:

首先定义model层里面的Userlist类,这是和我们后台mysql里面的表是一一对应的,然后定义UserlistMapper类,这个类主要是用来封装一些个方法,比如说增删改查等。其实现通过UserlistMapper.xml来实现,这个里面主要涉及一些sql语句。
做完上面这些以后,我们就需要和客户端交互,所以定义SrvUserlist类,主要与客户端进行交互。里面有dopost与doget等方法。当然先是响应service()的方法,然后根据客户端的请求,选择不同的方法进行响应。比如说,客户端请求的是post方法,那么服务器端就需要执行dopost方法与之对应。
dao层代码:(Data access object)包含的数据的所有操作。数据访问层:
package zhuxuekui.data;
import java.util.List;
import org.apache.ibatis.annotations.Param;
import zhuxuekui.model.Userlist;
public interface UserlistMapper {
Userlist selectUserlist(@Param("username")String username,@Param("passward")String passward);
}
参见这篇帖子:http://zhuyuehua.iteye.com/blog/1721715
配置文件:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="zhuxuekui.data.UserlistMapper">
<resultMap id="userResultMap" type="Userlist">
<result property="username" column="username"></result>
<result property="passward" column="passward"></result>
</resultMap>
<select id="selectUserlist" parameterType="Map"
resultMap="userResultMap">
select * from userlist
where username = #{username} and passward = #{passward}
</select>
</mapper>
Model层:
package zhuxuekui.model;
public class Userlist {
public String username;
public String passward;
}
Service层:
package zhuxuekui.service;
import java.io.IOException;
import java.util.List;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.ibatis.builder.annotation.MapperAnnotationBuilder;
import org.apache.ibatis.session.SqlSession;
import zhuxuekui.data.UserlistMapper;
import zhuxuekui.model.Userlist;
public class SrvUserlist extends HttpServlet {
private static final long serialVersionUID = 1L;
@Override
protected void service(HttpServletRequest req, HttpServletResponse res)
throws ServletException, IOException {
res.getWriter().println("Hello World||||!");
super.service(req, res);
}
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse res)
throws ServletException, IOException {
// String resource = "/com/arthur/data/Configuration.xml";
// Reader reader;
// try {
// reader = Resources.getResourceAsReader(resource);
// Constants.SQL_FACTORY = new SqlSessionFactoryBuilder()
// .build(reader);
// } catch (Exception e) {
// e.printStackTrace();
// e.printStackTrace(res.getWriter());
// }
String username = req.getParameter("username");
String passward = req.getParameter("passward");
//
// System.out.println("账号: "+username);
// System.out.println("密码:"+passward);
SqlSession session = Constants.SQLFactory().openSession();
//UserlistMapper userMapper =session.getMapper(UserlistMapper.class);
// Userlist userlist = userMapper.selectUserlist(username);
//加载映射 ,与 userlistMapper挂钩 ,就是一条sql语句
UserlistMapper mapper = session.getMapper(UserlistMapper.class);
//从数据库当中选择一条对的语句,进行比对。返回一条记录
Userlist userlist = mapper.selectUserlist(username,passward);
if (userlist !=null) {
//res.getWriter().println("there is no user with name" + username);
String json = Constants.GSON.toJson(userlist);
res.getWriter().println(json);
}
else {
res.getWriter().println("there is new reader with name" + username);
}
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
this.doGet(req, resp);
//String userName = req.getParameter("username");
String username = req.getParameter("username");
String passward = req.getParameter("passward");
System.out.println("账号: "+username);
System.out.println("密码:"+passward);
SqlSession session = Constants.SQLFactory().openSession();
UserlistMapper mapper = session.getMapper(UserlistMapper.class);
Userlist userlist = mapper.selectUserlist(username,passward);
if (userlist != null) {
resp.setStatus(200);
} else {
resp.sendError(345, "用户名密码不正确!");
}
}
}
服务器端调试界面:

客户端代码:
package com.buu.play.aa;
import org.apache.http.Header;
import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.EditText;
import android.widget.LinearLayout;
import android.widget.LinearLayout.LayoutParams;
import android.widget.Toast;
import com.buu.play.BMapApiDemoMain;
import com.buu.play.DemoApplication;
import com.loopj.android.http.AsyncHttpClient;
import com.loopj.android.http.BaseJsonHttpResponseHandler;
import com.loopj.android.http.RequestParams;
public class LoginActivity extends Activity implements OnClickListener {
static final String TAG = "ahttp";
private EditText etName, etPsw;
private Button btnLogin;
AsyncHttpClient httpClient;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
httpClient = DemoApplication.instance().asyncHttpClient;
LinearLayout ll = new LinearLayout(this);
ll.setOrientation(LinearLayout.VERTICAL);
ll.setPadding(25, 25, 25, 25);
setContentView(ll);
etName = new EditText(this);
etName.setHint("用户名");
ll.addView(etName, LayoutParams.MATCH_PARENT, LayoutParams.WRAP_CONTENT);
etPsw = new EditText(this);
etPsw.setHint("密码");
ll.addView(etPsw, LayoutParams.MATCH_PARENT, LayoutParams.WRAP_CONTENT);
btnLogin = new Button(this);
btnLogin.setText("登 录");
btnLogin.setOnClickListener(this);
ll.addView(btnLogin, LayoutParams.MATCH_PARENT,
LayoutParams.WRAP_CONTENT);
}
@Override
public void onClick(View v) {
// Intent intent = new Intent(LoginActivity.this,
// BMapApiDemoMain.class);
// LoginActivity.this.startActivity(intent);
if (!isValid()) {
Toast.makeText(LoginActivity.this, "用户名密码没有填写", Toast.LENGTH_LONG)
.show();
// 用户名密码没有填写
return;
}
//
// TODO do request
RequestParams param = new RequestParams();
param.put("username", etName.getText().toString());
param.put("passward", etPsw.getText().toString());
httpClient.post("http://192.168.1.106:8080/login", param,
new BaseJsonHttpResponseHandler<Object>() {
@Override
public void onSuccess(int statusCode, Header[] headers,
String rawJsonResponse, Object response) {
Log.d(TAG, rawJsonResponse);
Intent intent = new Intent(LoginActivity.this,
BMapApiDemoMain.class);
LoginActivity.this.startActivity(intent);
finish();
}
@Override
public void onFailure(int statusCode, Header[] headers,
Throwable throwable, String rawJsonData,
Object errorResponse) {
// Intent intent = new Intent(LoginActivity.this,
// BMapApiDemoMain.class);
// LoginActivity.this.startActivity(intent);
// finish();
Toast.makeText(LoginActivity.this, "用户名密码错误",
Toast.LENGTH_LONG).show();
}
@Override
protected Object parseResponse(String rawJsonData,
boolean isFailure) throws Throwable {
Log.d(TAG, rawJsonData);
return rawJsonData;
}
});
}
private boolean isValid() {
return etName.getText().length() > 0 && etPsw.getText().length() > 0;
}
}
改进:1)客户端:没有做注册,只做了一个登陆。后期可能需要优化。
2)服务器端:只尝试了序列号的方法,后期尝试hashmap方法。
android客户端向服务器端验证登陆方法的实现1的更多相关文章
- android客户端向服务器端验证登陆方法的实现2
一.在上一篇文章中,我只是提到了其中一种方法来实现登陆 大家可以参见: http://www.apkbus.com/android-45004-1-1.html android获取web服务 ...
- Android客户端和服务器端数据交互
网上有很多例子来演示Android客户端和服务器端数据如何实现交互不过这些例子大多比较繁杂,对于初学者来说这是不利的,现在介绍几种代码简单.逻辑清晰的交互例子,本篇博客介绍第四种: 一.服务器端: 代 ...
- android客户端从服务器端获取json数据并解析的实现代码
今天总结一下android客户端从服务器端获取json数据的实现代码,需要的朋友可以参考下 首先客户端从服务器端获取json数据 1.利用HttpUrlConnection /** * 从指定的U ...
- (转)android客户端从服务器端获取json数据并解析的实现代码
今天总结一下android客户端从服务器端获取json数据的实现代码,需要的朋友可以参考下 首先客户端从服务器端获取json数据 1.利用HttpUrlConnection 复制代码 ...
- android客户端从服务器端获取json数据并解析的实现代码(重要)
首先客户端从服务器端获取json数据 1.利用HttpUrlConnection /** * 从指定的URL中获取数组 * @param urlPath * @return * @throws Exc ...
- Android客户端与服务器端通过DES加密认证
转载地址:http://blog.csdn.net/spring21st/article/details/6730283 由于Android应用没有像web开发中的session机制,所以采用PHPS ...
- Android客户端向服务器端发送数据的流程(1)
原理: android客户端通过使用org.apache.http.impl.client.DefaultHttpClient类来发送数据; 方法介绍: HttpClient是android中提供的一 ...
- 数据加密,android客户端和服务器端可共用
安卓中,不管是内网还是外网,数据的传输首要考虑就是安全问题,尤其是用户信息,以及各种密码等敏感信息. 所以说,对数据的加密是很有必要的,尤其是当下物联网蓬勃发展的今天,数据安全尤为重要. 数据加密的方 ...
- app开发历程————Android程序解析服务器端的JSON格式数据,显示在界面上
上一篇文章写的是服务器端利用Servlet 返回JSON字符串,本文主要是利用android客户端访问服务器端链接,解析JSON格式数据,放到相应的位置上. 首先,android程序的布局文件main ...
随机推荐
- 12章 应用spary制作高级网页组件
比较复杂的用户界面,tab面板 伸缩面板和折叠面板等组件. tab面板和菜单实际上分为两种 一种是切换各个tab页中的内容时并不刷新浏览器窗口,仅仅是被隐藏起来了 利用ja ...
- 【JavaScript】关于 setInterval() 调用函数方法的一次实验
实验主题: setInterval() 方法是 JS 中比较常用的一个方法.setInterval() 方法可以按照指定的周期 ( 毫秒 ) 来调用函数方法或计算表达式. setInterval() ...
- 【LeetCode】Binary Tree Preorder Traversal(二叉树的前序遍历)
这道题是LeetCode里的第144道题. 题目要求: 给定一个二叉树,返回它的 前序 遍历. 示例: 输入: [1,null,2,3] 1 \ 2 / 3 输出: [1,2,3] 进阶: 递归算法很 ...
- ibatis 动态SQL
直接使用JDBC一个非常普遍的问题就是动态SQL.使用参数值.参数本身和数据列都是动态SQL,通常是非常困难的.典型的解决办法就是用上一堆的IF-ELSE条件语句和一连串的字符串连接.对于这个问题,I ...
- 利用hibernate与struts框架制作简单注册界面
一:配置hibernate 1.导包 hibernate包和jdbc连接mysql数据库的包 2.实用工具生成hibernate配置文件和映射文件 3.做好hibernateUtil生成session ...
- oracle查询包含大小写的数据
查询包含小写的所有数据: select oper_no from info_oper where regexp_like(oper_no,'[[:lower:]]'); select oper_no ...
- 【Luogu】P2536病毒检测(Trie上DP)
题目链接 这道题我写了个01DP,f[i][j]表示跑到Trie上第i个节点,匹配到字符串第j位行不行 然后重点在*号无限匹配怎么处理 经过一番脑洞我们可以发现*号无限匹配可以拆成两种情况: 1:匹配 ...
- C# 时间与时间戳互转 13位|13位時間戳与日期换转
这里直接上代码 懂C# 的程序猿 一看便知道如何使用的... /// <summary> /// 将Unix时间戳转换为DateTime类型时间 /// </summary> ...
- 【基础操作】2-sat
$2-sat$ 是一个很不怎么考的内容($NOI2017$ 除外) 例题
- Java面试题之多线程同步和互斥有几种实现方法,都是什么?
线程同步是指线程之间所具有的一种制约关系,一个线程的执行依赖另外一个线程的消息,当它没有得到另一个线程的消息时应等待,直到消息到达时才被唤醒. 线程互斥是指对于共享的进程系统资源,每个线程访问时的排他 ...