Android论坛项目展

目录

1.展示概述:

2.展示要点:

1.Android开发入门:

1.学习Android开发基础知识:

2.学习调试和解决问题:

3.参与开发社区和资源:

2.项目规划:

1.用户注册与登录:

2.点赞功能: 

3.收藏功能: 

等 

3.技术要点:

1.用户注册与登录(部分代码):

2.点赞功能(部分代码): 

3.收藏功能(部分代码): 

4.数据的获取与展示(部分代码):

4.交流与合作:

1.知识共享和经验交流:

2.学习和成长:

3.问题解决和协作开发:

5.成果展示:

3.总结与展望:


1.展示概述:


这门课程旨在通过实践项目的方式,帮助学生们学习和应用Android开发知识,并构建一个完整的Android论坛应用。通过这门课程,学生们将深入了解Android应用的开发流程和技术要点,并通过实际操作掌握开发工具和框架的使用,以及与其他开发者交流和合作的能力。

2.展示要点:

1.Android开发入门:

1.学习Android开发基础知识:

在掌握Java编程语言后,你可以学习Android开发的基础知识,包括Android组件、布局、资源管理、用户界面设计等内容。

2.学习调试和解决问题:

在开发过程中,你可能会遇到各种各样的问题。学习使用调试工具并查找解决方案是非常重要的。阅读官方的调试指南,了解常见的错误和解决方法。

3.参与开发社区和资源:

加入Android开发社区,与其他开发者共享经验和资源。参与开发者论坛、社交媒体组群和技术博客,获取最新的开发动态和技巧

2.项目规划:

1.用户注册与登录:

 

  • 需求:用户可以注册一个新账号,并使用该账号进行登录。
  • 实现思路:在应用中创建一个注册界面,要求用户填写必要的信息(如用户名、密码等)。将该信息保存到数据库中。在登录界面,用户输入正确的用户名和密码后,应用检查该信息是否与数据库中的匹配,允许用户登录。

2.点赞功能: 

 

  • 需求:用户可以对帖子进行点赞操作。
  • 实现思路:为每个帖子添加一个点赞的字段。当用户点击点赞按钮时,实现点赞功能

3.收藏功能: 

 

  • 需求:用户可以收藏自己感兴趣的帖子,以便稍后查看。
  • 实现思路:为用户创建一个收藏列表,用于保存他们收藏的帖子的ID。当用户点击收藏按钮时,应用将帖子ID添加到用户的收藏列表中,在个人账号或收藏页面上展示用户收藏的帖子列表,并允许用户查看详细内容

等 

3.技术要点:

1.用户注册与登录(部分代码):

package com.hnucm.lzzy.Model;

import com.hnucm.lzzy.Utils.JDBCUtils;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.HashMap;


public class UserDao {

    private static final String TAG = "mysql-party-UserDao";
    //Connection connection;
    public UserDao(){

    }

    //登录
    public int login(String userAccount, String userPassword){
        HashMap<String, Object> map = new HashMap<>();
        // 根据数据库名称,建立连接
        Connection connection = JDBCUtils.getConn();
        int msg = 0;
        try {
            // mysql简单的查询语句。这里是根据user表的account字段来查询某条记录
            String sql = "select * from user where account = ?";
            if (connection != null){// connection不为null表示与数据库建立了连接
                PreparedStatement ps = connection.prepareStatement(sql);
                if (ps != null){
                    //Log.e(TAG,"账号:" + userAccount);
                    //根据账号进行查询
                    ps.setString(1, userAccount);
                    // 执行sql查询语句并返回结果集
                    ResultSet rs = ps.executeQuery();
                    int count = rs.getMetaData().getColumnCount();
                    //将查到的内容储存在map里
                    while (rs.next()){
                        // 注意:下标是从1开始的
                        for (int i = 1;i <= count;i++){
                            String field = rs.getMetaData().getColumnName(i);
                            map.put(field, rs.getString(field));
                        }
                    }
                    connection.close();
                    ps.close();
                    if (map.size()!=0){
                        StringBuilder s = new StringBuilder();
                        //寻找密码是否匹配
                        for (String key : map.keySet()){
                            if(key.equals("password")){
                                if(userPassword.equals(map.get(key))){
                                    msg = 1;            //密码正确
                                }
                                break;
                            }
                        }
                    }
                }
            }
        }catch (Exception e){
            e.printStackTrace();
            //Log.d(TAG, "异常login:" + e.getMessage());
        }
        return msg;
    }


