最新要闻
- 硬件博主自费实测5大旗舰手机信号:iPhone各种被狂虐
- 焦点热文:载亿万富翁观光潜艇失联 被曝用游戏手柄操控 专家:生还希望渺茫
- 电动汽车也能无线充电了:像手机一样简单 超大充电板长这模样
- 全球热议:微软停止涨薪影响明显:员工跳槽意愿上涨23%
- 11499元 三星首款5K专业显示器上架:配可拆卸4K摄像头
- 班主任和家长扮恐龙接中考生 现场让网友看笑:可爱的显眼包 全球信息
- 史上最深深海救援!观光潜艇失联:搜救无进展 氧气剩不多、或卡残骸中|全球讯息
- 俄妹COS《塞尔达》公主火了 性感美艳:欧美曾呼吁塞尔达公主应黑人|时快讯
- 环球热文:破75%了!理想汽车家用交流充电桩安装率遥遥领先
- 比亚迪赵长江:腾势N7领先两代 将成为家用和年轻人首选大五座标杆SUV
- 全球短讯!年轻人第一辆车!“小米汽车”非官方渲染图又来了:质感拉满 你会买吗
- 世界即时:AMD Zen4c 128核心偷跑:只要4万元 不到官价一半
- 游客新疆旅游拍下雪崩全过程:壮观至极 众人尖叫_世界热文
- 【环球新视野】孟晚舟亲自站台!华为新杀手锏能否打破国际垄断?
- 耶鲁大学华裔学生驾车身亡:父母获赔2.5亿元_世界通讯
- 全球快看点丨观光泰坦尼克号潜艇失联:将是史上最深深海救援 将近4000米
手机
iphone11大小尺寸是多少?苹果iPhone11和iPhone13的区别是什么?
警方通报辅警执法直播中被撞飞:犯罪嫌疑人已投案
- iphone11大小尺寸是多少?苹果iPhone11和iPhone13的区别是什么?
- 警方通报辅警执法直播中被撞飞:犯罪嫌疑人已投案
- 男子被关545天申国赔:获赔18万多 驳回精神抚慰金
- 3天内26名本土感染者,辽宁确诊人数已超安徽
- 广西柳州一男子因纠纷杀害三人后自首
- 洱海坠机4名机组人员被批准为烈士 数千干部群众悼念
家电
网站怎么接入微信扫码支付?|焦点快报
第01章-准备工作
1、微信支付产品介绍
参考资料:产品中心 - 微信支付商户平台 (qq.com)
付款码支付、JSAPI支付、小程序支付、Native支付、APP支付、刷脸支付
1.1、付款码支付
用户展示微信钱包内的“付款码”给商家,商家扫描后直接完成支付,适用于线下面对面收银的场景。
1.2、JSAPI支付
- 线下场所:商户展示一个支付二维码,用户使用微信扫描二维码后,输入需要支付的金额,完成支付。
- 公众号场景:用户在微信内进入商家公众号,打开某个页面,选择某个产品,完成支付。
- PC网站场景:在网站中展示二维码,用户使用微信扫描二维码,输入需要支付的金额,完成支付。
特点:用户在客户端输入支付金额
1.3、小程序支付
在微信小程序平台内实现支付的功能。
1.4、Native支付
Native支付是指商户展示支付二维码,用户再用微信“扫一扫”完成支付的模式。这种方式适用于PC网站。
特点:商家预先指定支付金额
1.5、APP支付
商户通过在移动端独立的APP应用程序中集成微信支付模块,完成支付。
1.6、刷脸支付
用户在刷脸设备前通过摄像头刷脸、识别身份后进行的一种支付方式。
2、接口版本
微信支付企业主流的API版本有v2和v3,课程中我们使用微信支付APIv3。
V2和V3的比较
相比较而言,APIv2比APIv3安全性更高,但是APIv2中有一些功能在APIv3中尚未完整实现,具体参考如下API字典页面:API字典概览 | 微信支付商户平台文档中心 (qq.com)
3、接入指引
3.1、获取开发参数
如果需要独立申请和开通微信支付功能,可以参考如下官方文档。开通微信支付后,才能获取相关的开发参数以及商户公钥和商户私钥文件。
参考资料:微信支付接入指引 - 微信支付商户平台 (qq.com)
3.2、配置开发参数
在service-order
服务的resources目录中创建wxpay.properties
这个文件定义了在“接入指引”的步骤中我们提前准备的微信支付相关的参数,例如商户号、APPID、API秘钥等等
# 微信支付相关参数wxpay: mch-id: 1558950191 #商户号 mch-serial-no: 34345964330B66427E0D3D28826C4993C77E631F # 商户API证书序列号 private-key-path: D:/project/yygh/cert/apiclient_key.pem # 商户私钥文件 api-v3-key: UDuLFDcmy5Eb6o0nTNZdu6ek4DDh4K8B # APIv3密钥 appid: wx74862e0dfcf69954 # APPID notify-url: https://7d92-115-171-63-135.ngrok.io/api/order/wxpay/payment/notify # 接收支付结果通知地址 notify-refund-url: http://agxnyzl04y90.ngrok.xiaomiqiu123.top/api/order/wxpay/refunds/notify # 接收退款结果通知地址
3.3、复制商户私钥
将商户私钥文件复制到配置文件指定的目录下:
资料:资料>微信支付>商户证书>apiclient_key.pem
private-key-path: D:/project/yygh/cert/apiclient_key.pem # 商户私钥文件
3.4、证书密钥使用说明(了解)
参考文档:APIv3证书与密钥使用说明
一个完整的请求和响应的流程:
- 商户使用商户私钥对请求进行签名,发送给微信支付平台,平台使用商户公钥进行签名验证。
- 微信支付平台使用平台私钥对响应进行签名,商户使用微信支付平台公钥对响应进行验签。
第02章-订单支付
1、微信支付平台证书的获取
1.1、引入SDK
参考文档:SDK&工具
我们可以使用官方提供的 SDK wechatpay-java
在service-order微服务中添加依赖:
com.github.wechatpay-apiv3 wechatpay-java 0.2.6
1.2、读取支付参数
在config 包中 创建 WxPayConfig.java
package com.atguigu.syt.order.config;@Configuration@PropertySource("classpath:wxpay.properties") //读取配置文件@ConfigurationProperties(prefix="wxpay") //读取wxpay节点@Datapublic class WxPayConfig { // 商户号 private String mchId; // 商户API证书序列号 private String mchSerialNo; // 商户私钥文件 private String privateKeyPath; // APIv3密钥 private String apiV3Key; // APPID private String appid; // 接收支付结果通知地址 private String notifyUrl; // 接收退款结果通知地址 private String notifyRefundUrl; }
1.3、自动更新微信支付平台证书
在 API 请求过程中,客户端需使用微信支付平台证书,验证服务器应答的真实性和完整性。我们使用自动更新平台证书的配置类 RSAAutoCertificateConfig
。每个商户号只能创建一个 RSAAutoCertificateConfig
。
在WxPayConfig
中添加如下方法:
/** * 获取微信支付配置对象 * @return */@Beanpublic RSAAutoCertificateConfig getConfig(){ return new RSAAutoCertificateConfig.Builder() .merchantId(mchId) .privateKeyFromPath(privateKeyPath) .merchantSerialNumber(mchSerialNo) .apiV3Key(apiV3Key) .build();}
RSAAutoCertificateConfig
通过 RSAAutoCertificateProvider
自动下载微信支付平台证书。 同时,RSAAutoCertificateProvider
会启动一个后台线程,定时更新证书(目前设计为60分钟),以实现证书过期时的新老证书平滑切换。
常见错误:引入商户私钥后如果项目无法启动,则需要升级JDK版本,并重新配置idea编译和运行环境到最新版本的JDK。建议升级到1.8.0_300以上
2、生成支付二维码
2.1、Native支付流程
参考文档:业务流程时序图
2.2、Controller
在service-order中创建FrontWXPayController
package com.atguigu.syt.order.controller.front;@Api(tags = "微信支付接口")@RestController@RequestMapping("/front/order/wxpay")public class FrontWXPayController { @Resource private WxPayService wxPayService; @Resource private AuthContextHolder authContextHolder; @ApiOperation("获取支付二维码url") @ApiImplicitParam(name = "outTradeNo",value = "订单号", required = true) @GetMapping("/auth/nativePay/{outTradeNo}") public Result nativePay(@PathVariable String outTradeNo, HttpServletRequest request, HttpServletResponse response) { //校验用户登录状态 authContextHolder.checkAuth(request, response); String codeUrl = wxPayService.createNative(outTradeNo); return Result.ok(codeUrl); }}
2.3、Service
SDK参考代码:wechatpay-java/NativePayServiceExample.java at main · wechatpay-apiv3/wechatpay-java · GitHub
具体代码示例如下:
Native下单API参数参考:Native下单API
接口:OrderInfoService
/** * 根据订单号获取订单 * @param outTradeNo * @return */OrderInfo selectByOutTradeNo(String outTradeNo);
实现:OrderInfoServiceImpl
@Overridepublic OrderInfo selectByOutTradeNo(String outTradeNo) { LambdaQueryWrapper queryWrapper = new LambdaQueryWrapper<>(); queryWrapper.eq(OrderInfo::getOutTradeNo, outTradeNo); return baseMapper.selectOne(queryWrapper);}
接口:WxPayService
package com.atguigu.syt.order.service;public interface WxPayService { /** * 获取支付二维码utl * @param outTradeNo * @return */ String createNative(String outTradeNo);}
实现:WxPayServiceImpl
package com.atguigu.syt.order.service.impl;@Service@Slf4jpublic class WxPayServiceImpl implements WxPayService { @Resource private RSAAutoCertificateConfig rsaAutoCertificateConfig; @Resource private WxPayConfig wxPayConfig; @Resource private OrderInfoService orderInfoService; @Override public String createNative(String outTradeNo) { // 初始化服务 NativePayService service = new NativePayService.Builder().config(rsaAutoCertificateConfig).build(); // 调用接口 try { //获取订单 OrderInfo orderInfo = orderInfoService.selectByOutTradeNo(outTradeNo); PrepayRequest request = new PrepayRequest(); // 调用request.setXxx(val)设置所需参数,具体参数可见Request定义 request.setAppid(wxPayConfig.getAppid()); request.setMchid(wxPayConfig.getMchId()); request.setDescription(orderInfo.getTitle()); request.setOutTradeNo(outTradeNo); request.setNotifyUrl(wxPayConfig.getNotifyUrl()); Amount amount = new Amount(); //amount.setTotal(orderInfo.getAmount().multiply(new BigDecimal(100)).intValue()); amount.setTotal(1);//1分钱 request.setAmount(amount); // 调用接口 PrepayResponse prepayResponse = service.prepay(request); return prepayResponse.getCodeUrl(); } catch (HttpException e) { // 发送HTTP请求失败 // 调用e.getHttpRequest()获取请求打印日志或上报监控,更多方法见HttpException定义 log.error(e.getHttpRequest().toString()); throw new GuiguException(ResultCodeEnum.FAIL); } catch (ServiceException e) { // 服务返回状态小于200或大于等于300,例如500 // 调用e.getResponseBody()获取返回体打印日志或上报监控,更多方法见ServiceException定义 log.error(e.getResponseBody()); throw new GuiguException(ResultCodeEnum.FAIL); } catch (MalformedMessageException e) { // 服务返回成功,返回体类型不合法,或者解析返回体失败 // 调用e.getMessage()获取信息打印日志或上报监控,更多方法见MalformedMessageException定义 log.error(e.getMessage()); throw new GuiguException(ResultCodeEnum.FAIL); } }}
可见,使用 SDK 并不需要计算请求签名和验证应答签名。
3、前端整合
3.1、api
创建api/wxpay.js
import request from "~/utils/request"export default { //获取支付二维码url nativePay(outTradeNo) { return request({ url: `/front/order/wxpay/auth/nativePay/${outTradeNo}`, method: "get" }) },}
3.2、修改show.vue
引入api
import wxpayApi from "~/api/wxpay"
添加data数据
codeUrl: null, //微信支付二维码isPayShow: false, //不显示登录二维码组件payText: "支付"
修改按钮
将
修改为
添加方法
//支付pay() { //防止重复提交 if(this.isPayShow) return this.isPayShow = true this.payText = "支付中....." //显示二维码 wxpayApi.nativePay(this.orderInfo.outTradeNo).then((response) => { this.codeUrl = response.data this.dialogPayVisible = true })},//关闭对话框closeDialog(){ //恢复支付按钮 this.isPayShow = false this.payText = "支付"}
用二维码组件替换img图片
替换成
第03章-查询支付结果
1、支付查单
参考文档:微信支付查单接口
商户可以主动调用微信支付查单接口,同步订单状态。
调用查询订单接口,如果支付成功则更新订单状态
并添加交易记录
,如果支付尚未成功则轮询查单
1.1、更新订单状态
OrderInfoService接口
/** * 根据订单号更新订单状态 * @param outTradeNo * @param status */void updateStatus(String outTradeNo, Integer status);
OrderInfoServiceImpl实现
@Overridepublic void updateStatus(String outTradeNo, Integer status) { LambdaQueryWrapper queryWrapper = new LambdaQueryWrapper<>(); queryWrapper.eq(OrderInfo::getOutTradeNo, outTradeNo); OrderInfo orderInfo = new OrderInfo(); orderInfo.setOrderStatus(status); baseMapper.update(orderInfo, queryWrapper);}
1.2、添加交易记录
PaymentInfoService接口
/** * 保存交易记录 * @param orderInfo * @param transaction */void savePaymentInfo(OrderInfo orderInfo, Transaction transaction);
实现:PaymentInfoServiceImpl
@Overridepublic void savePaymentInfo(OrderInfo orderInfo, Transaction transaction) { PaymentInfo paymentInfo = new PaymentInfo(); paymentInfo.setOrderId(orderInfo.getId()); paymentInfo.setPaymentType(PaymentTypeEnum.WEIXIN.getStatus()); paymentInfo.setOutTradeNo(orderInfo.getOutTradeNo());//数据库字段的长度改成32 paymentInfo.setSubject(orderInfo.getTitle()); paymentInfo.setTotalAmount(orderInfo.getAmount()); paymentInfo.setPaymentStatus(PaymentStatusEnum.PAID.getStatus()); paymentInfo.setTradeNo(transaction.getTransactionId()); paymentInfo.setCallbackTime(new Date()); paymentInfo.setCallbackContent(transaction.toString()); baseMapper.insert(paymentInfo);}
1.3、查单Controller
FrontWXPayController
@ApiOperation("查询支付状态")@ApiImplicitParam(name = "outTradeNo",value = "订单id", required = true)@GetMapping("/queryPayStatus/{outTradeNo}")public Result queryPayStatus(@PathVariable String outTradeNo) { //调用查询接口 boolean success = wxPayService.queryPayStatus(outTradeNo); if (success) { return Result.ok().message("支付成功"); } return Result.ok().message("支付中").code(250);}
1.4、查单Service
接口:WxPayService
/** * 查询订单支付状态 * @param outTradeNo * @return */boolean queryPayStatus(String outTradeNo);
实现:WxPayServiceImpl
@Resourceprivate PaymentInfoService paymentInfoService;@Overridepublic boolean queryPayStatus(String outTradeNo) { // 初始化服务 NativePayService service = new NativePayService.Builder().config(rsaAutoCertificateConfig).build(); // 调用接口 try { QueryOrderByOutTradeNoRequest request = new QueryOrderByOutTradeNoRequest(); // 调用request.setXxx(val)设置所需参数,具体参数可见Request定义 request.setOutTradeNo(outTradeNo); request.setMchid(wxPayConfig.getMchId()); // 调用接口 Transaction transaction = service.queryOrderByOutTradeNo(request); Transaction.TradeStateEnum tradeState = transaction.getTradeState(); //支付成功 if(tradeState.equals(Transaction.TradeStateEnum.SUCCESS)){ OrderInfo orderInfo = orderInfoService.selectByOutTradeNo(outTradeNo); //更新订单状态 orderInfoService.updateStatus(outTradeNo, OrderStatusEnum.PAID.getStatus()); //记录支付日志 paymentInfoService.savePaymentInfo(orderInfo, transaction); //通知医院修改订单状态 //组装参数 HashMap paramsMap = new HashMap<>(); paramsMap.put("hoscode", orderInfo.getHoscode()); paramsMap.put("hosOrderId", orderInfo.getHosOrderId()); paramsMap.put("timestamp", HttpRequestHelper.getTimestamp()); paramsMap.put("sign", HttpRequestHelper.getSign(paramsMap, "8af52af00baf6aec434109fc17164aae")); //发送请求 JSONObject jsonResult = HttpRequestHelper.sendRequest(paramsMap, "http://localhost:9998/order/updatePayStatus"); //解析响应 if(jsonResult.getInteger("code") != 200) { log.error("查单失败," + "code:" + jsonResult.getInteger("code") + ",message:" + jsonResult.getString("message") ); throw new GuiguException(ResultCodeEnum.FAIL.getCode(), jsonResult.getString("message")); } //返回支付结果 return true;//支付成功 } return false;//支付中 } catch (HttpException e) { // 发送HTTP请求失败 // 调用e.getHttpRequest()获取请求打印日志或上报监控,更多方法见HttpException定义 log.error(e.getHttpRequest().toString()); throw new GuiguException(ResultCodeEnum.FAIL); } catch (ServiceException e) { // 服务返回状态小于200或大于等于300,例如500 // 调用e.getResponseBody()获取返回体打印日志或上报监控,更多方法见ServiceException定义 log.error(e.getResponseBody()); throw new GuiguException(ResultCodeEnum.FAIL); } catch (MalformedMessageException e) { // 服务返回成功,返回体类型不合法,或者解析返回体失败 // 调用e.getMessage()获取信息打印日志或上报监控,更多方法见MalformedMessageException定义 log.error(e.getMessage()); throw new GuiguException(ResultCodeEnum.FAIL); }}
2、前端整合
2.1、修改request.js
utils/request.js的响应拦截器中增加对250状态的判断
}else if (response.data.code !== 200) { 修改为}else if (response.data.code !== 200 && response.data.code !== 250) {
2.2、api
在api/wxpay.js中添加的方法
//查询订单queryPayStatus(outTradeNo) { return request({ url: `/front/order/wxpay/queryPayStatus/${outTradeNo}`, method: "get" })},
3.3、show.vue轮询查单
js中修改pay方法:每隔3秒查单
添加queryPayStatus方法
完善closeDialog方法:停止定时器
//发起支付pay(){ if(this.isPayShow) return this.isPayShow = true this.payText = "支付中....." wxpayApi.nativePay(this.orderInfo.outTradeNo).then((response) => { this.codeUrl = response.data this.dialogPayVisible = true //每隔3秒查单 this.timer = setInterval(()=>{ console.log("轮询查单:" + new Date()) this.queryPayStatus() }, 3000) })}, //查询订单状态queryPayStatus(){ wxpayApi.queryPayStatus(this.orderInfo.outTradeNo).then(response => { if(response.code == 250){ return } //清空定时器 clearInterval(this.timer) window.location.reload() })},//关闭对话框closeDialog(){ //停止定时器 clearInterval(this.timer) //恢复支付按钮 this.isPayShow = false this.payText = "支付"}
3、查单应答超时
3.1、测试应答超时
//应答超时//设置响应超时,支付成功后没有及时响应,可能继续轮询查单,此时数据库会记录多余的支付日志try { TimeUnit.SECONDS.sleep(5);} catch (InterruptedException e) { throw new RuntimeException(e);}//返回支付结果return true;//支付成功
3.2、处理重复通知
支付成功后,判断订单状态:
OrderInfo orderInfo = orderInfoService.selectByOutTradeNo(outTradeNo);//处理支付成功后重复查单//保证接口调用的幂等性:无论接口被调用多少次,产生的结果是一致的Integer orderStatus = orderInfo.getOrderStatus();if (OrderStatusEnum.UNPAID.getStatus().intValue() != orderStatus.intValue()) { return true;//支付成功、关单、。。。}//更新订单状态//记录支付日志......
关键词:
当前滚动:【后端面经-java】java线程池满的处理策略
Rust语言 - 接口设计的建议之受约束(Constrained)_天天最资讯
java~理解可重入锁 焦点速读
硬件博主自费实测5大旗舰手机信号:iPhone各种被狂虐
焦点热文:载亿万富翁观光潜艇失联 被曝用游戏手柄操控 专家:生还希望渺茫
电动汽车也能无线充电了:像手机一样简单 超大充电板长这模样
全球热议:微软停止涨薪影响明显:员工跳槽意愿上涨23%
11499元 三星首款5K专业显示器上架:配可拆卸4K摄像头
环球今日讯!java~字节码操作ASM
班主任和家长扮恐龙接中考生 现场让网友看笑:可爱的显眼包 全球信息
史上最深深海救援!观光潜艇失联:搜救无进展 氧气剩不多、或卡残骸中|全球讯息
公募基金派发约八百亿元“红包雨” 债基占比超八成
俄妹COS《塞尔达》公主火了 性感美艳:欧美曾呼吁塞尔达公主应黑人|时快讯
环球热文:破75%了!理想汽车家用交流充电桩安装率遥遥领先
比亚迪赵长江:腾势N7领先两代 将成为家用和年轻人首选大五座标杆SUV
全球短讯!年轻人第一辆车!“小米汽车”非官方渲染图又来了:质感拉满 你会买吗
读发布!设计与部署稳定的分布式系统(第2版)笔记07_线程阻塞_每日速递
每日看点!从0开始,手写MySQL事务
MySQL事务基础知识 世界快资讯
世界即时:AMD Zen4c 128核心偷跑:只要4万元 不到官价一半
游客新疆旅游拍下雪崩全过程:壮观至极 众人尖叫_世界热文
【环球新视野】孟晚舟亲自站台!华为新杀手锏能否打破国际垄断?
耶鲁大学华裔学生驾车身亡:父母获赔2.5亿元_世界通讯
全球快看点丨观光泰坦尼克号潜艇失联:将是史上最深深海救援 将近4000米
手机可拆卸电池即将回归 利大于弊?
霍启刚患上睡眠窒息症:会被自己打鼾声惊醒 医生称严重会猝死-全球快看
今日报丨北京市下周一通过柜台市场发行20亿元3年期地方债券
每日热闻!5人宿舍热3年用掉水费5275元 高校回应:还算正常 个人习惯不同
世界快讯:618全网销售总额增速降至近3年最低:总销售额7987亿元创新高
ARP与dns缓存攻击 --中间人攻击
文心一言 VS 讯飞星火 VS chatgpt (43)-- 算法导论5.4 7题
用Python写了一个「拥抱梅西」的小游戏
天天时讯:证监会:券商应规范开立综合账户 加强异常交易监测
女子称网购八喜冰淇淋发现少10g:客服赔付了500元
腾讯视频VIP年卡+京东PLUS年卡 双会员仅138元
17万买纯电7座 2024款AION V Plus上市:更有AI的家庭SUV 每日资讯
环球速看:百公里油耗仅需6.1L !全新问界m5曝光:或售价25万起
期望误差和经验误差的关系——期望误差上界
【焦点热闻】使用python对AWS-CloudTrail-Json-日志文件key字段名称的提取
天天日报丨决战暑期档!国产航空大片《长空之王》密钥再次延期:王一博主演
超越姚明!16岁女篮小将身高已达2米27 山东女篮主力 单场曾砍62分
国产显卡第一次!摩尔线程发布DX11社区版驱动 能玩5款游戏_世界聚焦
全球观焦点:价格跌倒iPhone吃饱!被群嘲的苹果竟成为618销冠
不再依赖进口锂矿 两款钠离子电池电动车来了:成本便宜30%
天天快消息!记录--前端实现文件预览(pdf、excel、word、图片)
InnoDB 内存结构之更改缓冲区 环球新消息
Springboot web,三层架构, IOC&DI 使用总结2023 关注
快讯 | ShowMeBug入选人力资源智享会《TPG红宝书》 观热点
精彩看点:中消协出手:反对扫码强制关注公众号 全国范围可举报
学生自掏30万拍作品:因获三等奖嫌低拒绝领奖_热文
号称性能最强轻薄掌机:AYANEO预热新AMD 7840U处理器掌机_天天即时看
210元大额券:礼盒装红蜻蜓男士真皮自动皮带49元大促_环球新资讯
还买啥RTX 3060 英特尔A770 16GB显卡1779元
热推荐:史上最全Hadoop面试题:尼恩大数据面试宝典专题1
kafka的学习之一_带SASL鉴权的集群安装与启动
全球今日讯!债市日报:6月20日
科学家警告:用AI生成内容训练AI 几代内将产生“垃圾”
《暗黑破坏神4》官方晒自定义RTX4080显卡 莉莉丝雕塑逼真吗?
微头条丨毕业典礼上学生帽穗丢了:老师无实物拨穗
环球热门:高考后考生特种兵式出游有多拼?准大学生凌晨2点坐飞机五天游五城
采用模块化可拆卸设计:Fairphone 5手机承诺提供5年保修
Python工具箱系列(三十六) 全球资讯
华为云GaussDB为MetaERP“成本核算”产品“保驾护航” 天天观热点
【经验贴】多项目并行,如何解决资源管理这个难点? 热闻
这里的工业为何跑出“加速度”?——福建宁德工业企业一线观察|每日焦点
世界观焦点:被曝脏乱粽子厂曾中标学校配餐项目 卫生脏乱粽子厂抽检曾发现问题
环球今日讯!高考生们看过来!“2023年高考网上咨询周”时间安排公布
当前视点!高速停车致三车追尾自己却溜了 驾驶员称跟自己没关系 被判全责
无毒无污染、更完美!长征六号火箭第11次成功发射|焦点速读
今日热文:手机为何不再使用可拆卸电池?原因揭开
天涯社区苦等“救命钱”!重启天涯宣布再开直播:筹款还是300万|快消息
LPR利率下调10个基点,如何影响你的房贷利率? 播报
世界速讯:以梦为码 自主创新 | 华为云开发者日成都站圆满举行!
ElasticSearch安装与使用-每日视点
天天信息:全国铁路7月1日起实行新的列车运行图 客、货列车分别增加46列和394列
每日消息!中方在世贸组织提交贸易与环境政策相关提案
家居巨头宜家引入AI:下一代沙发将由人工智能设计
华硕Zenfone 10外观首曝:二代骁龙8小屏旗舰
地表最强RTX 4090!索泰RTX 4090 PGF显卡图赏 世界简讯
广州新规:快递入柜需收件人同意 虚假签收最高可罚三万!
天天信息:长虹发布全球首款多模态交互电视:不管说什么都能听懂
天天速读:南方强降雨频繁有致灾风险 北方高温明起再登场
微动态丨标准IO使用复习
视讯!ABAQUS 模拟过盈配合解决材料选择及公差带设计等问题
全球观察:maven 使用总结2023
人民银行合肥中心支行联合交易商协会举办债务融资工具业务培训|环球滚动
货币宽松抬升经济复苏放缓预期 日债收益率曲线延续趋陡-快讯
每日热闻!英亿万富翁探索泰坦尼克号残骸 现已失联超24小时!
售价超20万元 AMD最贵显卡MI300X诞生:192GB显存史无前例
今日聚焦!雷军武汉大学演讲:36年前教授这句话打通我任督二脉
一天两瓶喝不够:认养一头牛酸/纯奶30盒79.9元抄底(50元立减券)_今日热文
原装进口!雀巢黑咖啡官旗大促:券后每杯仅需0.6元|天天热点
最新快讯!新干县气象台发布雷电黄色预警信号【III级/较重】【2023-06-20】
Apache Superset 身份认证绕过漏洞(CVE-2023-27524)
关于IEnumerable和IQuerable之间的区别 全球通讯
java~二进制补码的用途|世界新消息
中国广电5G悲催的第一年:信号差 销户难
智能驾驶将进入大模型时代!理想发布通勤NOA内测视频 可自主学习
第一款ITX A620终于出现!最便宜的AMD迷你小板 热门
鸡蛋壳难剥是鸡蛋放的久了吗 为什么鸡蛋的壳很难剥 天天新动态