播放器逻辑

播放逻辑

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

相关推荐
lpfasd1231 小时前
Markdown 导出 Word 文档技术方案
开发语言·c#·word
busideyang1 小时前
MATLAB vs Rust在嵌入式领域的角色定位
开发语言·matlab·rust
ghie90901 小时前
蚁群全局最优算法:原理、改进与MATLAB实现
开发语言·算法·matlab
’长谷深风‘2 小时前
线程函数接口和属性
c语言·开发语言·线程·进程·软件编程
wangluoqi2 小时前
c++ 图论-强连通分量 小总结
开发语言·c++
三无少女指南2 小时前
Spring Boot项目中Maven编译参数source、target与release的区别及配置实践
java·spring boot·maven
CHU7290352 小时前
货运物流APP前端交互创新:以用户为中心重构运输服务全链路
java·前端·小程序·重构
啊哈哈哈哈哈啊哈哈2 小时前
AOP笔记
java·开发语言