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

从0开始搭建一个生产级SpringBoot2.0.X项目(三)SpringBoot接口统一返回和全局异常处理

前言

最近有个想法想整理一个内容比较完整springboot项目初始化Demo。

SpringBoot接口统一返回和全局异常处理,使用@ControllerAdvice+ @ExceptionHandler

 的组合来实现。

一、pom文件新增依赖

         <dependency><groupId>com.alibaba</groupId><artifactId>fastjson</artifactId><version>1.2.3</version></dependency><dependency><groupId>org.apache.commons</groupId><artifactId>commons-lang3</artifactId></dependency><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId></dependency>

二、创建Json工具类、统一返回相关类

2.1JsonUtil 

package com.murg.bootdemo.util;import com.alibaba.fastjson.JSONArray;
import com.fasterxml.jackson.core.type.TypeReference;
import com.fasterxml.jackson.databind.ObjectMapper;
import lombok.SneakyThrows;
import org.springframework.stereotype.Component;import javax.servlet.ServletOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.lang.reflect.Field;
import java.util.List;
import java.util.Map;/*** jackson的序列化和反序列化工具类,逐步替换gson,只留一个序列化框架*/
@Component
public class JsonUtil {public static ObjectMapper objectMapper;public JsonUtil(ObjectMapper objectMapper) {JsonUtil.objectMapper = objectMapper;}public static ObjectMapper getObjectMapper() {return objectMapper;}/*** 根据json字符串解析对象(不带解密)*/@SneakyThrowspublic static <T> T fromJson(String json, Class<T> c) {ObjectMapper gson = getObjectMapper();return gson.readValue(json, c);}/*** 根据json字符串解析对象(不带解密,第二个参数是Type,适用于泛型类型的返回类型...)*/@SneakyThrowspublic static <T> T fromJson(String json, TypeReference<T> type) {ObjectMapper gson = getObjectMapper();return gson.readValue(json, type);}public static Map<String, Object> fromJsonToMap(String json) {return fromJson(json, new TypeReference<Map<String, Object>>() {});}public static Map<String, String> fromJsonToStrMap(String json) {return fromJson(json, new TypeReference<Map<String, String>>() {});}/*** 根据对象解析成json字符串**/@SneakyThrowspublic static String toJson(Object obj) {return getObjectMapper().writeValueAsString(obj);}public static Map<String, Object> fromJsonToMap(InputStream inputStream) throws IOException {return fromJson(inputStream, new TypeReference<Map<String, Object>>() {});}private static <T> T fromJson(InputStream inputStream, TypeReference<T> tTypeReference) throws IOException {return objectMapper.readValue(inputStream, tTypeReference);}/*** map中取list* @param map* @param clazz* @param key* @return*/public  static <T> List<T> mapToList(Map<String, Object> map, Class clazz, String key) {Object o=map.get(key);String json=JSONArray.toJSONString(o);return JSONArray.parseArray(json,clazz);}public static void write2Stream(ServletOutputStream outputStream, Object webResult) throws IOException {objectMapper.writeValue(outputStream, webResult);}/**** @description: 实体类转Map(可追加字段)* @author: Jeff* @date: 2019年10月29日* @param object* @return*/public static Map<String, Object> entityToMap(Object object,Map<String,Object> paramMap) {for (Field field : object.getClass().getDeclaredFields()) {try {boolean flag = field.isAccessible();field.setAccessible(true);Object o = field.get(object);paramMap.put(field.getName(), o);field.setAccessible(flag);} catch (Exception e) {e.printStackTrace();}}return paramMap;}}

2.2ErrorCode 

package com.murg.bootdemo.exception;import lombok.Getter;
import lombok.RequiredArgsConstructor;/***/
@Getter
@RequiredArgsConstructor
public enum ErrorCode {ERROR_CODE_400(400, "参数异常!"),;private final int errorCode;private final String errorMsg;
}

 2.3WebResult