    /**
     * function: 注册
     * */
    public boolean register(String account,String password,String Username){
        HashMap<String, Object> map = new HashMap<>();
        // 根据数据库名称,建立连接
        Connection connection = JDBCUtils.getConn();
        try {
            String sql = "insert into user(account,password,username) values (?,?,?)";
            if (connection != null){// connection不为null表示与数据库建立了连接
                PreparedStatement ps = connection.prepareStatement(sql);
                if (ps != null){

                    //将数据插入数据库
                    ps.setString(1,account);
                    ps.setString(2,password);
                    ps.setString(3,Username);
                    // 执行sql查询语句并返回结果集
                    int rs = ps.executeUpdate();
                    if(rs>0)
                        return true;
                    else
                        return false;
                }else {
                    return  false;
                }
            }else {
                return  false;
            }
        }catch (Exception e){
            e.printStackTrace();
            //Log.e(TAG, "异常register:" + e.getMessage());
            return false;
        }

    }

    public boolean updatePsw(String account,String password){
        // 根据数据库名称,建立连接
        Connection connection = JDBCUtils.getConn();
        try {
            String sql = "update user set password = ? where account = ?";
            if (connection != null){// connection不为null表示与数据库建立了连接
                PreparedStatement ps = connection.prepareStatement(sql);
                if (ps != null){

                    //将数据插入数据库
                    ps.setString(2,account);
                    ps.setString(1,password);
                    // 执行sql查询语句并返回结果集
                    int rs = ps.executeUpdate();
                    if(rs>0)
                        return true;
                    else
                        return false;
                }else {
                    return  false;
                }
            }else {
                return  false;
            }
        }catch (Exception e){
            e.printStackTrace();
            //Log.e(TAG, "异常register:" + e.getMessage());
            return false;
        }

    }

    /**
     * function: 根据账号进行查找该用户
     * */
    public User findMessage(String userAccount){
       Connection connection = JDBCUtils.getConn();
        User user = new User();
        HashMap<String, String> map = new HashMap<>();
        try {
            String sql = "select * from user where account = ?";
            if (connection != null){// connection不为null表示与数据库建立了连接
                PreparedStatement ps = connection.prepareStatement(sql);
                if (ps != null) {
                    ps.setString(1, userAccount);
                    ResultSet rs = ps.executeQuery(sql);
//                    while (rs.next()) {
//                        String username = rs.getString("username");
//                        String phone = rs.getString("phone");
//                        String email = rs.getString("email");
//                        String sign = rs.getString("sign");
//                        String birthday = rs.getString("birthday");
//                        String place = rs.getString("place");
//                        String sex = rs.getString("sex");
//                        //user = new User(phone,email,sign,username,birthday,place,sex);
//                        user.setUsername(username);
//                        user.setPhone(phone);
//                        user.setEmail(email);
//                        user.setSign(sign);
//                        user.setBirthday(birthday);
//                        user.setPlace(place);
//                        user.setSex(sex);
//                    }
                    int count = rs.getMetaData().getColumnCount();
                    //将查到的内容储存在map里
                    while (rs.next()){
                        // 注意:下标是从1开始的
                        for (int i = 1;i <= count;i++){
                            String field = rs.getMetaData().getColumnName(i);
                            map.put(field, rs.getString(field));
                        }
                    }
                    connection.close();
                    ps.close();
                    if (map.size()!=0){
                        StringBuilder s = new StringBuilder();
                        //寻找密码是否匹配
                        for (String key : map.keySet()){
                            if(key.equals("username"))user.setUsername((String)map.get(key));
                            else if(key.equals("phone"))user.setPhone((String)map.get(key));
                            else if(key.equals("email"))user.setEmail((String)map.get(key));
                            else if(key.equals("sign"))user.setSign((String)map.get(key));
                            else if(key.equals("birthday"))user.setBirthday((String)map.get(key));
                            else if(key.equals("place"))user.setPlace((String)map.get(key));
                            else if(key.equals("sex"))user.setSex((String)map.get(key));
                        }
                    }
                }
            }
        }catch (Exception e){
            e.printStackTrace();
            //Log.d(TAG, "异常findUser:" + e.getMessage());
            return null;
        }
        return user;
    }

