Web在线聊天室(7) --- 查询频道列表

2024-02-01 19:08

本文主要是介绍Web在线聊天室(7) --- 查询频道列表,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • 查询频道列表接口
    • 接口设计文档
    • 编写前端ajax回调函数
    • 编写servlet实现doget方法
    • 编写操作数据库方法
    • 实现结果

查询频道列表接口

接口设计文档

请求:
GET /channel
响应:
HTTP/1.1 200 OK
[ok:truereason:xxxdata{channelId: 1,channelName: xxx}
]

编写前端ajax回调函数

	   getChannels() {$.ajax({type: "get",url: "channel",success: function(body, status) {if(body.ok) {app.channels = body.data;}else {alert(body.reason)}}})}

编写servlet实现doget方法

@WebServlet("/channel")@Overrideprotected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {req.setCharacterEncoding("UTF-8");resp.setCharacterEncoding("UTF-8");resp.setContentType("applicaation/json");Response response = new Response();try {//查询所有频道列表返回List<Channel> list = ChannelDao.query();response.setOk(true);response.setData(list);//ok:true,data[{},{}]}catch (Exception e) {e.printStackTrace();//目前,前端的实现,在后端报错,要返回空的list//改造前端为解析ok,reason//参考LoginServlet改造response.setReason(e.getMessage());//ok:false,reason:""}resp.getWriter().println(Util.serialize(response));}

编写操作数据库方法

    /*** 查询频道列表*/public static List<Channel> query() {Connection connection = null;PreparedStatement statement = null;ResultSet resultSet = null;//定义返回数据List<Channel> list = new ArrayList<>();try {//1. 获取数据库连接Connectionconnection = Util.getConnection();//2. 通过Connection+sql 创建操作命令对象StatementString sql = "select channelId,channelName from channel";statement = connection.prepareStatement(sql);//3. 执行sql:执行前替换占位符resultSet = statement.executeQuery();//如果是查询操作,处理结果集while (resultSet.next()) {//移动到下一行,有数据返回trueChannel channel = new Channel();//设置属性channel.setChannelId(resultSet.getInt("channelId"));channel.setChannelName(resultSet.getString("channelName"));list.add(channel);}return list;}catch (Exception e) {throw new AppException("查询频道列表出错", e);}finally {//释放资源Util.close(connection,statement,resultSet);}}

实现结果

我们登录到账号上,就可以看到频道列表了
在这里插入图片描述

这篇关于Web在线聊天室(7) --- 查询频道列表的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/668187

相关文章

Python列表去重的4种核心方法与实战指南详解

《Python列表去重的4种核心方法与实战指南详解》在Python开发中,处理列表数据时经常需要去除重复元素,本文将详细介绍4种最实用的列表去重方法,有需要的小伙伴可以根据自己的需要进行选择... 目录方法1:集合(set)去重法(最快速)方法2:顺序遍历法(保持顺序)方法3:副本删除法(原地修改)方法4:

JS+HTML实现在线图片水印添加工具

《JS+HTML实现在线图片水印添加工具》在社交媒体和内容创作日益频繁的今天,如何保护原创内容、展示品牌身份成了一个不得不面对的问题,本文将实现一个完全基于HTML+CSS构建的现代化图片水印在线工具... 目录概述功能亮点使用方法技术解析延伸思考运行效果项目源码下载总结概述在社交媒体和内容创作日益频繁的

SQL表间关联查询实例详解

《SQL表间关联查询实例详解》本文主要讲解SQL语句中常用的表间关联查询方式,包括:左连接(leftjoin)、右连接(rightjoin)、全连接(fulljoin)、内连接(innerjoin)、... 目录简介样例准备左外连接右外连接全外连接内连接交叉连接自然连接简介本文主要讲解SQL语句中常用的表

MySQL高级查询之JOIN、子查询、窗口函数实际案例

《MySQL高级查询之JOIN、子查询、窗口函数实际案例》:本文主要介绍MySQL高级查询之JOIN、子查询、窗口函数实际案例的相关资料,JOIN用于多表关联查询,子查询用于数据筛选和过滤,窗口函... 目录前言1. JOIN(连接查询)1.1 内连接(INNER JOIN)1.2 左连接(LEFT JOI

MySQL 中查询 VARCHAR 类型 JSON 数据的问题记录

《MySQL中查询VARCHAR类型JSON数据的问题记录》在数据库设计中,有时我们会将JSON数据存储在VARCHAR或TEXT类型字段中,本文将详细介绍如何在MySQL中有效查询存储为V... 目录一、问题背景二、mysql jsON 函数2.1 常用 JSON 函数三、查询示例3.1 基本查询3.2

MySQL中的交叉连接、自然连接和内连接查询详解

《MySQL中的交叉连接、自然连接和内连接查询详解》:本文主要介绍MySQL中的交叉连接、自然连接和内连接查询,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、引入二、交php叉连接(cross join)三、自然连接(naturalandroid join)四

mysql的基础语句和外键查询及其语句详解(推荐)

《mysql的基础语句和外键查询及其语句详解(推荐)》:本文主要介绍mysql的基础语句和外键查询及其语句详解(推荐),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋... 目录一、mysql 基础语句1. 数据库操作 创建数据库2. 表操作 创建表3. CRUD 操作二、外键

Mybatis 传参与排序模糊查询功能实现

《Mybatis传参与排序模糊查询功能实现》:本文主要介绍Mybatis传参与排序模糊查询功能实现,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、#{ }和${ }传参的区别二、排序三、like查询四、数据库连接池五、mysql 开发企业规范一、#{ }和${ }传参的

JSON Web Token在登陆中的使用过程

《JSONWebToken在登陆中的使用过程》:本文主要介绍JSONWebToken在登陆中的使用过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录JWT 介绍微服务架构中的 JWT 使用结合微服务网关的 JWT 验证1. 用户登录,生成 JWT2. 自定义过滤

一文教你如何将maven项目转成web项目

《一文教你如何将maven项目转成web项目》在软件开发过程中,有时我们需要将一个普通的Maven项目转换为Web项目,以便能够部署到Web容器中运行,本文将详细介绍如何通过简单的步骤完成这一转换过程... 目录准备工作步骤一:修改​​pom.XML​​1.1 添加​​packaging​​标签1.2 添加