@[toc]
一,前言
头痛的项目,架构的原因,现在实现功能非常的困难,想了很多的招,连续俩天从早上肝到半夜。目前实现的需求:1,活动需要手动定为历史活动,不要按照年份自动变为历史活动。【今天已经把这部分搞定了】2,同时多个活动开展上传这个活动二,头痛呀,绞尽脑汁想出了一种解决办法,最近正在写。
今天文章笔记,记录目前的进度。
二,需求解决思路逻辑
弊端:【后期有时间我尝试解决一下】
多开架构思路实现:
2021|包头市第二界文化旅游创意作品大赛|2
解释:
我根据dbm数据库的特性,琢磨了一套多开的开发思路。如下:我不断的累加他们,然后,如果需要到2022的标识比赛,我在后端处理字符串,遍历到下标的值,再把|分割开的文字目标提取处理,返回前端,传入index的id。实现进入不同的活动。至于作品,作品的显示,我写了一个目标match,赛选数据库的目标match,前端逐一的显示作品详情。
三,后端部分实现原理详解
上传大赛封面部分:
if value not in db_config["past_matchs"].decode():上述代码解释:如果是新开的赛事标识的话。执行上传到腾讯云cos存储桶的操作逻辑实现:前端上传,返回目标图片地址,传递给后端,后端处理存储到dbm数据库【累加的形式】。
if(picture==''): flash("请上传大赛的封面图片") return redirect(url_for('config_set')) else: db_config["match_url"] = db_config["match_url"].decode( )+f"|{request.form.get('picture')}"上文代码块解释:if(picture=='')防报错,返回设置页面。正常情况:累加cos服务器返回的图片url。累加形式!原理是|分割。效果如下:
四,前端请求存储桶,返回目标url
部分代码块如下:
<div class="fileUpload"> <!-- name="picture" --> <input id="picture" type="file" accept="image/*" /> <label id="plb" class="fileUpload__label is-placeholder" for="picture" data-placeholder="上传封面"></label> <span class="fileUpload__reset" aria-label="{{ _('Reset') }}"> <i class="material-icons" aria-hidden>clear</i> </span> <span class="fileUpload__button">选择图片</span> </div>部分代码如上:这是一个上传图片的模块前端代码。picture为id值,后端获取的关键字!效果图展示:
引入继承模板。
4.1,响应慢bug发现与解决
我发现响应极慢,查到了原因是:cos-js-sdk-v5.min.js的原因,我上网查了一下,发现他的作用是JavaScript上传是通过http协议直接传输数据到腾讯云对象存储里面。响应慢如何解决?我溯源发现,他在代码里是:
原理是线上引入,我尝试直接访问:得全局复制,新建js文件,全部粘贴进去。
如上操作。我们再来看一下,响应速度:响应无压力哈。这是一个小窍门!
五,后端读取目标dbm显示到主页
past_url = db_config["match_url"].decode().split('|')上述代码解释:已|为标识。把现在的字符串分割开,成为一个列表。
past_matchs = db_config["past_matchs"].decode().split(',') flag=1 for match_tuple in past_matchs: if not match_tuple: continue match_mark = match_tuple.split("|")[0] match_name1=match_tuple.split("|")[1] if(match==match_mark): break flag=flag+1上述代码块解释:我写了应该粗糙的算法。past_matchs有,为分隔符,转换为一个类别,我们遍历他,再把每一个遍历的列表对象,用|分割,获取到列表下标为0,是比赛的字符串。写一个判断,如果获取的获取到列表下标为0的比赛的字符串和目前比赛的标识相等的话,停止循环,否则flag加一。这样就拿到了目标的比赛图片封面url。
match_url=match_url,上述代码解释:把目标url传递个前端。
六,前端得到响应,显示比赛封面
<img style="width: 100%;max-height:350px" src="{{match_url}}" alt="">上述代码解释;得到响应,显示后端传来的目标图片url。
七,阶段性效果展示
活动一:活动二:
基本完成了大纲,后续,有很多的工作需要做,因为架构的原因bug非常的多。