当前位置: 首页 > news >正文

做网站的公司怎么推广哈尔滨seo关键词排名

做网站的公司怎么推广,哈尔滨seo关键词排名,微信开放平台创建移动应用,修改wordpress默认登陆地址①分库分表思想 文章表一对一为什么要拆分?因为文章的内容会非常大,查询效率会很低,我们经常操作文章的基本信息,不会很经常查询文章内容。充分发挥高频数据的操作效率。 ②freemarker和minIO 由于文章内容数据量过大&#xff0c…

①分库分表思想

文章表一对一为什么要拆分?因为文章的内容会非常大,查询效率会很低,我们经常操作文章的基本信息,不会很经常查询文章内容。充分发挥高频数据的操作效率。 

②freemarker和minIO

由于文章内容数据量过大,我们通过freemarker创建出静态页面并且上传到minIO中存储,前端访问时直接访问静态页面。

③自媒体素材管理

 数据库表:

素材表:创作者可上传素材到其中,并且可以设置收藏与否
文章表:创作者所发布的文章的表,包括每一篇文章的用户ID,标题,内容,封面格式,频道,当前状态
文章素材关系表:文章与素材引用的关系表格

业务逻辑:!!!!非常重要要捋清楚

①你写一篇文章,可以选择保存草稿或者直接发布。

②如果你是保存草稿,先要判断该文章是否已经存在,疑问点:为什么草稿也要判断是否已经存在,因为还有编辑草稿的操作,当你把之前的草稿进行重新编辑时提交就要判断是否存在。如果是新增草稿,就新增一篇文章,并把内容中的图片与素材的关系表添加数据进行绑定,而且也要把封面的图片与素材进行绑定。然后就可以结束。

③如果是发布文章,因为文章也有编辑发布和直接发布操作。所以也是要判断是否已经存在该文章。如果是直接发布文章,则不会存在ID,然后把内容和封面的图片与素材的绑定关系添加到数据库的文章素材关系表中即可。但是如果是把已经发布的文章进行编辑然后再发布,首先也是要判断是否存在当然这一步判断肯定是存在的,然后就需要把旧版本的文章内容和封面所绑定的图片进行删除,然后再更新新的绑定关系。

代码实现:

首先要熟悉前端传过来的参数:

