播放器逻辑

播放逻辑

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";

相关推荐
亦暖筑序5 分钟前
Message 四分天下:Spring AI 如何统一消息格式
java·人工智能
镜花水月linyi11 分钟前
JDK 8 → 17 → 21 → 25:一次性讲清四代版本的关键跃迁
java·后端
沐知全栈开发15 分钟前
《jEasyUI 格式化列》
开发语言
0xDevNull23 分钟前
JDK 25 新特性概览与实战教程
java·开发语言·后端
某人辛木26 分钟前
nodejs下载安装
开发语言·前端·javascript
Yiyi_Coding28 分钟前
BUG列表:如何定位线上 OOM ?
java·linux·bug
gelald28 分钟前
Spring - 循环依赖
java·后端·spring
凤山老林32 分钟前
Java 开发者零成本构建 RAG 知识库:Spring AI Alibaba + Ollama 搭建本地 RAG 知识库
java·人工智能·知识库·rag·spring ai
笨笨饿33 分钟前
34_数据结构_栈
c语言·开发语言·数据结构·人工智能·嵌入式硬件·算法
爱码驱动37 分钟前
文件操作和IO
java·开发语言·io·文件操作