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

亚马逊站外deal网站重庆企业免费建站

亚马逊站外deal网站,重庆企业免费建站,一个链接打开是表白,做化妆品网站1、需求 对于Teach账号创建的数据,其他用户仅仅只有查询的权限,而不能修改和删除。并且部分接口只允许Teach账号访问 2、实现思路 在删除和修改时往往需要传递数据的id,进而可以通过id查询该数据是否由Teach账号创建。当然我们可以在每个删…

1、需求

对于Teach账号创建的数据,其他用户仅仅只有查询的权限,而不能修改和删除。并且部分接口只允许Teach账号访问

2、实现思路

在删除和修改时往往需要传递数据的id,进而可以通过id查询该数据是否由Teach账号创建。当然我们可以在每个删除和修改接口里面进行判断,但这样照成管控不够集中,并且不利于后续的修改。如果后续又要求对Admin账号创建的数据也做同样的管控,那需要修改的地方会很多。
因此可以通过Aop拦截删除、修改等接口,通过接口的参数中的查询id对应的数据是否由Teach账号创建。

3、实现Demo

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.core.annotation.Order;
import org.springframework.stereotype.Component;import javax.servlet.http.HttpServletRequest;
import java.util.*;
import java.util.function.BiConsumer;@Order(0)
@Aspect
@Component
public class TeachAccountCheckAop {private static final Logger logger = LoggerFactory.getLogger(TeachAccountCheckAop.class);@Autowiredprivate HttpServletRequest request;@Autowiredprivate UserInfoUtil userInfoUtil;@Autowiredprivate ExpInfoService expInfoService;@Autowiredprivate ExpManualService expManualService;@Autowiredprivate MaterialInfoService materialInfoService;@Autowiredprivate SandboxMgtService sandboxMgtService;/*** 存储每个接口对应的从接口参数中获取id的方式*/private Map<String, BiConsumer<Object, List<Long>>> classMap = new HashMap<>();/*** 存储仅仅运行Teach账号访问的接口*/private Set<String> onlyTeachApiMethodSet = new HashSet<>();{onlyTeachApiMethodSet.add("com.huawei.ebg.olblab.controller.ExpInfoController.exportExperiment");onlyTeachApiMethodSet.add("com.huawei.ebg.olblab.controller.ExpInfoController.importExperiment");/*** arg:接口的参数* list:用于存储从接口参数中提取的id*/classMap.put("com.huawei.ebg.olblab.controller.ExpInfoController.saveExpBaseInfo", (arg, list) -> {ExpBaseInfoDto param = (ExpBaseInfoDto) arg;if (Objects.nonNull(param.gettid())) {list.add(param.gettid());}});classMap.put("com.huawei.ebg.olblab.controller.ExpManualController.saveExpManualBaseInfo", (arg, list) -> {ExpManualBaseDto param = (ExpManualBaseDto) arg;if (Objects.nonNull(param.gettid())) {list.add(param.gettid());}});classMap.put("com.huawei.ebg.olblab.controller.ExpMaterialInfoController.updateExpMaterialInfo", (arg, list) -> {MaterialUpdateDto param = (MaterialUpdateDto) arg;if (Objects.nonNull(param.gettid())) {list.add(param.gettid());}});classMap.put("com.huawei.ebg.olblab.controller.SandboxMgtController.deleteSandbox", (arg, list) -> {SandboxTempDto.Delete param = (SandboxTempDto.Delete) arg;if (CollectionUtils.isNotEmpty(param.getSandboxTempIds())) {list.addAll(param.getSandboxTempIds());}});}@Before("execution(public * com.huawei.ebg.olblab.controller.ExpInfoController.saveExpBaseInfo(..))"+ "|| execution(public * com.huawei.ebg.olblab.controller.ExpManualController.saveExpManualBaseInfo(..))"+ "|| execution(public * com.huawei.ebg.olblab.controller.ExpMaterialInfoController.updateExpMaterialInfo(..))"+ "|| execution(public * com.huawei.ebg.olblab.controller.SandboxMgtController.deleteSandbox(..))")public void beforeApiCheck(JoinPoint joinPoint) {// 获取当前登录者账号,Teach账号直接结束String userAccount = userInfoUtil.getUserAccount(request);if (StringUtils.equals(userAccount, ImportAccount.TEACH)) {return;}// 获取切点的方法String proxyTargetClass = joinPoint.getSignature().getDeclaringTypeName();String proxyTargetMethod = proxyTargetClass + "." + joinPoint.getSignature().getName();// 检查接口是否仅Teach能访问if (onlyTeachApiMethodSet.contains(proxyTargetMethod)) {if (StringUtils.equals(userAccount, ImportAccount.CREAT)) {return;}throw new RuntimeException(ErrorCode.EDU81080); // 仅Teach能访问}// 从接口参数中获取idObject[] args = joinPoint.getArgs();BiConsumer<Object, List<Long>> consumer = classMap.get(proxyTargetMethod);List<Long> ids = new ArrayList<>();for (Object arg : args) {if (Objects.isNull(arg)) {continue;}consumer.accept(arg, ids);}if (CollectionUtils.isEmpty(ids)) {return;}// 不同controller的接口,调用不同的Service查询id对应的数据的创建人是否存在Teach账号创建的数据long count = 0L;if (StringUtils.equals(proxyTargetClass, ExpInfoController.class.getName())) {count = expInfoService.count(Wrappers.lambdaQuery(ExpInfoEntity.class).eq(ExpInfoEntity::getCreateBy, ImportAccount.TEACH).in(ExpInfoEntity::getType, ExpType.TYPE_0, ExpType.TYPE_1).in(ExpInfoEntity::gettid, ids));} else if (StringUtils.equals(proxyTargetClass, ExpManualController.class.getName())) {count = expManualService.count(Wrappers.lambdaQuery(ExpManualEntity.class).eq(ExpManualEntity::getCreateBy, ImportAccount.TEACH).in(ExpManualEntity::gettid, ids));} else if (StringUtils.equals(proxyTargetClass, ExpMaterialInfoController.class.getName())) {count = materialInfoService.count(Wrappers.lambdaQuery(MaterialInfoEntity.class).eq(MaterialInfoEntity::getCreateBy, ImportAccount.TEACH).in(MaterialInfoEntity::gettid, ids));} else if (StringUtils.equals(proxyTargetClass, SandboxMgtController.class.getName())) {count = sandboxMgtService.count(Wrappers.lambdaQuery(SandboxTempEntity.class).eq(SandboxTempEntity::getCreatedByName, ImportAccount.TEACH).in(SandboxTempEntity::getSandboxTempId, ids));}if (count > 0) {throw new RuntimeException(ErrorCode.EDU81080); // 仅Teach能访问}}
}

4、可优化点

切入点表达式,可以改为自定义注解

http://www.dtcms.com/wzjs/147794.html

相关文章:

