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

相关文章

MySQL中实现多表查询的操作方法(配sql+实操图+案例巩固 通俗易懂版)

《MySQL中实现多表查询的操作方法(配sql+实操图+案例巩固通俗易懂版)》本文主要讲解了MySQL中的多表查询,包括子查询、笛卡尔积、自连接、多表查询的实现方法以及多列子查询等,通过实际例子和操... 目录复合查询1. 回顾查询基本操作group by 分组having1. 显示部门号为10的部门名,员

mysql关联查询速度慢的问题及解决

《mysql关联查询速度慢的问题及解决》:本文主要介绍mysql关联查询速度慢的问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql关联查询速度慢1. 记录原因1.1 在一次线上的服务中1.2 最终发现2. 解决方案3. 具体操作总结mysql

Java中数组转换为列表的两种实现方式(超简单)

《Java中数组转换为列表的两种实现方式(超简单)》本文介绍了在Java中将数组转换为列表的两种常见方法使用Arrays.asList和Java8的StreamAPI,Arrays.asList方法简... 目录1. 使用Java Collections框架(Arrays.asList)1.1 示例代码1.

python中列表list切分的实现

《python中列表list切分的实现》列表是Python中最常用的数据结构之一,经常需要对列表进行切分操作,本文主要介绍了python中列表list切分的实现,文中通过示例代码介绍的非常详细,对大家... 目录一、列表切片的基本用法1.1 基本切片操作1.2 切片的负索引1.3 切片的省略二、列表切分的高

web网络安全之跨站脚本攻击(XSS)详解

《web网络安全之跨站脚本攻击(XSS)详解》:本文主要介绍web网络安全之跨站脚本攻击(XSS)的相关资料,跨站脚本攻击XSS是一种常见的Web安全漏洞,攻击者通过注入恶意脚本诱使用户执行,可能... 目录前言XSS 的类型1. 存储型 XSS(Stored XSS)示例:危害:2. 反射型 XSS(Re

mysql线上查询之前要性能调优的技巧及示例

《mysql线上查询之前要性能调优的技巧及示例》文章介绍了查询优化的几种方法,包括使用索引、避免不必要的列和行、有效的JOIN策略、子查询和派生表的优化、查询提示和优化器提示等,这些方法可以帮助提高数... 目录避免不必要的列和行使用有效的JOIN策略使用子查询和派生表时要小心使用查询提示和优化器提示其他常

Python如何计算两个不同类型列表的相似度

《Python如何计算两个不同类型列表的相似度》在编程中,经常需要比较两个列表的相似度,尤其是当这两个列表包含不同类型的元素时,下面小编就来讲讲如何使用Python计算两个不同类型列表的相似度吧... 目录摘要引言数字类型相似度欧几里得距离曼哈顿距离字符串类型相似度Levenshtein距离Jaccard相

SQL 中多表查询的常见连接方式详解

《SQL中多表查询的常见连接方式详解》本文介绍SQL中多表查询的常见连接方式,包括内连接(INNERJOIN)、左连接(LEFTJOIN)、右连接(RIGHTJOIN)、全外连接(FULLOUTER... 目录一、连接类型图表(ASCII 形式)二、前置代码(创建示例表)三、连接方式代码示例1. 内连接(I

解决JavaWeb-file.isDirectory()遇到的坑问题

《解决JavaWeb-file.isDirectory()遇到的坑问题》JavaWeb开发中,使用`file.isDirectory()`判断路径是否为文件夹时,需要特别注意:该方法只能判断已存在的文... 目录Jahttp://www.chinasem.cnvaWeb-file.isDirectory()遇

JavaWeb-WebSocket浏览器服务器双向通信方式

《JavaWeb-WebSocket浏览器服务器双向通信方式》文章介绍了WebSocket协议的工作原理和应用场景,包括与HTTP的对比,接着,详细介绍了如何在Java中使用WebSocket,包括配... 目录一、概述二、入门2.1 POM依赖2.2 编写配置类2.3 编写WebSocket服务2.4 浏