package com.murg.bootdemo.common;import com.murg.bootdemo.exception.ErrorCode;
import com.murg.bootdemo.util.JsonUtil;
import lombok.Data;
import org.slf4j.MDC;
import java.util.*;@Data
public class WebResult<T> {private T data;private int code = SysType.WEB_RESULT_OK;private int msgType = SysType.WEB_RESULT_MSG_ALERT;private String msg = "";private final String trace = Objects.toString(MDC.get("traceId"), "");public WebResult<T> setMsgType(int msgType) {this.msgType = msgType;return this;}public WebResult() {}public WebResult(int code, String msg) {this.code = code;this.msg = msg;}public T getData() {return data;}public WebResult<T> setData(T data) {this.data = data;return this;}public int getCode() {return code;}public WebResult<T> setCode(int code) {this.code = code;return this;}public String getMsg() {return msg;}public WebResult<T> setMsg(String msg) {this.msg = msg;return this;}public WebResult<T> isOK() {this.code = SysType.WEB_RESULT_OK;return this;}public WebResult<T> isWrong() {this.code = SysType.WEB_RESULT_WRONG;this.msgType = SysType.WEB_RESULT_MSG_ERROR;return this;}public WebResult<T> isWrong(String msg) {this.code = SysType.WEB_RESULT_WRONG;this.msgType = SysType.WEB_RESULT_MSG_ERROR;this.msg = msg;return this;}public WebResult<T> setErrorCode(int errorCode) {this.code = errorCode;return this;}public static <T> WebResult<T> ok() {return new WebResult<>();}public static <T> WebResult<T> ok(T data) {return WebResult.<T>ok().setData(data);}public static <T> WebResult<T> wrong() {return new WebResult<>(SysType.WEB_RESULT_WRONG, "操作失败!");}public static <T> WebResult<T> init(int code, String msg) {return new WebResult<>(code, msg);}public static <T> WebResult<T> wrong(String msg) {return new WebResult<>(SysType.WEB_RESULT_WRONG, msg);}public WebResult<T> alert(String msg) {this.setMsgType(SysType.WEB_RESULT_MSG_ALERT);this.setMsg(msg);return this;}public WebResult<T> alert(String msg, String yes) {this.setMsgType(SysType.WEB_RESULT_MSG_ALERT);this.setMsg(msg);return this;}public static <T> WebResult<T> confirm(String msg) {return new WebResult<T>().setMsgType(SysType.WEB_RESULT_MSG_CONFIRM).setMsg(msg);}public static <T> WebResult<T> setErrorCode(ErrorCode errorCode) {return WebResult.<T>wrong().setErrorCode(errorCode.getErrorCode()).setMsg(errorCode.getErrorMsg());}public WebResult<T> question(String msg, String yes) {this.setMsgType(SysType.WEB_RESULT_MSG_QUESTION);this.setMsg(msg);return this;}public WebResult<T> put(String key, Object val) {if (this.data == null) {this.data = (T) new HashMap<String, Object>();}((Map<String, Object>)this.data).put(key, val);return this;}public WebResult<T> putAll(Object object) {if (this.data == null) {this.data = (T) new HashMap<String, Object>();}if (object instanceof Map) {((Map<String, Object>)this.data).putAll((Map)object);} else {Map<String, Object> paramMap = JsonUtil.fromJsonToMap(JsonUtil.toJson(object));((Map<String, Object>)this.data).putAll(paramMap);}return this;}public  WebResult<T> setMainMessage(String msg) {return setMsg(msg);}public  WebResult<T> setMessageType(int msgType) {return setMsgType(msgType);}public WebResult<T> relaod(String mes) {return this.alert(mes,"$reloadPage");}}

三、创建全局异常处理配置

3.1BusinessException

创建自定义异常类BusinessException继承RuntimeException

package com.murg.bootdemo.exception;/*** 业务级异常***/
@SuppressWarnings("serial")
public class BusinessException extends RuntimeException {private String errMsg;private int errCode = -1;public BusinessException(Throwable cause) {}public BusinessException() {}public BusinessException(final String message, final Throwable cause) {super(message, cause);this.errMsg = message;}public BusinessException(ErrorCode errorCode) {this.errCode = errorCode.getErrorCode();this.errMsg = errorCode.getErrorMsg();}public BusinessException(String errMsg) {this.errMsg = errMsg;}public BusinessException(int errCode) {this.errCode = errCode;}public BusinessException(String errMsg, int errCode) {this.errMsg = errMsg;this.errCode = errCode;}@Overridepublic Throwable fillInStackTrace() {return this;}public String getErrMsg() {return errMsg;}public BusinessException setErrMsg(String errMsg) {this.errMsg = errMsg;return this;}public int getErrCode() {return errCode;}public BusinessException setErrCode(int errCode) {this.errCode = errCode;return this;}@Overridepublic String getMessage() {return errMsg;}}