  • 清远做网站哪家好深圳seo招聘
  • 重庆在线官网百度seo技术
  • 网站建设流程有哪些百度推广客服电话人工服务
  • 如何网站公司小程序怎么查搜索关键词排名
  • 汉邦未来网站建设网站点击量统计
  • 网站后台基本功能营销网络图
  • 自己做整个网站的流程疫情最新政策最新消息
  • 视频封面制作网站网站推广关键词工具
  • 网站 刷流量 SEO现在最火的推广平台有哪些
  • 快对作业小程序入口在线seo推广软件
  • 中山外贸网站建设线上营销公司
  • 沧源网站建设长沙专业网络推广公司
  • 网站开发交接资料邢台网站公司
  • android开发工具箱合肥网络优化推广公司
  • 网站开发需要什么资质今日新闻最新消息
  • 保定网站制作哪家好建设seo评测论坛
  • 网站开发西安中软网站排名监控工具
  • 长春火车站电话人工服务品牌活动策划
  • 沌口做网站国内十大软件培训机构
  • 微信公众号上微做网站百度竞价推广点击软件
  • 设计模板网站市场推广
  • 襄阳网站建设xtehus企业网站定制开发
  • 浙江立鹏建设有限公司网站搜索引擎优化的核心及内容
  • 南京房产网站建设seo中文意思
  • 北京门户企业网站建设360关键词指数查询
  • 有没有专门做日本代购的网站口碑seo推广公司
  • 做淘宝类网站怎么接app推广的单子
  • 什么是优化型网站和业务多一样的平台
  • 旅游 网站开发的项目描述郑州网站seo推广
  • c2c网站建设费用长沙本地推广