首页 > 代码库 > android客户端向服务器端验证登陆方法的实现2

android客户端向服务器端验证登陆方法的实现2

一、在上一篇文章中,我只是提到了其中一种方法来实现登陆

大家可以参见:

http://www.apkbus.com/android-45004-1-1.html      android获取web服务器端session并验证登陆

http://blog.csdn.net/cainiao123hack/article/details/8255848   服务器端向Android客户端传值——登录实现

http://zhidao.baidu.com/link?url=8g9EWhyUkUgUr1dh3_tEmmJgBcVLVVVJLtDrk_hJBm_-3n-SSBSItPdo1kjlC8MbeWyaK_fhgISCJbwGF4wQIa

请问如何写一个java 服务器端的servlet,然后可以当客户端发出http请求的时候,可以接受请求,读取数据库

二、一些代码的讲解:

    什么是servlet:一个小的,具有平台无关性,没有图形用户界面的java程序,他可以在很多方面扩充web服务的功能。

HttpServlet 类  :

参考文献:http://blog.csdn.net/jay198746/article/details/4489571   

http://www.cnblogs.com/amboyna/archive/2007/09/18/897101.html    Java学习之Servlet-doGet()与doPost()

提供了一个处理 HTTP 协议的框架。
在这个类中的 service 方法支持例如 GET、POST 这样的标准的 HTTP 方法。这一支持
过程是通过分配他们到适当的方法(例如 doGet、doPost)来实现的。

doGet方法:被这个类的service方法调用,用来处理一个HTTP GET操作。这个操作允许客户端简单的从一个HTTP服务器获得资源。对这个方法的重载将自动支持HEAD方法。安全的方法。

doPost方法:被service方法调用,用来处理一个HTTP POST操作。这个操作包含请求的数据体,servlet应该按照此行事。此操作可能是负面的操作。

三、客户端与服务器端的数据传递

相对于客户端的post与get方法,其都有数据传递,都在request于response当中。我们通过ServiceInputStream与ServiceOutputStream类来实现数据的共享。

参考文献:    http://bbs.csdn.net/topics/370118463    servlet服务器端如何向客户端返回数据

                   1、客户端发出http请求,服务器端接受请求,进行响应,然后读取数据库。

                   2、在客户端:利用内置对象requst获取数据,并传至服务器端。

                    put 与 getparameter是一对  ; setAtribute与getAttibute是一对。

                   服务器端:我们除了用response返回数据外,也可以用request返回数据。将封装好的对象放到requets.session中,直接用它们的setAtributer  (“key”,"value");然后,在客户端:我们用request.getAttibute来获取数据。  

int i=10;
把数据放到Servlet请求的属性中
request.setAttribute("i",i);
转发到客户端
request.getRequestdispatcher("url").forward(request,response);
在转发到的页面用request.getAttribute(i)取出来..记得类型转换

                        在服务器端:利用内置对象response获取数据,并传至客户端。与之对应方法中的response。

                   eg: response.getOutStream();  PrintWrite pw = response.getPrintWrite();

                           pw.out(“你想要传到客户端的数据”);      

                                                response这个对象就是用来响应的呀!
                                                response.getOutputSteam().write("写数据");
                                                response.flushBuffer()这样就可以发往数据到客户端了呀!

当然,假如我们只想知道返回的标识,而不想要数据,那么我们通过标识码来判断

服务器端代码:

if (userlist != null) {
            resp.setStatus(200);
        } else {
            resp.sendError(345, "用户名密码不正确!");

写在了resp当中。

在客户端代码:

    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();
                    }

<style type="text/css"> .csharpcode, .csharpcode pre { font-size: small; color: black; font-family: consolas, "Courier New", courier, monospace; background-color: #ffffff; /*white-space: pre;*/ } .csharpcode pre { margin: 0em; } .csharpcode .rem { color: #008000; } .csharpcode .kwrd { color: #0000ff; } .csharpcode .str { color: #006080; } .csharpcode .op { color: #0000c0; } .csharpcode .preproc { color: #cc6633; } .csharpcode .asp { background-color: #ffff00; } .csharpcode .html { color: #800000; } .csharpcode .attr { color: #ff0000; } .csharpcode .alt { background-color: #f4f4f4; width: 100%; margin: 0em; } .csharpcode .lnum { color: #606060; }</style>

      根据我们传递过来的标识码的值(statusCode),就知道到底是进入到onSuccess还是onFailure方法中。然后,在这些方法中选择我们所要进行的操作。

      

四、mybatis当中resultMap等的作用:

参考文献:http://zhuyuehua.iteye.com/blog/1721715   

 <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>

<mapper></mapper>映射标签

<resultMap id =”与类名相关的id名” type =”类名”/>  id 与下面的select中的resultMap一一对应,type后面是一个类名。通过id找到此类。

下面全是 此类的一些属性名用<result property=””  column=””/>   最好是一一对应

其中:property为你自己建立的类当中的属性,column是你自己建立的数据库当中的字段名。

<select   id = “函数名”   xxxxxxxx    \>

paremeterType这个为selectUserlist函数的参数类型,假如只有一个参数,我们可以写string或int等。但假如有多个参数,需要封装在Map里面。

<!-- 查询, 1.输入用map传入多个参数 2.<where>语句, 智能添加where和and关键字 3.输出直接映射对象 -->

    <select id="findAll" resultMap="navigations" parameterType="map" >

        select * from s_navigation

        <where>

            <if test="portletid != null">

                portletid=#{portletid}

            </if>

            <if test="uuid != null">

                and uuid=#{uuid}

            </if>

            <if test="uuid != null and portletid != null">

                and isshow=1

            </if>

        </where>

    </select>
<style type="text/css"> .csharpcode, .csharpcode pre { font-size: small; color: black; font-family: consolas, "Courier New", courier, monospace; background-color: #ffffff; /*white-space: pre;*/ } .csharpcode pre { margin: 0em; } .csharpcode .rem { color: #008000; } .csharpcode .kwrd { color: #0000ff; } .csharpcode .str { color: #006080; } .csharpcode .op { color: #0000c0; } .csharpcode .preproc { color: #cc6633; } .csharpcode .asp { background-color: #ffff00; } .csharpcode .html { color: #800000; } .csharpcode .attr { color: #ff0000; } .csharpcode .alt { background-color: #f4f4f4; width: 100%; margin: 0em; } .csharpcode .lnum { color: #606060; }</style>