播放器逻辑

播放逻辑

songs拿到选中的id(字符串)

var songs = $("tbody tr td input[type='checkbox']:checked")

现在拿到了1,2,3,4,5字符串

var sids = ""; //"1,2,3,4,5,"

字符串无法传到后端,后端要想加载真实的id数据,需要处理字符串。

songs.each(function () { var sid = $(this).val(); sids = sids + sid+"," })

sids = sids + sid+","这行代码把字符串变成了"1,2,3,4,5,"的字符串格式

调用controller的play方法

window.open("/song/play?sids="+sids,"play");

处理字符串

定义数组,判断sids是不是空串

// 前端传递的是sids字符串,处理拿到sid的值 {"2","3","4","5"} String[] idsArr = null; if(sids != null && !"".equals(sids)){ idsArr = sids.split(regex); }

idsArr = sids.split(regex);切割字符串,数组变成了{"1","2","3","4","5"}

请求对象HTTP拿到cookies,

Cookie[] cookies = request.getCookies();

定义cookieIds,这个一定和数组有关系

String cookieIds = null;

创建数组idsArrCookie

String[] idsArrCookie = null;

遍历cookies,拿到每一个cookie,cookie里存着一个playIds

if (cookies != null) { for (Cookie cookie : cookies) { // 每一个cookie的名称 String cookieName = cookie.getName(); // 配置是个长长的cookie if ("playIds".equals(cookieName)) { cookieIds = cookie.getValue(); // 解码 cookieIds = URLDecoder.decode(cookieIds, "UTF-8"); } } }

第一次来playIds是没有值的,所以cookiesname就匹配不上,匹配不上就走外边的,通过逗号切割,切割完后放到cookIds

// 获取到cookie的值后判断是否为空 不为空 解析 拿到对应的id {1,2} if(cookieIds != null){ idsArrCookie = cookieIds.split(","); }

后面的有些乱,这里用debug从最开始来讲。

复数框选中1,2,3,点击播放

创建数组,拿到("1","2","3")

String[] idsArr = null;

不是空,所以切割,切割完后idsArr变成{"1","2","3"}

if (sids != null && !"".equals(sids)) { idsArr = sids.split(","); }

拿到cookies

Cookie[] cookies = request.getCookies();

创建cookieids

String cookieIds = null;

创建idsArrCookie,这是cookieIds的承载数组

String[] idsArrCookie = null;

如果cookies不是null,就遍历找playerids,因为是第一次进,所以肯定找不到,找不到就退出去

if (cookies != null) { for (Cookie cookie : cookies) { // 每一个cookie的名称 String cookieName = cookie.getName(); // 配置是个长长的cookie if ("playIds".equals(cookieName)) { cookieIds = cookie.getValue(); // 解码 cookieIds = URLDecoder.decode(cookieIds, "UTF-8"); } } }

if (cookieIds != null) { idsArrCookie = cookieIds.split(","); }

退出后到这里,直接把1,2,3变成集合

List<Integer> list = new ArrayList<>();

这里肯定是null,不是的话也不会退出来

cookieIds = "";

接下来判断数组是否为null,肯定不是null,因为有1,2,3。接下来把1,2,3放进集合,并给cookieIds赋值1,2,3

if (idsArr != null) { // 遍历数组 将数组中的字符串的id值转换成integer的值 放入到集合中去 for (String s : idsArr) { list.add(new Integer(s)); cookieIds = cookieIds + s + ";"; // "1,2,3,4,5" } }

接下来判断idsArrCookie是否为null,这里肯定是null,因为第一次来,前面的代码String[] idsArrCookie = null;设置为了null,这里就不走里面的循环

if (idsArrCookie != null && !"".equals(idsArrCookie)) {

不走循环直接走下面代码

带着1,2,3直接去查

List<Song> songs = songService.selectSongBySids(list);

查到3首歌

cookieIds = URLEncoder.encode(cookieIds, "UTF-8");

cookieIds绑定1,2,3

Cookie cookie = new Cookie("playids", cookieIds);

设置路径,时效,并且返回去了

// cookie的访问路径 cookie.setPath("/"); // cookie的有效时间 cookie.setMaxAge(60 * 60 * 60 * 24 * 30); response.addCookie(cookie);

返回给页面

// model.addAttribute("songs", songs); return "player";

相关推荐
YXWik61 分钟前
Claude Code
java
小旭95272 分钟前
分布式事务 Seata 详解 + 链路追踪 SkyWalking 实战
java·分布式·后端·信息可视化·skywalking
曹牧3 分钟前
Spring:@RequestMapping 注解匹配顺序
java·后端·spring
云烟成雨TD6 分钟前
Spring AI Alibaba 1.x 系列【44】多智能体 - 混合模式、监督者(SupervisorAgent)、自定义模式
java·人工智能·spring
_日拱一卒14 分钟前
LeetCode:23合并K个升序链表
java·数据结构·算法·leetcode·链表·职场和发展
cany100015 分钟前
C++ -- 泛型编程
java·开发语言·c++
lee_curry16 分钟前
第三章 jvm中的对象和执行引擎
java·jvm·执行引擎
格林威17 分钟前
面阵相机 vs 线阵相机:堡盟与海康相机选型差异全解析 附C++ 实战演示
开发语言·c++·人工智能·数码相机·计算机视觉·视觉检测·工业相机
wang090718 分钟前
Linux性能优化之文件系统基础介绍
java·linux·性能优化
迷藏49426 分钟前
# 发散创新:用Locust实现高并发场景下的精准压力测试与性能调优实战在现代微服务架构中,**接口稳定性与响应速度**已成为衡量
java·python·微服务·架构·压力测试