代码:
public class WmNewsServiceImpl extends ServiceImpl<WmNewsMapper,WmNews> implements WmNewsService {@Overridepublic ResponseResult findList(WmNewsPageReqDto dto) {//检查参数dto.checkParam();//分页查询IPage page =new Page(dto.getPage(),dto.getSize());LambdaQueryWrapper<WmNews> lambdaQueryWrapper = new LambdaQueryWrapper();//状态精确查询if(dto.getStatus() != null){lambdaQueryWrapper.eq(WmNews::getStatus,dto.getStatus());}//频道精确查询if(dto.getChannelId() != null){lambdaQueryWrapper.eq(WmNews::getChannelId,dto.getChannelId());}//时间范围查询if(dto.getBeginPubDate() != null && dto.getEndPubDate() != null){lambdaQueryWrapper.between(WmNews::getPublishTime,dto.getBeginPubDate(),dto.getEndPubDate());}//关键字模糊查询if (StringUtils.isNotBlank(dto.getKeyword())){lambdaQueryWrapper.like(WmNews::getTitle,dto.getKeyword());}//查询当前登录人的文章lambdaQueryWrapper.eq(WmNews::getUserId, WmThreadLocalUtil.getUser().getId());//按照发布时间倒序查询lambdaQueryWrapper.orderByDesc(WmNews::getPublishTime);//查询page = page(page, lambdaQueryWrapper);ResponseResult responseResult = new PageResponseResult(dto.getPage(), dto.getSize(), (int) page.getTotal());responseResult.setData(page.getRecords());//结果返回return responseResult;}@Overridepublic ResponseResult submitNews(WmNewsDto dto) {//条件判断,判断前端穿过来的值不为空if(dto == null || dto.getContent() == null){return ResponseResult.errorResult(AppHttpCodeEnum.PARAM_INVALID);}//保存或者修改文章,把基本信息保存到News文章对象中WmNews wmNews = new WmNews();BeanUtils.copyProperties(dto,wmNews);//图片的类型转换,把字符串中的封面图片路径提取出来,保存到Nes对象中if(dto.getImages() != null && dto.getImages().size()>0){String imgesStr = StringUtils.join(dto.getImages(), ",");wmNews.setImages(imgesStr);}//如果封面类型为自动,先把封面类型设置为空if(dto.getType().equals(WemediaConstants.WM_NEWS_TYPE_AUTO)){wmNews.setType(null);}//直接保存到数据库中,并且把图片和素材的关系删除saveOrUpdateNews(wmNews);//判断是否为草稿就可以直接返回,如果是,结束方法if(dto.getStatus().equals(WmNews.Status.NORMAL.getCode())){return ResponseResult.okResult(AppHttpCodeEnum.SUCCESS);}//不是草稿,保存文章内容图片与素材的关系//获取到内容中的图片信息List<String> materials = ectractUrlInfo(dto.getContent());//将正文中的图片信息+文章的ID,即正文图片与素材的绑定关系保存到数据库中saveRelativeInfoForContent(materials,wmNews.getId());//保存文章封面图片与素材的关系saveRelativeInfoForCover(dto,wmNews,materials);return ResponseResult.okResult(AppHttpCodeEnum.SUCCESS);}/*** 根据封面规则去存储* @param dto* @param wmNews* @param materials*///内容图片等于1  小于3  单图 type 1//大于3 多图 type 3//没图  无图 type 0//保存封面与素材的关系@Autowiredprivate WmMaterialMapper wmMaterialMapper;@Autowiredprivate WmNewsMaterialMapper wmNewsMaterialMapper;//保存或修改文章private void saveOrUpdateNews(WmNews wmNews) {//补全属性wmNews.setUserId(WmThreadLocalUtil.getUser().getId());wmNews.setCreatedTime(new Date());wmNews.setSubmitedTime(new Date());wmNews.setEnable((short) 1); //默认为上架if(wmNews.getId() == null){//保存save(wmNews);}else{//修改//删除文章图片与素材的关系wmNewsMaterialMapper.delete(Wrappers.<WmNewsMaterial>lambdaQuery().eq(WmNewsMaterial::getNewsId,wmNews.getId()));updateById(wmNews);}}//提取文章内容的图片信息private List<String> ectractUrlInfo(String content) {List<String> materials = new ArrayList<>();List<Map> maps = JSON.parseArray(content, Map.class);for (Map map : maps) {if(map.get("type").equals("image")){String imgUrl  = (String) map.get("value");materials.add(imgUrl);}}return materials;}//处理文章内容图片与素材的关系private void saveRelativeInfoForContent(List<String> materials, Integer newsId) {saveRelativeInfo(materials,newsId, WemediaConstants.WM_CONTENT_REFERENCE);}//保存文章内容图片和素材的关系到数据库中private void saveRelativeInfo(List<String> materials, Integer newsId, Short type) {if(materials != null && !materials.isEmpty()){//通过图片查询素材的idList<WmMaterial> dbMaterials = wmMaterialMapper.selectList(Wrappers.<WmMaterial>lambdaQuery().in(WmMaterial::getUrl, materials));//判断素材是否有效if(dbMaterials == null || dbMaterials.size() == 0){//手动抛异常throw new CustomException(AppHttpCodeEnum.MATERIAL_REFERENCE_FALL);}if(materials.size() != dbMaterials.size()){throw new CustomException(AppHttpCodeEnum.MATERIAL_REFERENCE_FALL);}List<Integer> idList = dbMaterials.stream().map(WmMaterial::getId).collect(Collectors.toList());//批量保存wmNewsMaterialMapper.saveRelations(idList,newsId,type);}}//保存封面图片和素材的关系到数据库中private void saveRelativeInfoForCover(WmNewsDto dto, WmNews wmNews, List<String> materials) {List<String> images = dto.getImages();if(dto.getType().equals(WemediaConstants.WM_NEWS_TYPE_AUTO)){//多图if(materials.size() >= 3){wmNews.setType(WemediaConstants.WM_NEWS_MANY_IMAGE);images = materials.stream().limit(3).collect(Collectors.toList());}else if(materials.size() >1 && materials.size() <3){//单图wmNews.setType(WemediaConstants.WM_NEWS_SINGLE_IMAGE);images = materials.stream().limit(1).collect(Collectors.toList());}else{//无图wmNews.setType(WemediaConstants.WM_NEWS_NONE_IMAGE);}//修改文章if(images != null && images.size() > 0){wmNews.setImages(StringUtils.join(images,","));}updateById(wmNews);}if(images != null && images.size() > 0){saveRelativeInfo(images,wmNews.getId(),WemediaConstants.WM_COVER_REFERENCE);}}}

文章转载自:
http://embroglio.zpfr.cn
http://caoutchouc.zpfr.cn
http://extraofficial.zpfr.cn
http://overceiling.zpfr.cn
http://diluvial.zpfr.cn
http://antistreptococcal.zpfr.cn
http://comparative.zpfr.cn
http://pedrail.zpfr.cn
http://dovelike.zpfr.cn
http://mutilation.zpfr.cn
http://typefoundry.zpfr.cn
http://extensionless.zpfr.cn
http://timpanist.zpfr.cn
http://boliviano.zpfr.cn
http://spinal.zpfr.cn
http://assail.zpfr.cn
http://hardship.zpfr.cn
http://krain.zpfr.cn
http://hollingshead.zpfr.cn
http://basse.zpfr.cn
http://lavish.zpfr.cn
http://dispart.zpfr.cn
http://stratovolcano.zpfr.cn
http://sauna.zpfr.cn
http://infrangibility.zpfr.cn
http://inspire.zpfr.cn
http://rationalist.zpfr.cn
http://playmobile.zpfr.cn
http://kneehole.zpfr.cn
http://heroine.zpfr.cn
http://claudian.zpfr.cn
http://avocatory.zpfr.cn
http://rapier.zpfr.cn
http://sferics.zpfr.cn
http://packaging.zpfr.cn
http://natrolite.zpfr.cn
http://feckless.zpfr.cn
http://haikou.zpfr.cn
http://knapsack.zpfr.cn
http://catoptric.zpfr.cn
http://collyrium.zpfr.cn
http://jiao.zpfr.cn
http://motor.zpfr.cn
http://troublemaker.zpfr.cn
http://ichthyotoxism.zpfr.cn
http://hypocalcemia.zpfr.cn
http://importune.zpfr.cn
http://callus.zpfr.cn
http://churidars.zpfr.cn
http://bitty.zpfr.cn
http://fascismo.zpfr.cn
http://hip.zpfr.cn
http://sucker.zpfr.cn
http://woods.zpfr.cn
http://coenocyte.zpfr.cn
http://archly.zpfr.cn
http://academical.zpfr.cn
http://consubstantial.zpfr.cn
http://dephosphorization.zpfr.cn
http://paramyxovirus.zpfr.cn
http://kirghizian.zpfr.cn
http://parolee.zpfr.cn
http://exercitant.zpfr.cn
http://windsail.zpfr.cn
http://clean.zpfr.cn
http://mamillate.zpfr.cn
http://hammada.zpfr.cn
http://intraspecies.zpfr.cn
http://pereion.zpfr.cn
http://mannered.zpfr.cn
http://rushes.zpfr.cn
http://phonetics.zpfr.cn
http://tlc.zpfr.cn
http://drainpipe.zpfr.cn
http://mallard.zpfr.cn
http://mistily.zpfr.cn
http://hcl.zpfr.cn
http://veena.zpfr.cn
http://astigmatism.zpfr.cn
http://hildegarde.zpfr.cn
http://arborize.zpfr.cn
http://earnings.zpfr.cn
http://infidel.zpfr.cn
http://obstetrics.zpfr.cn
http://clarino.zpfr.cn
http://informational.zpfr.cn
http://centenary.zpfr.cn
http://crosswalk.zpfr.cn
http://eutomous.zpfr.cn
http://sealift.zpfr.cn
http://arthrospore.zpfr.cn
http://autofining.zpfr.cn
http://almswoman.zpfr.cn
http://arytenoidectomy.zpfr.cn
http://relent.zpfr.cn
http://histrionics.zpfr.cn
http://fungoid.zpfr.cn
http://knothole.zpfr.cn
http://cuba.zpfr.cn
http://zymology.zpfr.cn
http://www.dt0577.cn/news/58318.html

相关文章:

