android 仿微信demo——注册功能实现(服务端)

编辑: admin 分类: Android 发布时间: 2021-11-29 来源:互联网
目录
  • 服务端注册功能实现
    • 创建项目
    • 创建web层和客户端完成数据交互
    • 创建service层处理业务逻辑功能
    • 创建dao层操作数据库
    • 通过JDBC工具类访问数据库
    • mysql中创建数据库和表
    • 测试
  • 总结

    服务端注册功能实现

    通过web层完成客户端和服务端的数据交互(接受数据,发送数据),service层完成业务逻辑(注册,登录),dao层操作数据库(要借助工具类)

    创建项目

    idea创建服务端项目

    在这里插入图片描述

    在这里插入图片描述

    在这里插入图片描述

    配置tomcat服务器

    在这里插入图片描述

    在这里插入图片描述

    启动项目测试服务器

    在这里插入图片描述

    在这里插入图片描述

    在这里插入图片描述

    创建web层和客户端完成数据交互

    创建Servlet Reigister.java

    在这里插入图片描述

    在这里插入图片描述

    Reigister.java

    package com.example.controller;
    import com.alibaba.fastjson.JSON;
    import com.alibaba.fastjson.JSONObject;
    import com.example.pojo.User;
    import com.example.service.UserService;
    import com.example.service.UserServiceImpl;
    import javax.servlet.*;
    import javax.servlet.http.*;
    import javax.servlet.annotation.*;
    import java.io.BufferedReader;
    import java.io.IOException;
    import java.io.InputStreamReader;
    import java.net.URLDecoder;
    @WebServlet(name = "Reiister", value = "/Reigister")
    public class Reigister extends HttpServlet {
        @Override
        protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
            doPost(request, response);
        }
        @Override
        protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
            /* 设置中文字符编码,防止乱码*/
            request.setCharacterEncoding("utf-8");
            response.setCharacterEncoding("UTF-8");
            //以json数据完成操作
            response.setContentType("application/json;charset=UTF-8");
            System.out.println(request.getContentType());// 得到客户端发送过来内容的类型,application/json;charset=UTF-8
            System.out.println(request.getRemoteAddr());// 得到客户端的ip地址,
            BufferedReader br = new BufferedReader(new InputStreamReader(// 使用字符流读取客户端发过来的数据
                    request.getInputStream()));
            String line = null;
            StringBuffer s = new StringBuffer();//StringBuffer String的区别,如果要对数据作频繁的修改,則用StringBuffer
            // 以一行的形式读取数据
            while ((line = br.readLine()) != null) {
                s.append(line);
            }
            // 关闭io流
            br.close();
            System.out.println(s.toString());
            //JSON:这是json解析包,idea是没有的,要我们自己导入
            User user = JSON.parseObject(s.toString(), User.class);//是用了发射机制來完成对象的封闭
            //以utf-8解码操作
            String number = URLDecoder.decode(user.getNumber(), "utf-8");
            String name = URLDecoder.decode(user.getName(), "utf-8");
            String phone = URLDecoder.decode(user.getPhone(), "utf-8");
            String password = URLDecoder.decode(user.getPassword(), "utf-8");
            System.out.println("用户名是:" + name + ", 密码;" + password);
            System.out.println(user);
            // 去数据库完成用户注册功能
            UserService us = new UserServiceImpl();
            //调用注册的方法
            int i = us.reigisterUser(number, name, phone, password);
            boolean rs = false;
            //判断是否注册成功
            if (i > 0) {
                System.out.println("注册成功");
                rs = true;
            }
            //将结果返回给客户端	,將结果构建成json数据返回給客戶端
            JSONObject rjson = new JSONObject();
            rjson.put("json", rs);
            response.getOutputStream().write(
                    rjson.toString().getBytes("UTF-8"));// 向客户端发送一个带有json对象内容的响应
        }
    }
    

    上面代码用到用户实体类User和json(对数据进行封装),后面我们会介绍如何创建和使用,其他的就不阐述了,代码都有注释

    在创建实体类之前,先创建一个包单独存放实体类,因为后面我们在完善功能的过程中会创建很多实体类,方便管理

    在这里插入图片描述

    在这里插入图片描述

    User.java

    package com.example.pojo;
    public class User {
        private int id;
        private String number;
        private String name;
        private String password;
        private String phone;
        private String remark;
        public int getId() {
            return id;
        }
        public void setId(int id) {
            this.id = id;
        }
        public String getNumber() {
            return number;
        }
        public void setNumber(String number) {
            this.number = number;
        }
        public String getName() {
            return name;
        }
        public void setName(String name) {
            this.name = name;
        }
        public String getPassword() {
            return password;
        }
        public void setPassword(String password) {
            this.password = password;
        }
        public String getPhone() {
            return phone;
        }
        public void setPhone(String phone) {
            this.phone = phone;
        }
        public String getRemark() {
            return remark;
        }
        public void setRemark(String remark) {
            this.remark = remark;
        }
        @Override
        public String toString() {
            return "User{" +
                    "id=" + id +
                    ", number='" + number + '\'' +
                    ", name='" + name + '\'' +
                    ", password='" + password + '\'' +
                    ", phone='" + phone + '\'' +
                    ", remark='" + remark + '\'' +
                    '}';
        }
    }
    

    在WEB-INF目录下创建lib资源库,把下载好的JSON包复制到lib目录下,并把jar包添加到类库

    在这里插入图片描述

    在这里插入图片描述

    在这里插入图片描述

    在这里插入图片描述

    创建service层处理业务逻辑功能

    微信的除了注册业务逻辑处理功能,还有后面的要完善的登录,以及微信消息,通讯录,聊天信息等等,所以我们要用到一种编程思想,面向接口编程思想。创建一个接口,然后可以在里面添加我们需要业务处理的抽象方法(目前只有登录),之后在接口的实现类重写接口方法执行具体的操作即可

    在上面创建Servlet Reigister.java文件中报红的地方按alt+enter键创建接口,并放到单独的包里

    在这里插入图片描述

    在这里插入图片描述

    创建接口的实现类

    在这里插入图片描述

    在这里插入图片描述

    在接口里写个注册的抽象方法

    在这里插入图片描述

    在实现类中重写接口方法

    在这里插入图片描述

    在这里插入图片描述

    在实现类UserServiceImpl.java中修改代码

    UserServiceImpl.java

    package com.example.service;
    public class UserServiceImpl implements UserService {
        UserDao ud = new UserDaoImpl();
        @Override
        public int reigisterUser(String number, String name, String phone, String password) {
            int i = ud.insertUser(number, name, phone, password);
            return i;
        }
    }
    

    创建dao层操作数据库

    方法和创建service层一样,文字就不叙述了,直接上图

    在这里插入图片描述

    在这里插入图片描述

    在这里插入图片描述

    在这里插入图片描述

    在这里插入图片描述

    在这里插入图片描述

    在这里插入图片描述

    在实现类UserDaoImpl.java中修改代码

    UserDaoImpl.java

    package com.example.dao;
    public class UserDaoImpl implements UserDao {
        @Override
        public int insertUser(String number, String name, String phone, String password) {
            String sql = "insert into user (number, name, phone, password, remark) values(?,?,?,?,?);";
            //i如果操作成功,就是操作成功的条数
            int i = JDBCUtil.executeUpdate(sql, number, name, phone, password, "1");
            System.out.println("数据库的条数:");
            return i;
        }
    }
    

    通过JDBC工具类访问数据库

    先创建包单独存放工具类,后再创建工具类JDBCUtil.java

    在这里插入图片描述

    JDBCUtil.java

    package com.example.util;
    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.PreparedStatement;
    import java.sql.ResultSet;
    import java.sql.SQLException;
    public class JDBCUtil {
        private static final String DRIVER = "com.mysql.jdbc.Driver";
        private static final String URL = "jdbc:mysql://127.0.0.1:3306/androiddb1?useUnicode=true&characterEncoding=utf-8";
        private static final String USER = "root";
        private static final String PASSWORD = "jin1687062650";
        private static Connection ct;
        private static PreparedStatement ps;
        private static ResultSet rs;
        static {
            // 1.加载驱动,只需要加载一次,所以放到静态代码块中
            try {
                Class.forName(DRIVER);
            } catch (ClassNotFoundException e) {
                e.printStackTrace();
            }
        }
        /**
         * 描述:封装一个方法可以获得连接,目的可以在其他地方之接调用
         */
        public static Connection getConnection() {
            try {
                ct = DriverManager.getConnection(URL, USER, PASSWORD);
            } catch (SQLException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
            return ct;
        }
        /**
         * 描述:封装一个方法可以完成查询操作
         *
         * @param sql 要查询的sql语句
         * @param obj 占位符的具体内容
         * @return ResultSet 将查询到的结果返回
         */
        public static ResultSet executeQuery(String sql, Object... obj) {
            // 1.得到连接
            ct = getConnection();
            // 2.创键发送对象
            try {
                ps = ct.prepareStatement(sql);
                // 处理占位符问题
                if (obj != null) {
                    for (int i = 0; i < obj.length; i++) {
                        ps.setObject(i + 1, obj[i]);
                    }
                }
                rs = ps.executeQuery();
            } catch (SQLException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
            return rs;
        }
        /**
         * 描述:封装一个方法可以完成DDL,DML操作
         *
         * @param sql 要操作的sql语句
         * @param obj 占位符
         * @return
         */
        public static int executeUpdate(String sql, Object... obj) {
            // 1.得到连接
            ct = getConnection();
            // 2.创键发送对象
            try {
                ps = ct.prepareStatement(sql);
                // 处理占位符问题
                if (obj != null) {
                    for (int i = 0; i < obj.length; i++) {
                        ps.setObject(i + 1, obj[i]);
                    }
                }
                int in = ps.executeUpdate();
                close(ct, ps, null);
                return in;
            } catch (SQLException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
            return 0;
        }
        /**
         * 描述:封装一个关闭资源的方法
         *
         * @param ct 连接对象
         * @param ps 发送sql语句对象
         * @param rs 返回值对象
         */
        public static void close(Connection ct, PreparedStatement ps, ResultSet rs) {
            if (rs != null) {
                try {
                    rs.close();
                } catch (SQLException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }
            }
            if (ps != null) {
                try {
                    ps.close();
                } catch (SQLException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }
            }
            if (ct != null) {
                try {
                    ct.close();
                } catch (SQLException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }
            }
        }
        // 给外部一个访问ct,和ps的方法
        public static Connection getCt() {
            return ct;
        }
        public static PreparedStatement getPs() {
            return ps;
        }
    }
    

    上面代码会用到mysql驱动包,下面给出使用方法

    在上面下载的jar包中有mysql的驱动包,把它复制到lib下,然后添加到类库即可,方法和json包的添加一样

    在这里插入图片描述

    mysql中创建数据库和表

    可以通过navicat可视化工具创建数据库和表(可以用自己的方法),下面给出我数据库结构

    在这里插入图片描述

    在这里插入图片描述

    测试

    在服务端JDBCUtil.java工具类修改数据库名和数据库密码为自己的

    在这里插入图片描述

    在客户端中把注册activity的请求服务器的方法里面的URL的ip地址修改成自己的ip地址

    在这里插入图片描述

    查看ip地址的方法

    win+R,输入cmd进入命令行,然后输入ipconfig

    在这里插入图片描述

    在这里插入图片描述

    启动服务端和客户端项目测试

    在这里插入图片描述

    在这里插入图片描述

    在这里插入图片描述

    此时mysql已成功写入数据

    在这里插入图片描述

    总结

    这篇关于微信demo的文章就到这里了,希望大家可以多多关注海外IDC网的更多精彩内容!

    【文章出处:美国cn2站群服务器 欢迎转载】