3.2自定义ErrorCode

package com.murg.bootdemo.exception;import lombok.Getter;
import lombok.RequiredArgsConstructor;/***/
@Getter
@RequiredArgsConstructor
public enum ErrorCode {ERROR_CODE_400(400, "参数异常!"),;private final int errorCode;private final String errorMsg;
}

3.3自定义ExceptionUtil,获取堆栈信息

package com.murg.bootdemo.util;import java.io.PrintWriter;
import java.io.StringWriter;/*** Description: 系统异常处理*/
public class ExceptionUtil {/*** 获取完整的堆栈信息* @param throwable* @return*/public static String getStackTrace(Throwable throwable) {StringWriter sw = new StringWriter();PrintWriter pw = new PrintWriter(sw, true);throwable.printStackTrace(pw);return sw.getBuffer().toString();}/*** 获取异常堆栈信息 - 指定长度* @param throwable* @param size* @return*/public static String getStackTrace(Throwable throwable,int size) {String stac = getStackTrace(throwable);if (stac.length() > size) {stac = stac.substring(0, size);}return stac;}
}

3.4数据库创建表MySysException,用于以后将错误信息记录

package com.murg.bootdemo.exception.po;import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.KeySequence;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import io.swagger.annotations.ApiModel;
import lombok.Getter;
import lombok.Setter;import java.io.Serializable;
import java.math.BigDecimal;
import java.util.Date;/***/
@Getter
@Setter
@TableName("MY_SYS_EXCEPTION")
@KeySequence("MY_SYS_EXCEPTION_SEQ")
public class MySysException implements Serializable {private static final long serialVersionUID = 1L;@TableId(value = "EXCEPTIONID", type = IdType.INPUT)private BigDecimal exceptionid;private String userid;private String functionid;private String requesturl;private String requestparams;private Date exceptiondate;private Long exceptiontype;private Long exceptioncode;private String exceptionmsg;private String exceptionstac;}

 3.5最后通过@ControllerAdvice创建一个全局异常的配置类ExceptionConfig 