    /**
     * function: 根据账号进行查找该用户是否存在
     * */
    public boolean findUser(String userAccount) {

        // 根据数据库名称,建立连接
       Connection connection = JDBCUtils.getConn();
        try {
            String sql = "select * from user where account = ?";
            if (connection != null){// connection不为null表示与数据库建立了连接
                PreparedStatement ps = connection.prepareStatement(sql);
                if (ps != null) {
                    ps.setString(1, userAccount);
                    ResultSet rs = ps.executeQuery();
                    if(rs.next()) {
                        return true;
                    }else {
                        return false;
                    }
                }
            }
        }catch (Exception e){
            e.printStackTrace();
            //Log.d(TAG, "异常findUser:" + e.getMessage());
        }
        return false;
    }

    public void updateMessage(String account, String username, String phone, String email, String sign, String
                                 birthday, String sex, String place){
        HashMap<String, Object> map = new HashMap<>();
        // 根据数据库名称,建立连接
        Connection connection = JDBCUtils.getConn();
        try {
            String sql = "update user set username = ? , phone = ? , email = ? , sign = ? , birthday = ? , place = ? , sex = ? where account = ?";
            if (connection != null){// connection不为null表示与数据库建立了连接
                PreparedStatement ps = connection.prepareStatement(sql);
                if (ps != null){
                    //将数据插入数据库
                    ps.setString(1,username);
                    ps.setString(2,phone);
                    ps.setString(3,email);
                    ps.setString(4,sign);
                    ps.setString(5,birthday);
                    ps.setString(7,sex);
                    ps.setString(6,place);
                    ps.setString(8,account);
                    // 执行sql查询语句并返回结果集
                    int rs = ps.executeUpdate();
                    if(rs>0) {
                    }
                }else {
                }
            }else {
            }
        }catch (Exception e){
            e.printStackTrace();
            //Log.e(TAG, "异常register:" + e.getMessage());
        }

    }

}

2.点赞功能(部分代码): 

// 在布局文件中添加一个按钮(例如button_like)

// 在Activity或Fragment中找到该按钮,并为其设置点击监听器
Button likeButton = findViewById(R.id.button_like);
likeButton.setOnClickListener(new View.OnClickListener() {
    @Override
    public void onClick(View v) {
        // 在点击监听器中编写代码来处理点赞功能
        // 假设点赞操作已经在后台处理,并返回一个布尔值来表示点赞状态
        boolean hasLiked = performLikeAction();

        // 更新UI状态
        if (hasLiked) {
            likeButton.setBackground(getResources().getDrawable(R.drawable.ic_like_filled));
        } else {
            likeButton.setBackground(getResources().getDrawable(R.drawable.ic_like_empty));
        }
    }
});

// 点赞操作的处理方法
private boolean performLikeAction() {
    // 在这里执行点赞操作的相关逻辑
    // 例如发送点赞请求给服务器,更新数据库等
    // 返回一个布尔值来表示点赞状态
    // 这里只是一个示例,你需要根据你的应用需求来实现具体的点赞逻辑
    return isLiked; // 根据实际点赞状态返回
}

3.收藏功能(部分代码): 

// 在布局文件中添加一个按钮(例如button_favorite)

// 在Activity或Fragment中找到该按钮,并为其设置点击监听器
Button favoriteButton = findViewById(R.id.button_favorite);
favoriteButton.setOnClickListener(new View.OnClickListener() {
    @Override
    public void onClick(View v) {
        // 在点击监听器中编写代码来处理收藏功能
        // 假设收藏功能的状态已经在后台处理,并返回一个布尔值来表示收藏状态
        boolean isFavorite = performFavoriteAction();

        // 更新UI状态
        if (isFavorite) {
            favoriteButton.setBackground(getResources().getDrawable(R.drawable.ic_favorite_filled));
        } else {
            favoriteButton.setBackground(getResources().getDrawable(R.drawable.ic_favorite_empty));
        }
    }
});

// 收藏操作的处理方法
private boolean performFavoriteAction() {
    // 在这里执行收藏操作的相关逻辑
    // 例如将项目添加到收藏列表或数据库中
    // 返回一个布尔值来表示收藏状态
    // 这里只是一个示例,你需要根据你的应用需求来实现具体的收藏逻辑
    return isFavorite; // 根据实际收藏状态返回
}

4.数据的获取与展示(部分代码):

package com.hnucm.lzzy.Model;

import com.hnucm.lzzy.Utils.JDBCUtils;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.HashMap;


public class UserDao {

    private static final String TAG = "mysql-party-UserDao";
    //Connection connection;
    public UserDao(){

    }

