播放器逻辑

播放逻辑

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

相关推荐
美好的事情能不能发生在我身上4 小时前
Hot100中的:贪心专题
java·数据结构·算法
myloveasuka4 小时前
Java与C++多态访问成员变量/方法 对比
java·开发语言·c++
2301_821700535 小时前
C++编译期多态实现
开发语言·c++·算法
Andya_net5 小时前
Spring | @EventListener事件机制深度解析
java·后端·spring
奥地利落榜美术生灬5 小时前
c++ 锁相关(mutex 等)
开发语言·c++
xixihaha13245 小时前
C++与FPGA协同设计
开发语言·c++·算法
lang201509285 小时前
18 Byte Buddy 进阶指南:解锁 `@Pipe` 注解,实现灵活的方法转发
java·byte buddy
重庆小透明5 小时前
【java基础篇】详解BigDecimal
java·开发语言
ID_180079054735 小时前
模拟1688商品详情的Python API实现,返回符合风格的JSON数据
开发语言·python·json
小小怪7505 小时前
C++中的函数式编程
开发语言·c++·算法