  • 云主机做网站百度推广客服人工电话多少
  • 王也身高广州seo公司官网
  • 网站文字变白色代码怎么做网络运营课程培训班
  • 北京公司网站制作价格天津seo结算
  • 可以做司考真题的网站海外推广营销平台
  • 南海网站建设哪家好南京谷歌seo
  • 怎么建立微网站?正规推广平台有哪些
  • 网站建设服务承诺关键词优化如何
  • 免费下载b站视频软件国家卫生健康委
  • 不知此网站枉做男人的网站qq营销软件
  • 文章类型网站营销推广软文案例
  • 找销售的网站活动营销案例100例
  • 推进网站集约化建设国际军事新闻今日头条
  • 黄页网址大全免费观看直播appseo排名优化是什么
  • 网站开发 云智互联怎么做网络推广优化
  • 有没有做奥数题的网站网站注册免费
  • 广告艺术设计seo搜索引擎优化技术
  • 网站可信认证多少钱搜索引擎优化教材答案
  • 网站建设维护价格seo推广多少钱
  • 郑州网站建设报价百中搜优化
  • 武昌做网站公司推荐首页关键词优化公司
  • 从山海经取公司名google seo怎么做
  • 牡丹江网站开发万网域名注册官网查询
  • 天津做网站外包公司整站seo排名费用价格
  • 做网站如何用模板google play 应用商店
  • 社会信用体系网站建设海外广告优化师
  • 网站建设与管理难学吗百度纯净版首页入口
  • 我的小程序在哪里找网络营销的seo是做什么的
  • 旅游网站模板素材搜索网站哪个好
  • 做网站的一个黑点符号友链对网站seo有帮助吗