    //登录
    public int login(String userAccount, String userPassword){
        HashMap<String, Object> map = new HashMap<>();
        // 根据数据库名称,建立连接
        Connection connection = JDBCUtils.getConn();
        int msg = 0;
        try {
            // mysql简单的查询语句。这里是根据user表的account字段来查询某条记录
            String sql = "select * from user where account = ?";
            if (connection != null){// connection不为null表示与数据库建立了连接
                PreparedStatement ps = connection.prepareStatement(sql);
                if (ps != null){
                    //Log.e(TAG,"账号:" + userAccount);
                    //根据账号进行查询
                    ps.setString(1, userAccount);
                    // 执行sql查询语句并返回结果集
                    ResultSet rs = ps.executeQuery();
                    int count = rs.getMetaData().getColumnCount();
                    //将查到的内容储存在map里
                    while (rs.next()){
                        // 注意:下标是从1开始的
                        for (int i = 1;i <= count;i++){
                            String field = rs.getMetaData().getColumnName(i);
                            map.put(field, rs.getString(field));
                        }
                    }
                    connection.close();
                    ps.close();
                    if (map.size()!=0){
                        StringBuilder s = new StringBuilder();
                        //寻找密码是否匹配
                        for (String key : map.keySet()){
                            if(key.equals("password")){
                                if(userPassword.equals(map.get(key))){
                                    msg = 1;            //密码正确
                                }
                                break;
                            }
                        }
                    }
                }
            }
        }catch (Exception e){
            e.printStackTrace();
            //Log.d(TAG, "异常login:" + e.getMessage());
        }
        return msg;
    }


    /**
     * function: 注册
     * */
    public boolean register(String account,String password,String Username){
        HashMap<String, Object> map = new HashMap<>();
        // 根据数据库名称,建立连接
        Connection connection = JDBCUtils.getConn();
        try {
            String sql = "insert into user(account,password,username) values (?,?,?)";
            if (connection != null){// connection不为null表示与数据库建立了连接
                PreparedStatement ps = connection.prepareStatement(sql);
                if (ps != null){

                    //将数据插入数据库
                    ps.setString(1,account);
                    ps.setString(2,password);
                    ps.setString(3,Username);
                    // 执行sql查询语句并返回结果集
                    int rs = ps.executeUpdate();
                    if(rs>0)
                        return true;
                    else
                        return false;
                }else {
                    return  false;
                }
            }else {
                return  false;
            }
        }catch (Exception e){
            e.printStackTrace();
            //Log.e(TAG, "异常register:" + e.getMessage());
            return false;
        }

    }

    public boolean updatePsw(String account,String password){
        // 根据数据库名称,建立连接
        Connection connection = JDBCUtils.getConn();
        try {
            String sql = "update user set password = ? where account = ?";
            if (connection != null){// connection不为null表示与数据库建立了连接
                PreparedStatement ps = connection.prepareStatement(sql);
                if (ps != null){

                    //将数据插入数据库
                    ps.setString(2,account);
                    ps.setString(1,password);
                    // 执行sql查询语句并返回结果集
                    int rs = ps.executeUpdate();
                    if(rs>0)
                        return true;
                    else
                        return false;
                }else {
                    return  false;
                }
            }else {
                return  false;
            }
        }catch (Exception e){
            e.printStackTrace();
            //Log.e(TAG, "异常register:" + e.getMessage());
            return false;
        }

    }