package com.murg.bootdemo.config;import com.murg.bootdemo.common.WebResult;
import com.murg.bootdemo.exception.BusinessException;
import com.murg.bootdemo.exception.ErrorCode;
import com.murg.bootdemo.exception.po.MySysException;
import com.murg.bootdemo.util.ExceptionUtil;
import com.murg.bootdemo.util.JsonUtil;
import io.jsonwebtoken.ExpiredJwtException;
import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j;
import org.apache.commons.lang3.StringUtils;
import org.springframework.http.HttpStatus;
import org.springframework.validation.BindingResult;
import org.springframework.web.bind.MethodArgumentNotValidException;
import org.springframework.web.bind.annotation.ControllerAdvice;
import org.springframework.web.bind.annotation.ExceptionHandler;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.ResponseStatus;
import org.springframework.web.servlet.NoHandlerFoundException;
import javax.servlet.http.HttpServletRequest;
import javax.validation.ConstraintViolation;
import javax.validation.ConstraintViolationException;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;/*** 公共全局异常处理*/
@ControllerAdvice
@ResponseBody
@Slf4j
@RequiredArgsConstructor
public class ExceptionConfig {private final String defaultMessage = "系统出错,请与系统管理员联系!";private final Long EXCEPTION_CONTROLLER = 1L;private final Long EXCEPTION_SERVICE = 2L;@ExceptionHandler(BusinessException.class)public WebResult<Object> businessExceptionHandler(BusinessException businessException) {return new WebResult<>().alert(StringUtils.defaultString(businessException.getMessage(), defaultMessage)).setErrorCode(businessException.getErrCode());}@ExceptionHandler(MethodArgumentNotValidException.class)public WebResult<Object> handler(MethodArgumentNotValidException e) {log.error(e.getMessage(), e);BindingResult bindingResult = e.getBindingResult();List<Map<String, String>> collect = bindingResult.getAllErrors().stream().map(objectError -> {ConstraintViolation<?> unwrap = objectError.unwrap(ConstraintViolation.class);Map<String, String> map = new HashMap<>(3);map.put("property", unwrap.getPropertyPath().toString());map.put("message", objectError.getDefaultMessage());return map;}).collect(Collectors.toList());return WebResult.setErrorCode(ErrorCode.ERROR_CODE_400).setData(collect).alert("参数错误!");}//处理请求参数格式错误 @RequestParam上validate失败后抛出的异常是javax.validation.ConstraintViolationException@ExceptionHandler(ConstraintViolationException.class)public WebResult<Object> handler(ConstraintViolationException e) {log.error(e.getMessage(), e);List<Map<String, String>> collect = e.getConstraintViolations().stream().map(constraintViolation -> {Map<String, String> map = new HashMap<>(3);map.put("property", constraintViolation.getPropertyPath().toString());map.put("message", constraintViolation.getMessage());return map;}).collect(Collectors.toList());return WebResult.setErrorCode(ErrorCode.ERROR_CODE_400).setData(collect).alert("参数错误!");}@ExceptionHandler(Exception.class)public WebResult<Object> exceptionHandler(Exception exception, HttpServletRequest request) {log.error("系统错误", exception);// 简单记录下错误日志(复制的his表结构以及逻辑,后续应该会做调整)errorLogRecord(request, exception);return WebResult.wrong().alert(StringUtils.defaultString(exception.getMessage(), defaultMessage));}@ExceptionHandler(ExpiredJwtException.class)public WebResult<Object> exceptionHandler(ExpiredJwtException exception, HttpServletRequest request) {log.error("token解析错误", exception);WebResult<Object> webResult = WebResult.ok();webResult.isWrong("您可能未登录或登录超时,请重新登陆!");// 简单记录下错误日志(复制的his表结构以及逻辑,后续应该会做调整)errorLogRecord(request, exception);return webResult;}@ExceptionHandler(NoHandlerFoundException.class)@ResponseStatus(value = HttpStatus.NOT_FOUND)public WebResult<Object> handleNotFoundError(NoHandlerFoundException ex) {return WebResult.wrong("接口不存在!");}private void errorLogRecord(HttpServletRequest request, Exception e) {try {MySysException sysException = new MySysException();//异常类型sysException.setExceptiontype(EXCEPTION_CONTROLLER);//请求地址String basePath = request.getScheme() + "://" + request.getServerName() + ":" + request.getServerPort() + request.getContextPath();sysException.setRequesturl(basePath);//请求参数Map<String, String[]> params = new HashMap<>(request.getParameterMap());String param = JsonUtil.toJson(params);if (param.length() > 1800) {param = param.substring(0, 1800);}sysException.setRequestparams(param);//时间sysException.setExceptiondate(new Date());//异常信息String msg = e.getMessage();if (StringUtils.length(msg) > 200) {msg = msg.substring(0, 200);}sysException.setExceptionmsg(msg);//堆栈信息sysException.setExceptionstac(ExceptionUtil.getStackTrace(e, 1000));//后续正式的话保存信息//MySysExceptionMapper.insert(sysException);} catch (Exception exception) {//不处理log.error("拦截异常保存失败:" + exception.getMessage());}}}
package com.murg.bootdemo.util;import java.io.PrintWriter;
import java.io.StringWriter;/*** Description: 系统异常处理*/
public class ExceptionUtil {/*** 获取完整的堆栈信息* @param throwable* @return*/public static String getStackTrace(Throwable throwable) {StringWriter sw = new StringWriter();PrintWriter pw = new PrintWriter(sw, true);throwable.printStackTrace(pw);return sw.getBuffer().toString();}/*** 获取异常堆栈信息 - 指定长度* @param throwable* @param size* @return*/public static String getStackTrace(Throwable throwable,int size) {String stac = getStackTrace(throwable);if (stac.length() > size) {stac = stac.substring(0, size);}return stac;}
}

四、改造getTt26接口返回统一返回值

package com.murg.bootdemo.business.controller;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.murg.bootdemo.business.entity.Tt26;
import com.murg.bootdemo.business.service.Tt26Service;
import com.murg.bootdemo.common.WebResult;
import lombok.RequiredArgsConstructor;
import org.springframework.http.*;
import org.springframework.web.bind.annotation.*;
import org.springframework.web.client.RestTemplate;
import java.util.HashMap;
import java.util.Map;@RequiredArgsConstructor
@RestController
public class TestRestController {private final RestTemplate restTemplate;private final Tt26Service tt26Service;@RequestMapping(value = "/getTt26", method = RequestMethod.GET)public WebResult getTt26(@RequestParam String code){//通过不同的id获取不同的namereturn WebResult.ok(tt26Service.getOne(Wrappers.<Tt26>lambdaQuery().eq(Tt26::getCode,code)));}}

出参结果

五、创建测试Controller测试全局异常 

package com.murg.bootdemo.business.controller;import com.murg.bootdemo.exception.BusinessException;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;@RestController
public class TestExceptionController {//Get接口主要是用来获取信息的接口@RequestMapping(value = "/testbusiexception", method = RequestMethod.GET)public String testbussexception(){throw new BusinessException("测试全局异常拦截");}//Get接口主要是用来获取信息的接口@RequestMapping(value = "/testexception", method = RequestMethod.GET)public String testexception() throws Exception {throw new Exception("测试全局异常拦截2");}}

接口访问自主抛出异常的接口看返回结果

相关文章:

从0开始搭建一个生产级SpringBoot2.0.X项目(三)SpringBoot接口统一返回和全局异常处理

前言 最近有个想法想整理一个内容比较完整springboot项目初始化Demo。 SpringBoot接口统一返回和全局异常处理&#xff0c;使用ControllerAdvice ExceptionHandler 的组合来实现。 一、pom文件新增依赖 <dependency><groupId>com.alibaba</groupId><ar…...

Mybatis-plus-扩展功能

Mybatis-plus-扩展功能 一&#xff1a;代码生成器 AutoGenerator 是 MyBatis-Plus 的代码生成器&#xff0c;通过 AutoGenerator 可以快速生成 Entity、Mapper、Mapper XML、Service、Controller 等各个模块的代码&#xff0c;极大的提升了开发效率。 功能的演示&#xff1a…...

【AI辅助】AWS Toolkit+AmazonQ

#偶然看到网上某up主用的这个AI工具&#xff0c;感觉还挺实用的&#xff0c;推荐大家~我们不可阻挡AI的攻势&#xff0c;但是成为利用它的人&#xff0c;也是反侵占的方式呢# AWS toolkit Amazon Q 安装 VScode--Extensions--搜索工具--安装 安装后&#xff0c;工具栏会多出对…...

云手机简述(概况,使用场景,自己部署云手机)

背景 最近经常会看到云手机的相关广告&#xff0c;手痒难耐&#xff0c;了解一下。 我的主要需求&#xff1a; Android 已 root&#xff0c;能够做一些自动化等高级功能。能够通过 远程adb 控制手机。能够尽量的少花钱&#xff0c;最好是能够提供动态创建删除手机的方式&…...

Java已死,大模型才是未来?

作者&#xff1a;不惑_ 引言 在数字技术的浪潮中&#xff0c;编程语言始终扮演着至关重要的角色。Java&#xff0c;自1995年诞生以来&#xff0c;便以其跨平台的特性和丰富的生态系统&#xff0c;成为了全球范围内开发者们最为青睐的编程语言之一 然而&#xff0c;随着技术的…...

NCCL安装(Ubuntu等)

目录 一、NCCL的定义二、安装NCCL的原因1、加速多GPU通信2、支持流行的深度学习框架3、提高计算效率4、易于使用和集成5、可扩展性 三、NCCL安装方法1、下载安装包2、更新APT数据库3、使用APT安装libnccl2包&#xff0c;另外&#xff0c;如果需要使用NCCL编译应用程序&#xff…...

加载视频显示 - python 实现

#-*-coding:utf-8-*- # date:2021-03-21 # Author: DataBall - Xian # Function: 加载视频并显示import cv2 if __name__ "__main__":#加载视频cap cv2.VideoCapture(./video/1.mp4)while True:ret, img cap.read()# 获取相机图像if ret True:# 如果 ret 返回值为…...

数据结构模拟题[五]

数据结构试卷&#xff08;五&#xff09; 一、选择题 (20 分) 1&#xff0e;数据的最小单位是&#xff08; &#xff09;。 (A) 数据项 (B) 数据类型 (C) 数据元素 (D) 数据变量 2&#xff0e;设一组初始记录关键字序列为 (50 &#xff0c;40&#xff0c; 95&#xff0c;20…...

IDEA切换窗口快捷键失效

问题描述&#xff1a; 在idea中&#xff0c;如果切换窗口的快捷键&#xff08;Alt Tab&#xff09;失效了&#xff0c;可以通过清除缓存的方式修复...

QT中使用图表之QChart绘制X轴为日期时间轴的折线图

显然X轴是日期时间轴的话&#xff0c;那么我们使用的轴类就得是QDateTimeAxis QChart中日期时间轴的精度是毫秒 因此图表里面的数据的x值需要是一个毫秒数&#xff0c;才能显示出来 --------------------------------------------------------------------------------------…...

【传知代码】短期电力负荷(论文复现)

&#x1f351;个人主页&#xff1a;Jupiter. &#x1f680; 所属专栏&#xff1a;传知代码 欢迎大家点赞收藏评论&#x1f60a; 目录 备注前言介绍问题背景复现&#xff1a;一. 多维特征提取的提取框架&#xff1a;二. 论文中进行性能测试的MultiTag2Vec-STLF模型&#xff1a;三…...

ubuntu20.04 加固方案-设置重复登录失败后锁定时间限制

一、编辑PAM配置文件 打开终端。 使用文本编辑器&#xff08;如vim&#xff09;编辑/etc/pam.d/common-auth文件。 sudo vim /etc/pam.d/common-auth 二、添加配置参数 在打开的配置文件中&#xff0c;添加或修改以下参数&#xff1a; auth required pam_tally2.so deny5 un…...

【综合算法学习】(第十三篇)

目录 解数独&#xff08;hard&#xff09; 题目解析 讲解算法原理 编写代码 单词搜索&#xff08;medium&#xff09; 题目解析 解析算法原理 编写代码 解数独&#xff08;hard&#xff09; 题目解析 1.题目链接&#xff1a;. - 力扣&#xff08;LeetCode&#xff09;…...

Web3 Key Talking #4|Sui有何不同?及其发展路线图

活动时间&#xff1a; 2024 年 10 月 31 日&#xff08;周四&#xff09;20:00–21:00&#xff08;UTC8&#xff09; 会议链接&#xff1a; 腾讯会议 会议 ID &#xff1a;429–339–777 主持&#xff1a;Sanzhisanzhichazi1 嘉宾&#xff1a;uvdwangtxxl&#xff0c;Sui …...

Axios 请求超时设置无效的问题及解决方案

文章目录 Axios 请求超时设置无效的问题及解决方案1. 引言2. 理解 Axios 的超时机制2.1 Axios 超时的工作原理2.2 超时错误的处理 3. Axios 请求超时设置无效的常见原因3.1 配置错误或遗漏3.2 超时发生在建立连接之前3.3 使用了不支持的传输协议3.4 代理服务器或中间件干扰3.5 …...

数据结构+算法

一、数据结构 1、线性结构 数组&#xff1a; 访问&#xff1a;O(1)访问特定位置的元素&#xff1b;插入&#xff1a;O(n)最坏的情况发生在插入发生在数组的首部并需要移动所有元素时&#xff1b;删除&#xff1a;O(n)最坏的情况发生在删除数组的开头发生并需要移动第一元素后…...

利用ExcelJS封装一个excel表格的导出

ExcelJS 操作和写入Excel 文件。 直接上代码&#xff0c;js部分&#xff1a; exportFn.js import ExcelJS from exceljs; import { saveAs } from file-saver;export function exportExcleUtils(tHeader, filterVal, listData, fileName) {//设置工作簿属性const workbook ne…...

AI 原生时代,更要上云:百度智能云云原生创新实践

本文整理自百度云智峰会 2024 —— 云原生论坛的同名演讲。 我今天分享的主题&#xff0c;是谈谈在云计算和 AI 技术快速发展和深入落地的背景下&#xff0c;百度智能云在云原生的基础设施产品和技术层面做的一些创新实践。 毋庸置疑&#xff0c;过去十几年云计算和 AI 技术是…...

C语言程序编译运行

程序功能&#xff1a;使用 printf() 输出 “Hello, World!”。 C语言源程序&#xff1a; #include <stdio.h> int main() {// printf() 中字符串需要引号printf("Hello, World!");return 0; }编译过程&#xff1a; vim hello.c gcc hello.c -o hello ./hell…...

视频点播系统扩展示例

更多的前端页面&#xff08;如视频详情页、用户注册页等&#xff09;。更复杂的业务逻辑&#xff08;如视频评论、搜索功能等&#xff09;。安全性和权限管理&#xff08;如用户角色管理、权限控制等&#xff09;。其他技术细节&#xff08;如文件上传、分页查询等&#xff09;…...

echo $? —— Linux 中的退出状态码详解

在 Linux 系统中&#xff0c;echo $? 是一个非常重要的命令&#xff0c;用于显示上一条命令的退出状态码。这个小小的符号组合可以帮助我们判断命令是否成功执行&#xff0c;同时也为编写自动化脚本提供了基础支持。本文将详细介绍 echo $? 的用法及其在实际开发中的应用。 …...

heic格式转化jpg最简单方法?快来学习这几种简单的转换方法!

heic格式转化jpg最简单方法&#xff1f;在当今的数字图像处理领域&#xff0c;HEIC格式以其卓越的压缩效率和高质量图像表现&#xff0c;正逐渐崭露头角并受到业界的深切关注&#xff0c;HEIC格式凭借先进的压缩技术&#xff0c;成功地在保持图像清晰度的同时&#xff0c;大幅度…...

力扣(leetcode)每日一题 3259 超级饮料的最大强化能量|动态规划

3259. 超级饮料的最大强化能量 题干 来自未来的体育科学家给你两个整数数组 energyDrinkA 和 energyDrinkB&#xff0c;数组长度都等于 n。这两个数组分别代表 A、B 两种不同能量饮料每小时所能提供的强化能量。 你需要每小时饮用一种能量饮料来 最大化 你的总强化能量。然而…...

Webserver(2.7)内存映射

目录 内存映射内存映射相关系统调用内存映射的注意事项如果对mmap的返回值(ptr)做操作&#xff0c;释放内存&#xff08;munmap&#xff09;是否能够成功&#xff1f;如果open时O_RDONLY&#xff0c;mmap时prot参数指定PROT_READ | PROT_WRITE会怎样&#xff1f;如果文件偏移量…...

vue3父子组件传值,子组件暴漏方法

1.父传子 defineProps 父组件直接通过属性绑定的方式给子组件绑定数据&#xff0c;子组件通过defineProps接收函数接收 其中v-model是完成事件绑定和事件监听的语法糖。v-model算是v-bind和v-on的简洁写法&#xff0c;等价于 <c-input ref"inputRef" :modelValue…...

Linux_04 Linux常用命令——tar

一、命令格式 tar [选项] [归档文件] [要处理的文件或目录]1、选项 c创建归档文件x解压缩归档文件z使用gzipj使用bzip2v处理过程显示信息f指定归档文件名称 2、归档文件-可指定目录及文件名 /home/wang.tar.gz 3、要处理的文件或目录 /home/study1/wang 二、常见命令 t…...

Java项目实战II基于Java+Spring Boot+MySQL的编程训练系统(源码+数据库+文档)

目录 一、前言 二、技术介绍 三、系统实现 四、文档参考 五、核心代码 六、源码获取 全栈码农以及毕业设计实战开发&#xff0c;CSDN平台Java领域新星创作者&#xff0c;专注于大学生项目实战开发、讲解和毕业答疑辅导。获取源码联系方式请查看文末 一、前言 在当今数字…...

Rust:文档注释 //! 和 ///

在 Rust 编程语言中&#xff0c;//! 是一种特殊的文档注释&#xff08;documentation comment&#xff09;。它用于为整个模块、结构体、枚举、函数或其他项提供文档说明。与单行注释 // 和多行注释 /* ... */ 不同&#xff0c;//! 和 ///&#xff08;用于紧跟在项之前的文档注…...

练习LabVIEW第二十七题

学习目标&#xff1a; 刚学了LabVIEW&#xff0c;在网上找了些题&#xff0c;练习一下LabVIEW&#xff0c;有不对不好不足的地方欢迎指正&#xff01; 第二十七题&#xff1a; 创建一个VI程序模拟温度测量。假设传感器输出电压与温度成正比。例如&#xff0c;当温度为70F时&…...

使用React构建现代Web应用

&#x1f496; 博客主页&#xff1a;瑕疵的CSDN主页 &#x1f4bb; Gitee主页&#xff1a;瑕疵的gitee主页 &#x1f680; 文章专栏&#xff1a;《热点资讯》 使用React构建现代Web应用 1 引言 2 React简介 3 安装React 4 创建React项目 5 设计应用结构 6 创建组件 7 使用组件…...