最新要闻
- 热文:谁说的不流畅?Steam玩家调查:Win11成香饽饽 NV四年前神卡1650领跑
- 新年暴击!超10家车企宣布涨价 特斯拉公开“唱反调”
- 三星将在CES 2023展示新款显示屏:折叠、滑动都支持
- 赚翻的节奏:美国超级百万彩票头奖升至54亿元 竟多次没人中奖
- 全球热门:女司机等红灯陌生男突然上车搭讪:拉车门坐到后排 被当场吓哭
- 今亮点!特斯拉司机在德国高速公路上睡着!无视交警 结果“很刑”
- 世界讯息:2022年新生儿爆款名字出炉上热搜 这些字用得最多:土爆了?
- 全球微速讯:电商晒数据!4年卖出那么多块SSD 三星质量稳如狗:零返修
- 天天短讯!越南地产大佬都做出60万的车了 建议国内这位好好学
- 环球快资讯丨2023元旦档总票房5.47亿:《阿凡达2》撑起“半壁江山”
- 天天通讯!手慢真无了!徐福记零食礼盒大促:39.9元到手 送礼有面
- 天天即时看!NVIDIA服软了!RTX 4070 Ti大量偷跑:价格低至6299元
- 环球速讯:国行6499元买到就是赚到?RTX 4070 Ti性能抢先看:对比4080
- 全球快看:你肯定达标了?31省份最低工资表公布:上海第一 超2500元
- 热议:29岁男子身高2.89米成世界上最高的人:还在生长中!
- 焦点快看:因14 Plus销量太差 曝苹果将对iPhone 15 Plus价格大调整
广告
手机
iphone11大小尺寸是多少?苹果iPhone11和iPhone13的区别是什么?
警方通报辅警执法直播中被撞飞:犯罪嫌疑人已投案
- iphone11大小尺寸是多少?苹果iPhone11和iPhone13的区别是什么?
- 警方通报辅警执法直播中被撞飞:犯罪嫌疑人已投案
- 男子被关545天申国赔:获赔18万多 驳回精神抚慰金
- 3天内26名本土感染者,辽宁确诊人数已超安徽
- 广西柳州一男子因纠纷杀害三人后自首
- 洱海坠机4名机组人员被批准为烈士 数千干部群众悼念
家电
天天百事通!微信支付之支付码支付
(资料图片)
一、获取微信支付码url(1)获取微信支付码url主方法
///(2)支付辅助类/// 获取微信支付二维码 /// /// 日志 /// 订单编号 ///public static string GetPayUrl(string orderId, decimal totalPrice) { //errMsg = ""; //Log4Net.Log4Net.Info(log, "订单号:" + orderId + "发起Native的第二种支付方式"); WxPayData data = new WxPayData(); data.SetValue("body", "");//商品描述 data.SetValue("attach", "");//附加数据 data.SetValue("out_trade_no", orderId);//随机字符串 data.SetValue("total_fee", Convert.ToInt32(totalPrice * 100));//总金额 data.SetValue("time_start", DateTime.Now.ToString("yyyyMMddHHmmss"));//交易起始时间 data.SetValue("time_expire", DateTime.Now.AddMinutes(30).ToString("yyyyMMddHHmmss"));//交易结束时间,前端二维码有效期半小时 data.SetValue("goods_tag", "");//商品标记(可根据业务随便填) data.SetValue("trade_type", "NATIVE");//交易类型 data.SetValue("product_id", orderId);//商品ID WxPayData result = WxPayApi.UnifiedOrder(data);//调用统一下单接口 string url = string.Empty; if (result.GetValue("return_code").ToString() == "SUCCESS") { if (result.GetValue("result_code").ToString() == "SUCCESS") { url = result.GetValue("code_url").ToString();//获得统一下单接口返回的二维码链接 } else { //errMsg = result.GetValue("err_code_des").ToString(); } } else { //errMsg = result.GetValue("return_msg").ToString(); } //Log4Net.Log4Net.Info(log, "订单号:" + orderId + "发起Native的第二种支付方式,生成支付链接:" + url); return url; }
/** * * 统一下单 * @param WxPaydata inputObj 提交给统一下单API的参数 * @param int timeOut 超时时间 * @throws WxPayException * @return 成功时返回,其他抛异常 */ public static WxPayData UnifiedOrder(WxPayData inputObj, int timeOut = 6) { string url = "https://api.mch.weixin.qq.com/pay/unifiedorder"; //检测必填参数 if (!inputObj.IsSet("out_trade_no")) { throw new Exception("缺少统一支付接口必填参数out_trade_no!"); } else if (!inputObj.IsSet("body")) { throw new Exception("缺少统一支付接口必填参数body!"); } else if (!inputObj.IsSet("total_fee")) { throw new Exception("缺少统一支付接口必填参数total_fee!"); } else if (!inputObj.IsSet("trade_type")) { throw new Exception("缺少统一支付接口必填参数trade_type!"); } //关联参数 if (inputObj.GetValue("trade_type").ToString() == "JSAPI" && !inputObj.IsSet("openid")) { throw new Exception("统一支付接口中,缺少必填参数openid!trade_type为JSAPI时,openid为必填参数!"); } if (inputObj.GetValue("trade_type").ToString() == "NATIVE" && !inputObj.IsSet("product_id")) { throw new Exception("统一支付接口中,缺少必填参数product_id!trade_type为JSAPI时,product_id为必填参数!"); } //异步通知url未设置,则使用配置文件中的url if (!inputObj.IsSet("notify_url")) { inputObj.SetValue("notify_url", WxPayConfig.GetConfig().GetNotifyUrl());//异步通知url } inputObj.SetValue("appid", WxPayConfig.GetConfig().GetAppID());//appID inputObj.SetValue("mch_id", WxPayConfig.GetConfig().GetMchID());//商户号 inputObj.SetValue("spbill_create_ip", WxPayConfig.GetConfig().GetIp());//终端ip inputObj.SetValue("nonce_str", GenerateNonceStr());//随机字符串 inputObj.SetValue("sign_type", WxPayData.SIGN_TYPE_HMAC_SHA256);//签名类型 //签名 inputObj.SetValue("sign", inputObj.MakeSign()); string xml = inputObj.ToXml(); var start = DateTime.Now; //Log4Net.Log4Net.Info(log, "WX UnfiedOrder request : " + xml); string response = HttpService.Post(xml, url, false, timeOut); //Log4Net.Log4Net.Info(log, "WX UnfiedOrder response : " + response); var end = DateTime.Now; int timeCost = (int)((end - start).TotalMilliseconds); WxPayData result = new WxPayData(); result.FromXml(response); ReportCostTime(url, timeCost, result);//测速上报 return result; }
public class WxPayData { public const string SIGN_TYPE_MD5 = "MD5"; public const string SIGN_TYPE_HMAC_SHA256 = "HMAC-SHA256"; public WxPayData() { } //采用排序的Dictionary的好处是方便对数据包进行签名,不用再签名之前再做一次排序 private SortedDictionarym_values = new SortedDictionary (); /** * 设置某个字段的值 * @param key 字段名 * @param value 字段值 */ public void SetValue(string key, object value) { m_values[key] = value; } /** * 根据字段名获取某个字段的值 * @param key 字段名 * @return key对应的字段值 */ public object GetValue(string key) { object o = null; m_values.TryGetValue(key, out o); return o; } /** * 判断某个字段是否已设置 * @param key 字段名 * @return 若字段key已被设置,则返回true,否则返回false */ public bool IsSet(string key) { object o = null; m_values.TryGetValue(key, out o); if (null != o) return true; else return false; } /** * @将Dictionary转成xml * @return 经转换得到的xml串 * @throws WxPayException **/ public string ToXml() { //数据为空时不能转化为xml格式 if (0 == m_values.Count) { throw new Exception("WxPayData数据为空!"); } string xml = " "; foreach (KeyValuePair "; return xml; } /** * @将xml转为WxPayData对象并返回对象内部的数据 * @param string 待转换的xml串 * @return 经转换得到的Dictionary * @throws WxPayException */ public SortedDictionarypair in m_values) { //字段值不能为null,会影响后续流程 if (pair.Value == null) { throw new Exception("WxPayData内部含有值为null的字段!"); } if (pair.Value.GetType() == typeof(int)) { xml += "<" + pair.Key + ">" + pair.Value + "" + pair.Key + ">"; } else if (pair.Value.GetType() == typeof(string)) { xml += "<" + pair.Key + ">" + "" + pair.Key + ">"; } else//除了string和int类型不能含有其他数据类型 { throw new Exception("WxPayData字段数据类型错误!"); } } xml += " FromXml(string xml) { if (string.IsNullOrEmpty(xml)) { throw new Exception("将空的xml串转换为WxPayData不合法!"); } XmlDocument xmlDoc = new XmlDocument(); xmlDoc.LoadXml(xml); XmlNode xmlNode = xmlDoc.FirstChild;//获取到根节点 XmlNodeList nodes = xmlNode.ChildNodes; foreach (XmlNode xn in nodes) { XmlElement xe = (XmlElement)xn; m_values[xe.Name] = xe.InnerText;//获取xml的键值对到WxPayData内部的数据中 } try { //2015-06-29 错误是没有签名 if (m_values["return_code"] != "SUCCESS") { return m_values; } CheckSign();//验证签名,不通过会抛异常 } catch (Exception ex) { throw new Exception(ex.Message); } return m_values; } /** * @Dictionary格式转化成url参数格式 * @ return url格式串, 该串不包含sign字段值 */ public string ToUrl() { string buff = ""; foreach (KeyValuePair pair in m_values) { if (pair.Value == null) { throw new Exception("WxPayData内部含有值为null的字段!"); } if (pair.Key != "sign" && pair.Value.ToString() != "") { buff += pair.Key + "=" + pair.Value + "&"; } } buff = buff.Trim("&"); return buff; } /** * @Dictionary格式化成Json * @return json串数据 */ public string ToJson() { //string jsonStr = JsonMapper.ToJson(m_values); //return jsonStr; return ""; } /** * @values格式化成能在Web页面上显示的结果(因为web页面上不能直接输出xml格式的字符串) */ public string ToPrintStr() { string str = ""; foreach (KeyValuePair pair in m_values) { if (pair.Value == null) { throw new Exception("WxPayData内部含有值为null的字段!"); } str += string.Format("{0}={1}\n", pair.Key, pair.Value.ToString()); } str = HttpUtility.HtmlEncode(str); return str; } /** * @生成签名,详见签名生成算法 * @return 签名, sign字段不参加签名 */ public string MakeSign(string signType) { //转url格式 string str = ToUrl(); //在string后加入API KEY str += "&key=" + WxPayConfig.GetConfig().GetKey(); if (signType == SIGN_TYPE_MD5) { var md5 = MD5.Create(); var bs = md5.ComputeHash(Encoding.UTF8.GetBytes(str)); var sb = new StringBuilder(); foreach (byte b in bs) { sb.Append(b.ToString("x2")); } //所有字符转为大写 return sb.ToString().ToUpper(); } else if (signType == SIGN_TYPE_HMAC_SHA256) { return CalcHMACSHA256Hash(str, WxPayConfig.GetConfig().GetKey()); } else { throw new Exception("sign_type 不合法"); } } /** * @生成签名,详见签名生成算法 * @return 签名, sign字段不参加签名 SHA256 */ public string MakeSign() { return MakeSign(SIGN_TYPE_HMAC_SHA256); } /** * * 检测签名是否正确 * 正确返回true,错误抛异常 */ public bool CheckSign(string signType) { //如果没有设置签名,则跳过检测 if (!IsSet("sign")) { throw new Exception("WxPayData签名存在但不合法!"); } //如果设置了签名但是签名为空,则抛异常 else if (GetValue("sign") == null || GetValue("sign").ToString() == "") { throw new Exception("WxPayData签名存在但不合法!"); } //获取接收到的签名 string return_sign = GetValue("sign").ToString(); //在本地计算新的签名 string cal_sign = MakeSign(signType); if (cal_sign == return_sign) { return true; } throw new Exception("WxPayData签名验证错误!"); } /** * * 检测签名是否正确 * 正确返回true,错误抛异常 */ public bool CheckSign() { return CheckSign(SIGN_TYPE_HMAC_SHA256); } /** * @获取Dictionary */ public SortedDictionary GetValues() { return m_values; } private string CalcHMACSHA256Hash(string plaintext, string salt) { string result = ""; var enc = Encoding.Default; byte[] baText2BeHashed = enc.GetBytes(plaintext), baSalt = enc.GetBytes(salt); System.Security.Cryptography.HMACSHA256 hasher = new HMACSHA256(baSalt); byte[] baHashedText = hasher.ComputeHash(baText2BeHashed); result = string.Join("", baHashedText.ToList().Select(b => b.ToString("x2")).ToArray()); return result; } }
/** * 生成随机串,随机串包含字母或数字 * @return 随机串 */ public static string GenerateNonceStr() { RandomGenerator randomGenerator = new RandomGenerator(); return randomGenerator.GetRandomUInt().ToString(); }
public class RandomGenerator { readonly RNGCryptoServiceProvider csp; public RandomGenerator() { csp = new RNGCryptoServiceProvider(); } public int Next(int minValue, int maxExclusiveValue) { if (minValue >= maxExclusiveValue) throw new ArgumentOutOfRangeException("minValue must be lower than maxExclusiveValue"); long diff = (long)maxExclusiveValue - minValue; long upperBound = uint.MaxValue / diff * diff; uint ui; do { ui = GetRandomUInt(); } while (ui >= upperBound); return (int)(minValue + (ui % diff)); } public uint GetRandomUInt() { var randomBytes = GenerateRandomBytes(sizeof(uint)); return BitConverter.ToUInt32(randomBytes, 0); } private byte[] GenerateRandomBytes(int bytesNumber) { byte[] buffer = new byte[bytesNumber]; csp.GetBytes(buffer); return buffer; } }
二、微信支付结果回调接收
(1)支付回调主接收方法
///(2)辅助方法/// 微信支付回调函数 /// ///[HttpPost] [AllowAnonymous] public async Task WxPayNotify() { HttpContext context = _httpContextAccessor.HttpContext; try { WxPayData notifyData = GetNotifyData(context); Log.Information("GetNotifyData finished"); //检查支付结果中transaction_id是否存在 if (!notifyData.IsSet("transaction_id")) { //若transaction_id不存在,则立即返回结果给微信支付后台 WxPayData res = new WxPayData(); res.SetValue("return_code", "FAIL"); res.SetValue("return_msg", "支付结果中微信订单号不存在"); await context.Response.WriteAsync(res.ToXml()); } string transaction_id = notifyData.GetValue("transaction_id").ToString(); string out_trade_no = notifyData.GetValue("out_trade_no").ToString(); //查询订单,判断订单真实性 if (!QueryOrder(transaction_id)) { //若订单查询失败,则立即返回结果给微信支付后台 WxPayData res = new WxPayData(); res.SetValue("return_code", "FAIL"); res.SetValue("return_msg", "订单查询失败"); await context.Response.WriteAsync(res.ToXml()); } //查询订单成功 else { //判断订单号和支付金额是否和数据库中一致 //修改订单状态,插入支付payment信息 string result_code = notifyData.GetValue("result_code").ToString(); string openid = notifyData.GetValue("openid").ToString(); string trade_type = notifyData.GetValue("trade_type").ToString(); string bank_type = notifyData.GetValue("bank_type").ToString(); int total_fee = Convert.ToInt32(notifyData.GetValue("total_fee")); int cash_fee = Convert.ToInt32(notifyData.GetValue("cash_fee")); string time_end = notifyData.GetValue("time_end").ToString(); Log.Information($"out_trade_no is {out_trade_no}"); var orderInfo = await _orderRepository.FindAsync(item => item.OrderNumber.ToString() == out_trade_no); if (orderInfo == null) { //若订单查询失败,则立即返回结果给微信支付后台 WxPayData res = new WxPayData(); res.SetValue("return_code", "FAIL"); res.SetValue("return_msg", "商户订单不存在"); await context.Response.WriteAsync(res.ToXml()); } Log.Information($"total_fee is {total_fee}"); Log.Information($"DiscountPrice*100 is {orderInfo.DiscountPrice * 100}"); if (orderInfo.DiscountPrice * 100 != total_fee)//订单支付金额不一致 { WxPayData res = new WxPayData(); res.SetValue("return_code", "FAIL"); res.SetValue("return_msg", "订单支付金额不一致"); await context.Response.WriteAsync(res.ToXml()); } if (orderInfo.PayStatus == PayStatus.Success && orderInfo.DiscountPrice * 100 == total_fee)//订单已支付 { WxPayData res = new WxPayData(); res.SetValue("return_code", "SUCCESS"); res.SetValue("return_msg", "OK"); await context.Response.WriteAsync(res.ToXml()); } else { //该部分主要是一些自定义逻辑了,可以根据自己的业务需求设置; WXPayResult wPay = new WXPayResult(); wPay.OpenId = openid; wPay.TradeState = result_code; wPay.BankType = bank_type; wPay.TotalFee = total_fee; wPay.CashFee = cash_fee; wPay.TransactionId = transaction_id; wPay.TimeEnd = time_end; wPay = await _wXPayResultRepository.InsertAsync(wPay, true); if (null != wPay) { OrderWXPaymentMapping mapping = new OrderWXPaymentMapping(); mapping.OrderNumber = orderInfo.OrderNumber; mapping.WXPayResultId = wPay.Id; mapping = await _orderWXPaymentRepository.InsertAsync(mapping, true); if (mapping != null) { Order orderEntity = null; if (result_code == "SUCCESS") { orderInfo.PayStatus = PayStatus.Success; orderEntity = await _orderRepository.UpdateAsync(orderInfo, true);//10001支付成功 } else { orderInfo.PayStatus = PayStatus.Fail; orderEntity = await _orderRepository.UpdateAsync(orderInfo, true); ;//10002支付失败 } if (orderEntity != null) { WxPayData res = new WxPayData(); res.SetValue("return_code", "SUCCESS"); res.SetValue("return_msg", "OK"); await context.Response.WriteAsync(res.ToXml()); } else { //若订单查询失败,则立即返回结果给微信支付后台 WxPayData res = new WxPayData(); res.SetValue("return_code", "FAIL"); res.SetValue("return_msg", "商户订单处理失败"); await context.Response.WriteAsync(res.ToXml()); } } else { //若订单查询失败,则立即返回结果给微信支付后台 WxPayData res = new WxPayData(); res.SetValue("return_code", "FAIL"); res.SetValue("return_msg", "商户订单处理失败"); await context.Response.WriteAsync(res.ToXml()); } } else { //若订单查询失败,则立即返回结果给微信支付后台 WxPayData res = new WxPayData(); res.SetValue("return_code", "FAIL"); res.SetValue("return_msg", "商户订单处理失败"); await context.Response.WriteAsync(res.ToXml()); } } } } catch (Exception ex) { Log.Information($"WxPayNotify error message is {ex.Message}"); //若订单查询失败,则立即返回结果给微信支付后台 WxPayData res = new WxPayData(); res.SetValue("return_code", "FAIL"); res.SetValue("return_msg", "商户订单处理失败"); await context.Response.WriteAsync(res.ToXml()); var currentInfo = MethodBase.GetCurrentMethod(); //Log4Net.Error(log, ex.Message, currentInfo.ReflectedType.FullName + "-" + currentInfo.Name); } }
////// 接收从微信支付后台发送过来的数据并验证签名 /// ///微信支付后台返回的数据 public WxPayData GetNotifyData(HttpContext context) { string message = string.Empty; context.Request.EnableBuffering(); context.Request.Body.Seek(0, SeekOrigin.Begin); Log.Information(context.Request.Method); using (var reader = new StreamReader(context.Request.Body, Encoding.UTF8)) { message = reader.ReadToEndAsync().Result; } Log.Information($"context result is {message}"); //Log4Net.Info(log, $"GetNotifyData Receive data from WeChat :{message}"); //转换数据格式并验证签名 WxPayData data = new WxPayData(); try { data.FromXml(message); } catch (Exception ex) { //若签名错误,则立即返回结果给微信支付后台 WxPayData res = new WxPayData(); res.SetValue("return_code", "FAIL"); res.SetValue("return_msg", ex.Message); context.Response.WriteAsync(res.ToXml()); } //Log4Net.Info(log, $"GetNotifyData Check sign success"); return data; }
提示:
* APPID:绑定支付的APPID(必须配置) * MCHID:商户号(必须配置) * KEY:商户支付密钥,参考开户邮件设置(必须配置),请妥善保管,避免密钥泄露
天天百事通!微信支付之支付码支付
关注:学习Python第一个程序“Hello,World”
【新要闻】1.2 今天和对象吵架 但依旧学了代码
热文:谁说的不流畅?Steam玩家调查:Win11成香饽饽 NV四年前神卡1650领跑
新年暴击!超10家车企宣布涨价 特斯拉公开“唱反调”
三星将在CES 2023展示新款显示屏:折叠、滑动都支持
赚翻的节奏:美国超级百万彩票头奖升至54亿元 竟多次没人中奖
全球热门:女司机等红灯陌生男突然上车搭讪:拉车门坐到后排 被当场吓哭
环球关注:保研经历分享
环球消息!MySQL——事务
今亮点!特斯拉司机在德国高速公路上睡着!无视交警 结果“很刑”
世界讯息:2022年新生儿爆款名字出炉上热搜 这些字用得最多:土爆了?
全球微速讯:电商晒数据!4年卖出那么多块SSD 三星质量稳如狗:零返修
天天日报丨1.2复习了一下MySQL的索引
Codeforces Good Bye 2022 CF 1770 F Koxia and Sequence 题解
世界热头条丨WPF+ASP.NET SignalR实现动态折线图
世界头条:1. 线程管理基础
天天短讯!越南地产大佬都做出60万的车了 建议国内这位好好学
环球快资讯丨2023元旦档总票房5.47亿:《阿凡达2》撑起“半壁江山”
bbs项目(部分讲解)
天天通讯!手慢真无了!徐福记零食礼盒大促:39.9元到手 送礼有面
天天即时看!NVIDIA服软了!RTX 4070 Ti大量偷跑:价格低至6299元
环球速讯:国行6499元买到就是赚到?RTX 4070 Ti性能抢先看:对比4080
世界观焦点:解放生产力!一文教你快速入门正则表达式
全球快看:你肯定达标了?31省份最低工资表公布:上海第一 超2500元
热议:29岁男子身高2.89米成世界上最高的人:还在生长中!
JavaWeb学习笔记
焦点快看:因14 Plus销量太差 曝苹果将对iPhone 15 Plus价格大调整
环球头条:超14亿美元!《阿凡达2》票房达到回本线 你贡献了几张票?
世界快看:3G CDMA再见!美国运营商关闭 中国电信也快关闭了
新消息丨苹果中国不手软:iPhone 14之前机型保修费大涨 700元换块电池
即时焦点:tclap库的使用
美好午餐肉罐头促销:5盒不到20元 味道鲜美入口留香
天天新资讯:MySQL——基础架构
Python类与对象详解
【环球热闻】Python重用父类方法
Python类的封装教程
世界热门:电竞圈说的“满血”到底是啥 真能带来游戏体验升级?实测揭秘真相
女子花2700修热水器:成本只有13元
docker复杂安装
热点在线丨AcWing1170. 排队布局[USACO05]
当前速读:今天是卢伟冰入职小米4周年!卢伟冰想起4年前雷军说过的话
取暖电器火了!成为老外眼中的香饽饽
看点:docker安装软件
天天看点:根治安卓卡顿!一加11超21万人预约:本周发
蔚来2022年累计交付新车122486辆 明年目标超雷克萨斯
速讯:微软吹大了!Win11流畅度没那么神:Office/PS还没Win10快
实时焦点:女子跨年夜捡烟花废品赚552元 一晚上捡了920斤:网友叹服人勤劳怎么都赚钱
2023油价新年第一涨来了:我国汽油全面进入国六B时代 油品质量不缩水
全球微动态丨2022年第一票房是《壮志凌云2》 阿汤哥驾F14胜5代战机的爽片赢下全球影迷
全球播报:JDBC
Maven基础
【天天新要闻】Redmi 12C只卖699元:但支持双频WiFi 还有3.5mm耳机孔和TF卡槽
当前信息:三亚近期酒店房间几乎售罄:飞机上坐满了人
世界通讯!摄影师对小米13 Pro长焦刮目相看:原本不抱希望 但实际效果令人意外
世界消息!一加11本周发!李杰:一部你越用越爱、越用越惊喜的手机
实时焦点:甘肃省高速公路实施差异化收费 绿牌新能源最高能省50%过路费
焦点短讯!女子接触发霉玉米肺里长黄曲霉菌 没戴口罩防护:医生科普毒性超强
特斯拉美国遭起诉:违反劳动法
焦点简讯:1TB+ SSD固态盘继续便宜 用户消费不动:微软背锅
当前快讯:东北500米超长冰滑梯走红!世界最长“出溜滑”:1秒10米风驰电掣
动态焦点:一招轻松解决node内存溢出问题
环球视讯!2020年“老卡”姗姗来迟:映泰突然推出RTX 3080/3070非公显卡
世界聚焦:PG认证的注意事项 (这很重要!)
【全球聚看点】《原神》赚麻了!推出2年移动端收入超过275亿元
视讯!3人同时订酒店价格相差1倍 去哪儿回应:正常 因素有很多
观天下!Django中间件
环球看点!造车新势力第一!2022年埃安累计销量27.1万辆 明年冲击60万辆
热头条丨Django组件之form组件
全球观察:索尼音乐在B站传了17万个视频 网友:当免费服务器了
当前时讯:比亚迪技术加持 创维汽车2022年总销量21916台 暴增255.72%
天天日报丨复兴号新动车元旦首秀:红白灰绿四色机身成“网红”车型
N95有效防护时间为4到6小时:和戴普通口罩效果有什么区别?
Django组件之Ajax请求
视焦点讯!RTX 4070 Ti完整规格、性能曝光:4090一半性能、一半的价格
新年快乐!今天遇到一个问题:3个鸡蛋5元,6个鸡蛋多少钱?
iPhone 15 mini重出江湖?苹果把这几个功能加上卖爆
世界热文:蒙脱石散为啥突然火了?医生提醒:不要乱用 小心便秘
今日快讯:关于使用boto3方式获取AWS-所有EC2-机型及属性时所遇到的结果返回不全的坑点及使用分布机制的解决方法
世界快讯:web项目开发---第三天
环球关注:1月4日发布!一加11官宣搭载双环式对磁扬声器:支持杜比全景声
世界讯息:新能源补贴正式终止!小鹏宣布:2023年各车型售价与补贴后一致
MAUI新生6.6-搜索栏SearchHandler
今日热搜:岚图汽车12月交付1729辆 大增14.7%!全年累计交付19409辆
每日焦点!得到跨年演讲2023
环球微速讯:《阿凡达2》成第100部内地票房破10亿电影:当年《阿凡达1》是第1部
Django模板层
今日看点:外观帅炸了!阿富汗首款国产跑车随风雪亮相喀布尔
《王者荣耀》盘古即将获得品质升级:上手难度大幅下降
每日短讯:跨年夜无人机被气球缠绕坠落人群 引发一阵惊呼
【世界热闻】从系统整体观思考系统构建
大年初一上映!《流浪地球2》微笑海报发布:主创全员出镜
2023全年油价调整时间表出炉:1月3日第一调 要涨
AcWing362. 区间
最新消息:你看过几场?2022年国内电影总票房超300亿
即时焦点:必囤:百草味年货坚果大礼包1370g/8袋仅49元
微速讯:特斯拉拼了:其他品牌车辆置换特斯拉 3.2万元功能免费用90天
全球首架国产大飞机C919新年首飞:验证飞行将达100小时
每日快看:全球最大第三方Android系统!基于Android 13的LineageOS 20正式发布
全球今头条!联想新款迷你主机M60Q官宣:厚度仅3.4厘米 可选12代i5