    /**
     * function: 根据账号进行查找该用户
     * */
    public User findMessage(String userAccount){
       Connection connection = JDBCUtils.getConn();
        User user = new User();
        HashMap<String, String> map = new HashMap<>();
        try {
            String sql = "select * from user where account = ?";
            if (connection != null){// connection不为null表示与数据库建立了连接
                PreparedStatement ps = connection.prepareStatement(sql);
                if (ps != null) {
                    ps.setString(1, userAccount);
                    ResultSet rs = ps.executeQuery(sql);
//                    while (rs.next()) {
//                        String username = rs.getString("username");
//                        String phone = rs.getString("phone");
//                        String email = rs.getString("email");
//                        String sign = rs.getString("sign");
//                        String birthday = rs.getString("birthday");
//                        String place = rs.getString("place");
//                        String sex = rs.getString("sex");
//                        //user = new User(phone,email,sign,username,birthday,place,sex);
//                        user.setUsername(username);
//                        user.setPhone(phone);
//                        user.setEmail(email);
//                        user.setSign(sign);
//                        user.setBirthday(birthday);
//                        user.setPlace(place);
//                        user.setSex(sex);
//                    }
                    int count = rs.getMetaData().getColumnCount();
                    //将查到的内容储存在map里
                    while (rs.next()){
                        // 注意:下标是从1开始的
                        for (int i = 1;i <= count;i++){
                            String field = rs.getMetaData().getColumnName(i);
                            map.put(field, rs.getString(field));
                        }
                    }
                    connection.close();
                    ps.close();
                    if (map.size()!=0){
                        StringBuilder s = new StringBuilder();
                        //寻找密码是否匹配
                        for (String key : map.keySet()){
                            if(key.equals("username"))user.setUsername((String)map.get(key));
                            else if(key.equals("phone"))user.setPhone((String)map.get(key));
                            else if(key.equals("email"))user.setEmail((String)map.get(key));
                            else if(key.equals("sign"))user.setSign((String)map.get(key));
                            else if(key.equals("birthday"))user.setBirthday((String)map.get(key));
                            else if(key.equals("place"))user.setPlace((String)map.get(key));
                            else if(key.equals("sex"))user.setSex((String)map.get(key));
                        }
                    }
                }
            }
        }catch (Exception e){
            e.printStackTrace();
            //Log.d(TAG, "异常findUser:" + e.getMessage());
            return null;
        }
        return user;
    }

    /**
     * function: 根据账号进行查找该用户是否存在
     * */
    public boolean findUser(String userAccount) {

        // 根据数据库名称,建立连接
       Connection connection = JDBCUtils.getConn();
        try {
            String sql = "select * from user where account = ?";
            if (connection != null){// connection不为null表示与数据库建立了连接
                PreparedStatement ps = connection.prepareStatement(sql);
                if (ps != null) {
                    ps.setString(1, userAccount);
                    ResultSet rs = ps.executeQuery();
                    if(rs.next()) {
                        return true;
                    }else {
                        return false;
                    }
                }
            }
        }catch (Exception e){
            e.printStackTrace();
            //Log.d(TAG, "异常findUser:" + e.getMessage());
        }
        return false;
    }

    public void updateMessage(String account, String username, String phone, String email, String sign, String
                                 birthday, String sex, String place){
        HashMap<String, Object> map = new HashMap<>();
        // 根据数据库名称,建立连接
        Connection connection = JDBCUtils.getConn();
        try {
            String sql = "update user set username = ? , phone = ? , email = ? , sign = ? , birthday = ? , place = ? , sex = ? where account = ?";
            if (connection != null){// connection不为null表示与数据库建立了连接
                PreparedStatement ps = connection.prepareStatement(sql);
                if (ps != null){
                    //将数据插入数据库
                    ps.setString(1,username);
                    ps.setString(2,phone);
                    ps.setString(3,email);
                    ps.setString(4,sign);
                    ps.setString(5,birthday);
                    ps.setString(7,sex);
                    ps.setString(6,place);
                    ps.setString(8,account);
                    // 执行sql查询语句并返回结果集
                    int rs = ps.executeUpdate();
                    if(rs>0) {
                    }
                }else {
                }
            }else {
            }
        }catch (Exception e){
            e.printStackTrace();
            //Log.e(TAG, "异常register:" + e.getMessage());
        }

    }

}

4.交流与合作:

在开发论坛过程中与其他开发者进行交流和合作是非常重要的,以下是一些解释其重要性和利用资源的方法:

1.知识共享和经验交流:

与其组内成员交流可以共同解决问题和获得有价值的建议。查看类似的文章可能已经面对过类似的挑战并找到了解决方案,他们的经验可以帮助你节省时间和精力。

2.学习和成长:

共同交流可以帮助我们学习新的技术和工具。他们可能会推荐一些有用的资源、教程或书籍,或分享他们的学习经历和成功案例。通过与其他组员合作,你可以扩展自己的知识和技能。

3.问题解决和协作开发:

在开发过程中,你可能会遇到一些复杂的问题,只有组员讨论和合作,才能找到更好的解决方案。他们可以提供新的视角和想法,帮助我们更好地理解问题。

5.成果展示:

3.总结与展望:

参与Android论坛项目可以让我们亲身体验项目开发的全过程。我们将面临需求分析、系统设计、编码实现、测试调试等各个阶段。通过实践项目,可以锻炼自己的开发技能,并提升解决问题的能力。,通过这样的一课一展,学生们将能够深入了解Android开发的实践过程,通过动手实践项目提升他们的技能和经验。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值