Java项目:进销存管理系统(前后端分离+java+vue+Springboot+ssm+mysql+maven+redis)
源码获取:博客首页 "资源" 里下载!
一、项目简述
本系统功能包括: 库存管理,入库管理,出库管理,往来管理,基础资料, 系统管理,消息中心,系统监控等等。
二、项目运行
环境配置: Jdk1.8 + Tomcat8.5 + Mysql + HBuilderX ( Webstorm也 行)+ Eclispe ( IntelliJ IDEA ,Eclispe,MyEclispe , Sts都支持)。
项目技术: Springboot + Maven + Mybatis-plus+ Vue + Redis + Shiro + Druid + logback 组成,B/S模萤;,其他:fastjson, poi, Swagger-ui, quartz, lombok (简化代码)等
接口返回数据格式:
/*** 接口返回数据格式* @author scott*/
@Data
@ApiModel(value="接口返回对象", description="接口返回对象")
public class Result<T> implements Serializable {private static final long serialVersionUID = 1L;/*** 成功标志*/@ApiModelProperty(value = "成功标志")private boolean success = true;/*** 返回处理消息*/@ApiModelProperty(value = "返回处理消息")private String message = "操作成功!";/*** 返回代码*/@ApiModelProperty(value = "返回代码")private Integer code = 0;/*** 返回数据对象 data*/@ApiModelProperty(value = "返回数据对象")private T result;/*** 时间戳*/@ApiModelProperty(value = "时间戳")private long timestamp = System.currentTimeMillis();public Result() {}public Result<T> success(String message) {this.message = message;this.code = CommonConstant.SC_OK_200;this.success = true;return this;}public static Result<Object> ok() {Result<Object> r = new Result<Object>();r.setSuccess(true);r.setCode(CommonConstant.SC_OK_200);r.setMessage("成功");return r;}public static Result<Object> ok(String msg) {Result<Object> r = new Result<Object>();r.setSuccess(true);r.setCode(CommonConstant.SC_OK_200);r.setMessage(msg);return r;}public static Result<Object> ok(Object data) {Result<Object> r = new Result<Object>();r.setSuccess(true);r.setCode(CommonConstant.SC_OK_200);r.setResult(data);return r;}public static Result<Object> error(String msg) {return error(CommonConstant.SC_INTERNAL_SERVER_ERROR_500, msg);}public static Result<Object> error(int code, String msg) {Result<Object> r = new Result<Object>();r.setCode(code);r.setMessage(msg);r.setSuccess(false);return r;}public Result<T> error500(String message) {this.message = message;this.code = CommonConstant.SC_INTERNAL_SERVER_ERROR_500;this.success = false;return this;}/*** 无权限访问返回结果*/public static Result<Object> noauth(String msg) {return error(CommonConstant.SC_JEECG_NO_AUTHZ, msg);}
}
用户信息控制器:
/*** <p>* 用户表 前端控制器* </p>**/
@Slf4j
@RestController
@RequestMapping("/sys/common")
public class CommonController {@Autowiredprivate ISysBaseAPI sysBaseAPI;@Value(value = "${jeecg.path.upload}")private String uploadpath;/*** 本地:local minio:minio 阿里:alioss*/@Value(value="${jeecg.uploadType}")private String uploadType;/*** @Author 政辉* @return*/@GetMapping("/403")public Result<?> noauth() {return Result.error("没有权限,请联系管理员授权");}/*** 文件上传统一方法* @param request* @param response* @return*/@PostMapping(value = "/upload")public Result<?> upload(HttpServletRequest request, HttpServletResponse response) {Result<?> result = new Result<>();String savePath = "";String bizPath = request.getParameter("biz");MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request;MultipartFile file = multipartRequest.getFile("file");// 获取上传文件对象if(oConvertUtils.isEmpty(bizPath)){if(CommonConstant.UPLOAD_TYPE_OSS.equals(uploadType)){//未指定目录,则用阿里云默认目录 uploadbizPath = "upload";//result.setMessage("使用阿里云文件上传时,必须添加目录!");//result.setSuccess(false);//return result;}else{bizPath = "";}}if(CommonConstant.UPLOAD_TYPE_LOCAL.equals(uploadType)){//针对jeditor编辑器如何使 lcaol模式,采用 base64格式存储String jeditor = request.getParameter("jeditor");if(oConvertUtils.isNotEmpty(jeditor)){result.setMessage(CommonConstant.UPLOAD_TYPE_LOCAL);result.setSuccess(true);return result;}else{savePath = this.uploadLocal(file,bizPath);}}else{savePath = sysBaseAPI.upload(file,bizPath,uploadType);}if(oConvertUtils.isNotEmpty(savePath)){result.setMessage(savePath);result.setSuccess(true);}else {result.setMessage("上传失败!");result.setSuccess(false);}return result;}/*** 本地文件上传* @param mf 文件* @param bizPath 自定义路径* @return*/private String uploadLocal(MultipartFile mf,String bizPath){try {String ctxPath = uploadpath;String fileName = null;File file = new File(ctxPath + File.separator + bizPath + File.separator );if (!file.exists()) {file.mkdirs();// 创建文件根目录}String orgName = mf.getOriginalFilename();// 获取文件名orgName = CommonUtils.getFileName(orgName);if(orgName.indexOf(".")!=-1){fileName = orgName.substring(0, orgName.lastIndexOf(".")) + "_" + System.currentTimeMillis() + orgName.substring(orgName.indexOf("."));}else{fileName = orgName+ "_" + System.currentTimeMillis();}String savePath = file.getPath() + File.separator + fileName;File savefile = new File(savePath);FileCopyUtils.copy(mf.getBytes(), savefile);String dbpath = null;if(oConvertUtils.isNotEmpty(bizPath)){dbpath = bizPath + File.separator + fileName;}else{dbpath = fileName;}if (dbpath.contains("\\")) {dbpath = dbpath.replace("\\", "/");}return dbpath;} catch (IOException e) {log.error(e.getMessage(), e);}return "";}// @PostMapping(value = "/upload2")
// public Result<?> upload2(HttpServletRequest request, HttpServletResponse response) {
// Result<?> result = new Result<>();
// try {
// String ctxPath = uploadpath;
// String fileName = null;
// String bizPath = "files";
// String tempBizPath = request.getParameter("biz");
// if(oConvertUtils.isNotEmpty(tempBizPath)){
// bizPath = tempBizPath;
// }
// String nowday = new SimpleDateFormat("yyyyMMdd").format(new Date());
// File file = new File(ctxPath + File.separator + bizPath + File.separator + nowday);
// if (!file.exists()) {
// file.mkdirs();// 创建文件根目录
// }
// MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request;
// MultipartFile mf = multipartRequest.getFile("file");// 获取上传文件对象
// String orgName = mf.getOriginalFilename();// 获取文件名
// fileName = orgName.substring(0, orgName.lastIndexOf(".")) + "_" + System.currentTimeMillis() + orgName.substring(orgName.indexOf("."));
// String savePath = file.getPath() + File.separator + fileName;
// File savefile = new File(savePath);
// FileCopyUtils.copy(mf.getBytes(), savefile);
// String dbpath = bizPath + File.separator + nowday + File.separator + fileName;
// if (dbpath.contains("\\")) {
// dbpath = dbpath.replace("\\", "/");
// }
// result.setMessage(dbpath);
// result.setSuccess(true);
// } catch (IOException e) {
// result.setSuccess(false);
// result.setMessage(e.getMessage());
// log.error(e.getMessage(), e);
// }
// return result;
// }/*** 预览图片&下载文件* 请求地址:http://localhost:8080/common/static/{user/20190119/e1fe9925bc315c60addea1b98eb1cb1349547719_1547866868179.jpg}** @param request* @param response*/@GetMapping(value = "/static/**")public void view(HttpServletRequest request, HttpServletResponse response) {// ISO-8859-1 ==> UTF-8 进行编码转换String imgPath = extractPathFromPattern(request);if(oConvertUtils.isEmpty(imgPath) || imgPath=="null"){return;}// 其余处理略InputStream inputStream = null;OutputStream outputStream = null;try {imgPath = imgPath.replace("..", "");if (imgPath.endsWith(",")) {imgPath = imgPath.substring(0, imgPath.length() - 1);}String filePath = uploadpath + File.separator + imgPath;File file = new File(filePath);if(!file.exists()){response.setStatus(404);throw new RuntimeException("文件不存在..");}response.setContentType("application/force-download");// 设置强制下载不打开response.addHeader("Content-Disposition", "attachment;fileName=" + new String(file.getName().getBytes("UTF-8"),"iso-8859-1"));inputStream = new BufferedInputStream(new FileInputStream(filePath));outputStream = response.getOutputStream();byte[] buf = new byte[1024];int len;while ((len = inputStream.read(buf)) > 0) {outputStream.write(buf, 0, len);}response.flushBuffer();} catch (IOException e) {log.error("预览文件失败" + e.getMessage());response.setStatus(404);e.printStackTrace();} finally {if (inputStream != null) {try {inputStream.close();} catch (IOException e) {log.error(e.getMessage(), e);}}if (outputStream != null) {try {outputStream.close();} catch (IOException e) {log.error(e.getMessage(), e);}}}}// /**
// * 下载文件
// * 请求地址:http://localhost:8080/common/download/{user/20190119/e1fe9925bc315c60addea1b98eb1cb1349547719_1547866868179.jpg}
// *
// * @param request
// * @param response
// * @throws Exception
// */
// @GetMapping(value = "/download/**")
// public void download(HttpServletRequest request, HttpServletResponse response) throws Exception {
// // ISO-8859-1 ==> UTF-8 进行编码转换
// String filePath = extractPathFromPattern(request);
// // 其余处理略
// InputStream inputStream = null;
// OutputStream outputStream = null;
// try {
// filePath = filePath.replace("..", "");
// if (filePath.endsWith(",")) {
// filePath = filePath.substring(0, filePath.length() - 1);
// }
// String localPath = uploadpath;
// String downloadFilePath = localPath + File.separator + filePath;
// File file = new File(downloadFilePath);
// if (file.exists()) {
// response.setContentType("application/force-download");// 设置强制下载不打开
// response.addHeader("Content-Disposition", "attachment;fileName=" + new String(file.getName().getBytes("UTF-8"),"iso-8859-1"));
// inputStream = new BufferedInputStream(new FileInputStream(file));
// outputStream = response.getOutputStream();
// byte[] buf = new byte[1024];
// int len;
// while ((len = inputStream.read(buf)) > 0) {
// outputStream.write(buf, 0, len);
// }
// response.flushBuffer();
// }
//
// } catch (Exception e) {
// log.info("文件下载失败" + e.getMessage());
// // e.printStackTrace();
// } finally {
// if (inputStream != null) {
// try {
// inputStream.close();
// } catch (IOException e) {
// e.printStackTrace();
// }
// }
// if (outputStream != null) {
// try {
// outputStream.close();
// } catch (IOException e) {
// e.printStackTrace();
// }
// }
// }
//
// }/*** @功能:pdf预览Iframe* @param modelAndView* @return*/@RequestMapping("/pdf/pdfPreviewIframe")public ModelAndView pdfPreviewIframe(ModelAndView modelAndView) {modelAndView.setViewName("pdfPreviewIframe");return modelAndView;}/*** 把指定URL后的字符串全部截断当成参数* 这么做是为了防止URL中包含中文或者特殊字符(/等)时,匹配不了的问题* @param request* @return*/private static String extractPathFromPattern(final HttpServletRequest request) {String path = (String) request.getAttribute(HandlerMapping.PATH_WITHIN_HANDLER_MAPPING_ATTRIBUTE);String bestMatchPattern = (String) request.getAttribute(HandlerMapping.BEST_MATCHING_PATTERN_ATTRIBUTE);return new AntPathMatcher().extractPathWithinPattern(bestMatchPattern, path);}/*** 中转HTTP请求,解决跨域问题** @param url 必填:请求地址* @return*/@RequestMapping("/transitRESTful")public Result transitRESTful(@RequestParam("url") String url, HttpServletRequest request) {try {ServletServerHttpRequest httpRequest = new ServletServerHttpRequest(request);// 中转请求method、bodyHttpMethod method = httpRequest.getMethod();JSONObject params;try {params = JSON.parseObject(JSON.toJSONString(httpRequest.getBody()));} catch (Exception e) {params = new JSONObject();}// 中转请求问号参数JSONObject variables = JSON.parseObject(JSON.toJSONString(request.getParameterMap()));variables.remove("url");// 在 headers 里传递TokenString token = TokenUtils.getTokenByRequest(request);HttpHeaders headers = new HttpHeaders();headers.set("X-Access-Token", token);// 发送请求String httpURL = URLDecoder.decode(url, "UTF-8");ResponseEntity<String> response = RestUtil.request(httpURL, method, headers , variables, params, String.class);// 封装返回结果Result<Object> result = new Result<>();int statusCode = response.getStatusCodeValue();result.setCode(statusCode);result.setSuccess(statusCode == 200);String responseBody = response.getBody();try {// 尝试将返回结果转为JSONObject json = JSON.parse(responseBody);result.setResult(json);} catch (Exception e) {// 转成JSON失败,直接返回原始数据result.setResult(responseBody);}return result;} catch (Exception e) {log.debug("中转HTTP请求失败", e);return Result.error(e.getMessage());}}}
付款单控制层:
/*** @Description: 付款单*/
@Api(tags="付款单")
@RestController
@RequestMapping("/finance/finPayment")
@Slf4j
public class FinPaymentController {@Autowiredprivate IFinPaymentService finPaymentService;@Autowiredprivate IFinPaymentEntryService finPaymentEntryService;/*** 分页列表查询** @param finPayment* @param pageNo* @param pageSize* @param req* @return*/@AutoLog(value = "付款单-分页列表查询")@ApiOperation(value="付款单-分页列表查询", notes="付款单-分页列表查询")@GetMapping(value = {"/list", "/list/{paymentType}"}) //paymentType会传至finPayment.paymentTypepublic Result<?> queryPageList(FinPayment finPayment,@RequestParam(name="pageNo", defaultValue="1") Integer pageNo,@RequestParam(name="pageSize", defaultValue="10") Integer pageSize,HttpServletRequest req) {QueryWrapper<FinPayment> queryWrapper = QueryGenerator.initQueryWrapper(finPayment, req.getParameterMap());Page<FinPayment> page = new Page<FinPayment>(pageNo, pageSize);IPage<FinPayment> pageList = finPaymentService.page(page, queryWrapper);return Result.ok(pageList);}@GetMapping(value = "/checkableList")public Result<?> queryCheckablePageList(FinPayment finPayment,@RequestParam(name="pageNo", defaultValue="1") Integer pageNo,@RequestParam(name="pageSize", defaultValue="10") Integer pageSize,HttpServletRequest req) {QueryWrapper<FinPayment> queryWrapper = QueryGenerator.initQueryWrapper(finPayment, req.getParameterMap());List<String> list = new ArrayList<String>();list.add("23");list.add("31");list.add("32");queryWrapper.in("bill_proc_Status", list);queryWrapper.eq("is_approved", 1);queryWrapper.eq("is_closed", 0);queryWrapper.eq("is_voided", 0);queryWrapper.apply("amt - deducted_amt - checked_amt > 0");Page<FinPayment> page = new Page<FinPayment>(pageNo, pageSize);IPage<FinPayment> pageList = finPaymentService.page(page, queryWrapper);return Result.ok(pageList);}/*** 添加** @param finPaymentPage* @return*/@AutoLog(value = "付款单-添加")@ApiOperation(value="付款单-添加", notes="付款单-添加")@PostMapping(value = "/add")public Result<?> add(@RequestBody FinPaymentPage finPaymentPage) {FinPayment finPayment = new FinPayment();BeanUtils.copyProperties(finPaymentPage, finPayment);finPaymentService.saveMain(finPayment, finPaymentPage.getFinPaymentEntryList());return Result.ok("添加成功!");}/*** 编辑** @param finPaymentPage* @return*/@AutoLog(value = "付款单-编辑")@ApiOperation(value="付款单-编辑", notes="付款单-编辑")@PutMapping(value = "/edit")public Result<?> edit(@RequestBody FinPaymentPage finPaymentPage) {FinPayment finPayment = new FinPayment();BeanUtils.copyProperties(finPaymentPage, finPayment);FinPayment finPaymentEntity = finPaymentService.getById(finPayment.getId());if(finPaymentEntity==null) {return Result.error("未找到对应数据");}finPaymentService.updateMain(finPayment, finPaymentPage.getFinPaymentEntryList());return Result.ok("编辑成功!");}/*** 通过id删除** @param id* @return*/@AutoLog(value = "付款单-通过id删除")@ApiOperation(value="付款单-通过id删除", notes="付款单-通过id删除")@DeleteMapping(value = "/delete")public Result<?> delete(@RequestParam(name="id",required=true) String id) {finPaymentService.delMain(id);return Result.ok("删除成功!");}/*** 批量删除** @param ids* @return*/@AutoLog(value = "付款单-批量删除")@ApiOperation(value="付款单-批量删除", notes="付款单-批量删除")@DeleteMapping(value = "/deleteBatch")public Result<?> deleteBatch(@RequestParam(name="ids",required=true) String ids) {this.finPaymentService.delBatchMain(Arrays.asList(ids.split(",")));return Result.ok("批量删除成功!");}/*** 通过id查询** @param id* @return*/@AutoLog(value = "付款单-通过id查询")@ApiOperation(value="付款单-通过id查询", notes="付款单-通过id查询")@GetMapping(value = "/queryById")public Result<?> queryById(@RequestParam(name="id",required=true) String id) {FinPayment finPayment = finPaymentService.getById(id);if(finPayment==null) {return Result.error("未找到对应数据");}return Result.ok(finPayment);}/*** 通过id查询** @param id* @return*/@AutoLog(value = "付款明细集合-通过id查询")@ApiOperation(value="付款明细集合-通过id查询", notes="付款明细-通过id查询")@GetMapping(value = "/queryFinPaymentEntryByMainId")public Result<?> queryFinPaymentEntryListByMainId(@RequestParam(name="id",required=true) String id) {List<FinPaymentEntry> finPaymentEntryList = finPaymentEntryService.selectByMainId(id);return Result.ok(finPaymentEntryList);}/*** 导出excel** @param request* @param finPayment*/@RequestMapping(value = {"/exportXls", "/exportXls/{paymentType}"})public ModelAndView exportXls(HttpServletRequest request, FinPayment finPayment) {// Step.1 组装查询条件查询数据QueryWrapper<FinPayment> queryWrapper = QueryGenerator.initQueryWrapper(finPayment, request.getParameterMap());LoginUser sysUser = (LoginUser) SecurityUtils.getSubject().getPrincipal();//Step.2 获取导出数据List<FinPayment> queryList = finPaymentService.list(queryWrapper);// 过滤选中数据String selections = request.getParameter("selections");List<FinPayment> finPaymentList = new ArrayList<FinPayment>();if(oConvertUtils.isEmpty(selections)) {finPaymentList = queryList;}else {List<String> selectionList = Arrays.asList(selections.split(","));finPaymentList = queryList.stream().filter(item -> selectionList.contains(item.getId())).collect(Collectors.toList());}// Step.3 组装pageListList<FinPaymentPage> pageList = new ArrayList<FinPaymentPage>();for (FinPayment main : finPaymentList) {FinPaymentPage vo = new FinPaymentPage();BeanUtils.copyProperties(main, vo);List<FinPaymentEntry> finPaymentEntryList = finPaymentEntryService.selectByMainId(main.getId());vo.setFinPaymentEntryList(finPaymentEntryList);pageList.add(vo);}// Step.4 AutoPoi 导出ExcelModelAndView mv = new ModelAndView(new JeecgEntityExcelView());mv.addObject(NormalExcelConstants.FILE_NAME, "付款单列表");mv.addObject(NormalExcelConstants.CLASS, FinPaymentPage.class);mv.addObject(NormalExcelConstants.PARAMS, new ExportParams("付款单数据", "导出人:"+sysUser.getRealname(), "付款单"));mv.addObject(NormalExcelConstants.DATA_LIST, pageList);return mv;}/*** 通过excel导入数据** @param request* @param response* @return*/@RequestMapping(value = "/importExcel", method = RequestMethod.POST)public Result<?> importExcel(HttpServletRequest request, HttpServletResponse response) {MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request;Map<String, MultipartFile> fileMap = multipartRequest.getFileMap();for (Map.Entry<String, MultipartFile> entity : fileMap.entrySet()) {MultipartFile file = entity.getValue();// 获取上传文件对象ImportParams params = new ImportParams();params.setTitleRows(2);params.setHeadRows(1);params.setNeedSave(true);try {List<FinPaymentPage> list = ExcelImportUtil.importExcel(file.getInputStream(), FinPaymentPage.class, params);for (FinPaymentPage page : list) {FinPayment po = new FinPayment();BeanUtils.copyProperties(page, po);finPaymentService.saveMain(po, page.getFinPaymentEntryList());}return Result.ok("文件导入成功!数据行数:" + list.size());} catch (Exception e) {log.error(e.getMessage(),e);return Result.error("文件导入失败:"+e.getMessage());} finally {try {file.getInputStream().close();} catch (IOException e) {e.printStackTrace();}}}return Result.ok("文件导入失败!");}@AutoLog(value = "付款单-通过id审核")@ApiOperation(value="付款单-通过id审核", notes="付款单-通过id审核")@PutMapping(value = "/approve")public Result<?> approve(@RequestBody JSONObject json) {finPaymentService.approve(json.getString("id"));return Result.ok("审核通过!");}
}
源码获取:博客首页 "资源" 里下载!
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
相关文章
- 逻辑回归算法深度思考-优点和缺点
之前《python信用评分卡建模(附代码)》介绍了逻辑回归评分卡模型的各个细节,包括各种分箱方法,woe和iv原理和Excel保姆级推导,变量badrate单调性,坏客户定义,逻辑回归调参等等。因此今天不谈论这…...
2024/4/18 16:30:26 - 分治算法4 题目练习
题目AB名称网线主管月度开销难度☆☆★★★☆☆★★★ A. 网线主管 内存限制:128 MiB 时间限制:1000 ms 标准输入输出 题目类型:传统 评测方式:文本比较题目描述 仙境的居民们决定举办一场程序设计区域赛。裁判委员会完全由自愿…...
2024/4/13 4:39:05 - Error: Failed to download metadata for repo ‘AppStream‘: Cannot download repomd.xml解决方法
最近在使用阿里云ESC服务器去下载软件时出现了这个错误,最后在官方上找到了答案 Error: Failed to download metadata for repo ‘AppStream’: Cannot download repomd.xml: Cannot download repodata/repomd.xml: All mirrors were tried 解决方法 ‘https://help…...
2024/4/13 4:39:10 - 路径穿越/遍历
前提知识: 相对于正常输入的,目录/文件名这类,/../在路径也是有效的,不过它有点独特,发挥返回上一层目录的作用。因此,在知道目录有几层的情况下,就可以通过相对应层数的/../来返回到根目录&am…...
2024/5/4 20:41:03 - 江苏省最新四级行政区划矢量数据(到乡镇)
上图效果: 编码格式:UTF-8 文件格式:Shpfile 地理坐标:WGS84 属性字段明细: 下载链接:2021年江苏省最新四级行政区划矢量数据(到乡镇).zip-交通文档类资源-CSDN下载...
2024/4/13 4:39:25 - java————二十抽象类
由abstract修饰的类叫抽象类。抽象的类无法进行实例化,因为他不是具体存在的类,或者说这样的类还不够完善,不能直接使用new关键字调用其构造器生成该类的对象。 public abstract class Animal {private String name;public Animal(String ana…...
2024/4/13 4:39:10 - 1058 选择题 (20 分)
1058 选择题 (20 分) 批改多选题是比较麻烦的事情,本题就请你写个程序帮助老师批改多选题,并且指出哪道题错的人最多。 输入格式: 输入在第一行给出两个正整数 N(≤ 1000)和 M(≤ 100)&#x…...
2024/4/13 4:39:35 - docker-windows 安装 nacos
1.首先安装 mysql,我用的是mysql8.0, docker run -itd --name mysql -p 3307:3306 -e MYSQL_ROOT_PASSWORD123456 mysql:8.0 --character-set-serverutf8mb4 --collation-serverutf8mb4_unicode_ci其中: --name 是容器名称-itd 后台运行-p 将…...
2024/4/18 21:30:26 - Leetcode 0001.两数之和
目录0001.两数之和0001.两数之和 题目: 给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数,并返回它们的数组下标。 思路1: 直接用两层循环暴力求解,算法复杂度为…...
2024/4/15 0:23:26 - Leetcode--Java--394. 字符串解码
题目描述 给定一个经过编码的字符串,返回它解码后的字符串。 编码规则为: k[encoded_string],表示其中方括号内部的 encoded_string 正好重复 k 次。注意 k 保证为正整数。 你可以认为输入字符串总是有效的;输入字符串中没有额外的空格&am…...
2024/4/8 19:29:30 - 懒人必备神器 ,一个创意十足的 Python 命令行工具
相关文件 想学Python的小伙伴可以关注小编的公众号【Python日志】 有很多的资源可以白嫖的哈,不定时会更新一下Python的小知识的哈!! 正文 当听到某些人说 xx 库非常好用的时候,我们总是忍不住想要去亲自试试。 比百度全家桶&…...
2024/4/13 4:39:25 - 【第十八期】分享一个网易go面经
自我介绍未来的主要方向介绍下之前的项目用到的优化点、难点为什么不要大量使用goroutinegpm模型go里面goroutine创建数量有限制吗?线程和协程有什么区别golang支持哪些并发机制go利用channel通信的方式有缓冲和无缓冲channel的区别channel实现原理被close的channel…...
2024/4/20 7:32:24 - redis config之save命令详解
# Redis will save the DB if both the given number of seconds and the given # number of write operations against the DB occurred. save seconds number save命令有两个参数,第一个是秒数,第二个是写入操作次数,再看下面一段注释 # …...
2024/4/18 10:16:39 - 障碍物检测
现在对于我来说最困惑的地方就是realsense SDK2.0怎么使用,怎么将代码和摄像头获取图像结合起来. 障碍物检测思路 读入图像对图像进行二值处理 (使用开运算或者闭运算),只检测一米内的距离的范围 (用realsense摄像头)通过阈值大小(先设置好阈值大小)&a…...
2024/4/13 4:40:15 - 服务器搭建系列之7:k8s安装postgresql数据库,2022最新版本
Dockerfile FROM postgresEXPOSE 5432deploy.yaml #命名空间 apiVersion: v1 kind: Namespace metadata:name: fandai --- apiVersion: apps/v1 kind: Deployment metadata:name: postgresqlnamespace: fandai spec:replicas: 1selector:matchLabels:app: postgresqltemplate…...
2024/4/17 16:58:52 - 我的c语言学习记录(蓝桥)————文件和文件的输入与输出
文件和文件的输入与输出 什么是文件 文件有不同的类型,在程序设计中,主要用到两种文件: 程序文件:包括源程序文件(后缀为 .c),目标文件(后缀为 .o)以及可执行文件等。…...
2024/4/19 17:40:35 - k8s 心跳机制
...
2024/4/19 12:03:22 - java--static修饰词
static的意思就是字面意思:共享。 被static修饰的成员变量 被static修饰的成员变量可以被所以对象共享,就像一个班的人都公用一个饮水机: static String 饮水机 ; 然后再定义一个方法: public void show(){System.out.printl…...
2024/4/20 11:20:17 - C++11_lambda表达式,包装器,bind绑定
文章目录1.lambda表达式捕获列表说明C11 lambda原理2.包装器bind绑定1.lambda表达式 【捕捉列表】(参数列表)mutable ->返回值类型 {函数体} mutable:默认条件下,lambda表达式默认具有const属性,mutable可以取消其…...
2024/4/20 0:48:30 - 88. 合并两个有序数组(java实现)--3种解法(暴力,不建数组--从后往前,新建数组--从前往后)LeetCode
文章目录题目:解法1:暴力解法2:不建数组(从后往前)解法3:新建数组(从前往后)题目: 给你两个按 非递减顺序 排列的整数数组 nums1 和 nums2,另有两个整数 m 和…...
2024/4/18 21:42:12
最新文章
- MySQL数据库—初识数据库 | DDL语句 | DML语句
初识数据库 ____________________________________★_______________________________________ ▐ 为什么学习数据库? • 以前我们在程序中存储数据. 例如:一个变量,一个对象 ( 数据存储在内存中,程序运行结束后就销毁 ) • …...
2024/5/5 3:39:12 - 梯度消失和梯度爆炸的一些处理方法
在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言,在此感激不尽。 权重和梯度的更新公式如下: w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...
2024/3/20 10:50:27 - Android如何实现一个应用位于前台时全局页面每隔三分钟弹出一次一天最多弹出5次的GroMore半插屏广告,处于付费页和后台时停止
首先我们需要添加一个全局的Application public class MyApp extends LitePalApplication {private static final String TAG "MyApp";private static Context mContext;private boolean isManageMent;public static String oaid;Overridepublic void onCreate() {…...
2024/5/3 5:28:16 - 算法四十天-删除排序链表中的重复元素
删除排序链表中的重复元素 题目要求 解题思路 一次遍历 由于给定的链表是排好序的,因此重复的元素在链表中的出现的位置是连续的,因此我们只需要对链表进行一次遍历,就可以删除重复的元素。 具体地,我们从指针cur指向链表的头节…...
2024/5/1 13:07:13 - 解决GNU Radio+USRP实现OFDM收发在接收端QPSK星座图映射无“抖动”问题
文章目录 前言一、遇到的问题二、解决方案三、重新编译安装四、验证五、资源自取 前言 本文记录在 GNU RadioUSRP 实现 OFDM 收发时,在接收端 QPSK 星座图映射无“抖动”问题的解决方法, 一、遇到的问题 我遇到的问题是,现在搭建的 OFDM 模…...
2024/5/3 13:25:32 - 【外汇早评】美通胀数据走低,美元调整
原标题:【外汇早评】美通胀数据走低,美元调整昨日美国方面公布了新一期的核心PCE物价指数数据,同比增长1.6%,低于前值和预期值的1.7%,距离美联储的通胀目标2%继续走低,通胀压力较低,且此前美国一季度GDP初值中的消费部分下滑明显,因此市场对美联储后续更可能降息的政策…...
2024/5/4 23:54:56 - 【原油贵金属周评】原油多头拥挤,价格调整
原标题:【原油贵金属周评】原油多头拥挤,价格调整本周国际劳动节,我们喜迎四天假期,但是整个金融市场确实流动性充沛,大事频发,各个商品波动剧烈。美国方面,在本周四凌晨公布5月份的利率决议和新闻发布会,维持联邦基金利率在2.25%-2.50%不变,符合市场预期。同时美联储…...
2024/5/4 23:54:56 - 【外汇周评】靓丽非农不及疲软通胀影响
原标题:【外汇周评】靓丽非农不及疲软通胀影响在刚结束的周五,美国方面公布了新一期的非农就业数据,大幅好于前值和预期,新增就业重新回到20万以上。具体数据: 美国4月非农就业人口变动 26.3万人,预期 19万人,前值 19.6万人。 美国4月失业率 3.6%,预期 3.8%,前值 3…...
2024/5/4 23:54:56 - 【原油贵金属早评】库存继续增加,油价收跌
原标题:【原油贵金属早评】库存继续增加,油价收跌周三清晨公布美国当周API原油库存数据,上周原油库存增加281万桶至4.692亿桶,增幅超过预期的74.4万桶。且有消息人士称,沙特阿美据悉将于6月向亚洲炼油厂额外出售更多原油,印度炼油商预计将每日获得至多20万桶的额外原油供…...
2024/5/4 23:55:17 - 【外汇早评】日本央行会议纪要不改日元强势
原标题:【外汇早评】日本央行会议纪要不改日元强势近两日日元大幅走强与近期市场风险情绪上升,避险资金回流日元有关,也与前一段时间的美日贸易谈判给日本缓冲期,日本方面对汇率问题也避免继续贬值有关。虽然今日早间日本央行公布的利率会议纪要仍然是支持宽松政策,但这符…...
2024/5/4 23:54:56 - 【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响
原标题:【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响近日伊朗局势升温,导致市场担忧影响原油供给,油价试图反弹。此时OPEC表态稳定市场。据消息人士透露,沙特6月石油出口料将低于700万桶/日,沙特已经收到石油消费国提出的6月份扩大出口的“适度要求”,沙特将满…...
2024/5/4 23:55:05 - 【外汇早评】美欲与伊朗重谈协议
原标题:【外汇早评】美欲与伊朗重谈协议美国对伊朗的制裁遭到伊朗的抗议,昨日伊朗方面提出将部分退出伊核协议。而此行为又遭到欧洲方面对伊朗的谴责和警告,伊朗外长昨日回应称,欧洲国家履行它们的义务,伊核协议就能保证存续。据传闻伊朗的导弹已经对准了以色列和美国的航…...
2024/5/4 23:54:56 - 【原油贵金属早评】波动率飙升,市场情绪动荡
原标题:【原油贵金属早评】波动率飙升,市场情绪动荡因中美贸易谈判不安情绪影响,金融市场各资产品种出现明显的波动。随着美国与中方开启第十一轮谈判之际,美国按照既定计划向中国2000亿商品征收25%的关税,市场情绪有所平复,已经开始接受这一事实。虽然波动率-恐慌指数VI…...
2024/5/4 23:55:16 - 【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试
原标题:【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试美国和伊朗的局势继续升温,市场风险情绪上升,避险黄金有向上突破阻力的迹象。原油方面稍显平稳,近期美国和OPEC加大供给及市场需求回落的影响,伊朗局势并未推升油价走强。近期中美贸易谈判摩擦再度升级,美国对中…...
2024/5/4 23:54:56 - 【原油贵金属早评】市场情绪继续恶化,黄金上破
原标题:【原油贵金属早评】市场情绪继续恶化,黄金上破周初中国针对于美国加征关税的进行的反制措施引发市场情绪的大幅波动,人民币汇率出现大幅的贬值动能,金融市场受到非常明显的冲击。尤其是波动率起来之后,对于股市的表现尤其不安。隔夜美国股市出现明显的下行走势,这…...
2024/5/4 18:20:48 - 【外汇早评】美伊僵持,风险情绪继续升温
原标题:【外汇早评】美伊僵持,风险情绪继续升温昨日沙特两艘油轮再次发生爆炸事件,导致波斯湾局势进一步恶化,市场担忧美伊可能会出现摩擦生火,避险品种获得支撑,黄金和日元大幅走强。美指受中美贸易问题影响而在低位震荡。继5月12日,四艘商船在阿联酋领海附近的阿曼湾、…...
2024/5/4 23:54:56 - 【原油贵金属早评】贸易冲突导致需求低迷,油价弱势
原标题:【原油贵金属早评】贸易冲突导致需求低迷,油价弱势近日虽然伊朗局势升温,中东地区几起油船被袭击事件影响,但油价并未走高,而是出于调整结构中。由于市场预期局势失控的可能性较低,而中美贸易问题导致的全球经济衰退风险更大,需求会持续低迷,因此油价调整压力较…...
2024/5/4 23:55:17 - 氧生福地 玩美北湖(上)——为时光守候两千年
原标题:氧生福地 玩美北湖(上)——为时光守候两千年一次说走就走的旅行,只有一张高铁票的距离~ 所以,湖南郴州,我来了~ 从广州南站出发,一个半小时就到达郴州西站了。在动车上,同时改票的南风兄和我居然被分到了一个车厢,所以一路非常愉快地聊了过来。 挺好,最起…...
2024/5/4 23:55:06 - 氧生福地 玩美北湖(中)——永春梯田里的美与鲜
原标题:氧生福地 玩美北湖(中)——永春梯田里的美与鲜一觉醒来,因为大家太爱“美”照,在柳毅山庄去寻找龙女而错过了早餐时间。近十点,向导坏坏还是带着饥肠辘辘的我们去吃郴州最富有盛名的“鱼头粉”。说这是“十二分推荐”,到郴州必吃的美食之一。 哇塞!那个味美香甜…...
2024/5/4 23:54:56 - 氧生福地 玩美北湖(下)——奔跑吧骚年!
原标题:氧生福地 玩美北湖(下)——奔跑吧骚年!让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 啊……啊……啊 两…...
2024/5/4 23:55:06 - 扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!
原标题:扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!扒开伪装医用面膜,翻六倍价格宰客!当行业里的某一品项火爆了,就会有很多商家蹭热度,装逼忽悠,最近火爆朋友圈的医用面膜,被沾上了污点,到底怎么回事呢? “比普通面膜安全、效果好!痘痘、痘印、敏感肌都能用…...
2024/5/4 2:59:34 - 「发现」铁皮石斛仙草之神奇功效用于医用面膜
原标题:「发现」铁皮石斛仙草之神奇功效用于医用面膜丽彦妆铁皮石斛医用面膜|石斛多糖无菌修护补水贴19大优势: 1、铁皮石斛:自唐宋以来,一直被列为皇室贡品,铁皮石斛生于海拔1600米的悬崖峭壁之上,繁殖力差,产量极低,所以古代仅供皇室、贵族享用 2、铁皮石斛自古民间…...
2024/5/4 23:55:16 - 丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者
原标题:丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者【公司简介】 广州华彬企业隶属香港华彬集团有限公司,专注美业21年,其旗下品牌: 「圣茵美」私密荷尔蒙抗衰,产后修复 「圣仪轩」私密荷尔蒙抗衰,产后修复 「花茵莳」私密荷尔蒙抗衰,产后修复 「丽彦妆」专注医学护…...
2024/5/4 23:54:58 - 广州械字号面膜生产厂家OEM/ODM4项须知!
原标题:广州械字号面膜生产厂家OEM/ODM4项须知!广州械字号面膜生产厂家OEM/ODM流程及注意事项解读: 械字号医用面膜,其实在我国并没有严格的定义,通常我们说的医美面膜指的应该是一种「医用敷料」,也就是说,医用面膜其实算作「医疗器械」的一种,又称「医用冷敷贴」。 …...
2024/5/4 23:55:01 - 械字号医用眼膜缓解用眼过度到底有无作用?
原标题:械字号医用眼膜缓解用眼过度到底有无作用?医用眼膜/械字号眼膜/医用冷敷眼贴 凝胶层为亲水高分子材料,含70%以上的水分。体表皮肤温度传导到本产品的凝胶层,热量被凝胶内水分子吸收,通过水分的蒸发带走大量的热量,可迅速地降低体表皮肤局部温度,减轻局部皮肤的灼…...
2024/5/4 23:54:56 - 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...
解析如下:1、长按电脑电源键直至关机,然后再按一次电源健重启电脑,按F8健进入安全模式2、安全模式下进入Windows系统桌面后,按住“winR”打开运行窗口,输入“services.msc”打开服务设置3、在服务界面,选中…...
2022/11/19 21:17:18 - 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。
%读入6幅图像(每一幅图像的大小是564*564) f1 imread(WashingtonDC_Band1_564.tif); subplot(3,2,1),imshow(f1); f2 imread(WashingtonDC_Band2_564.tif); subplot(3,2,2),imshow(f2); f3 imread(WashingtonDC_Band3_564.tif); subplot(3,2,3),imsho…...
2022/11/19 21:17:16 - 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...
win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面,在等待界面中我们需要等待操作结束才能关机,虽然这比较麻烦,但是对系统进行配置和升级…...
2022/11/19 21:17:15 - 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...
有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows,请勿关闭计算机”的提示,要过很久才能进入系统,有的用户甚至几个小时也无法进入,下面就教大家这个问题的解决方法。第一种方法:我们首先在左下角的“开始…...
2022/11/19 21:17:14 - win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...
置信有很多用户都跟小编一样遇到过这样的问题,电脑时发现开机屏幕显现“正在配置Windows Update,请勿关机”(如下图所示),而且还需求等大约5分钟才干进入系统。这是怎样回事呢?一切都是正常操作的,为什么开时机呈现“正…...
2022/11/19 21:17:13 - 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...
Win7系统开机启动时总是出现“配置Windows请勿关机”的提示,没过几秒后电脑自动重启,每次开机都这样无法进入系统,此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一:开机按下F8,在出现的Windows高级启动选…...
2022/11/19 21:17:12 - 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...
有不少windows10系统用户反映说碰到这样一个情况,就是电脑提示正在准备windows请勿关闭计算机,碰到这样的问题该怎么解决呢,现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法:1、2、依次…...
2022/11/19 21:17:11 - 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...
今天和大家分享一下win7系统重装了Win7旗舰版系统后,每次关机的时候桌面上都会显示一个“配置Windows Update的界面,提示请勿关闭计算机”,每次停留好几分钟才能正常关机,导致什么情况引起的呢?出现配置Windows Update…...
2022/11/19 21:17:10 - 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...
只能是等着,别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚,只能是考虑备份数据后重装系统了。解决来方案一:管理员运行cmd:net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...
2022/11/19 21:17:09 - 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?
原标题:电脑提示“配置Windows Update请勿关闭计算机”怎么办?win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢?一般的方…...
2022/11/19 21:17:08 - 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...
关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!关机提示 windows7 正在配…...
2022/11/19 21:17:05 - 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...
钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...
2022/11/19 21:17:05 - 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...
前几天班里有位学生电脑(windows 7系统)出问题了,具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面,长时间没反应,无法进入系统。这个问题原来帮其他同学也解决过,网上搜了不少资料&#x…...
2022/11/19 21:17:04 - 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...
本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法,并在最后教给你1种保护系统安全的好方法,一起来看看!电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中,添加了1个新功能在“磁…...
2022/11/19 21:17:03 - 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...
许多用户在长期不使用电脑的时候,开启电脑发现电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机。。.这要怎么办呢?下面小编就带着大家一起看看吧!如果能够正常进入系统,建议您暂时移…...
2022/11/19 21:17:02 - 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...
配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!配置windows update失败 还原更改 请勿关闭计算机&#x…...
2022/11/19 21:17:01 - 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...
不知道大家有没有遇到过这样的一个问题,就是我们的win7系统在关机的时候,总是喜欢显示“准备配置windows,请勿关机”这样的一个页面,没有什么大碍,但是如果一直等着的话就要两个小时甚至更久都关不了机,非常…...
2022/11/19 21:17:00 - 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...
当电脑出现正在准备配置windows请勿关闭计算机时,一般是您正对windows进行升级,但是这个要是长时间没有反应,我们不能再傻等下去了。可能是电脑出了别的问题了,来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...
2022/11/19 21:16:59 - 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...
我们使用电脑的过程中有时会遇到这种情况,当我们打开电脑之后,发现一直停留在一个界面:“配置Windows Update失败,还原更改请勿关闭计算机”,等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢࿰…...
2022/11/19 21:16:58 - 如何在iPhone上关闭“请勿打扰”
Apple’s “Do Not Disturb While Driving” is a potentially lifesaving iPhone feature, but it doesn’t always turn on automatically at the appropriate time. For example, you might be a passenger in a moving car, but your iPhone may think you’re the one dri…...
2022/11/19 21:16:57