C# 实现微信退款及对帐

news2024/12/24 0:22:53

目录

需求

基础准备

关键代码

操作界面

​编辑

退款订单类及方法

退款功能实现

对帐

支付商家后台相关要点

实时交易帐单查询

精确交易帐单查询

小结

需求

在招聘报名系统里,考务费支付是其中一个环节,支付方式很多种,比如银联、微信、支付宝等等。本次我们以微信支付进行举例,在考生注册账号、编写简历、报名职位、被初审核通过等一系列基础的条件的具备下,可以进入支付考务费的环节(笔试费用),我们会为其生成一个支付二维码,考生支付后(无论成功与否),都会记录其支付结果状态。

在实际的应用中,对于支付成功的考生,我们会遇到实现退款的需求,只要包括如下场景:

1、根据政策规定,某些符合全部或部分退款条件的考生。

2、其它未知原因,重复支付订单的考生。

3、其它不可抗力,需求进行退款的考生。

基础准备

在实现功能前,做为企业,我们需要申请一个微信服务号,并成为微信支付商家。

1、申请服务号

申请成功后会获得到 AppId 和 AppSecret 用于后续开发,如关联支付商户、网页授权登录等。

具体指引请参照微信公众平台首页:https://mp.weixin.qq.com/cgi-bin/loginpage

2、成为微信支付商家

申请成功后会获得 Mchid 和 paySignKey 用于微信支付、退款等,请在商家后台务必关联申请的公众号。

具体指引请参照微信支付平台首页:https://pay.weixin.qq.com/index.php/core/home/login

上述两个平台申请成功后,请登录微信支付商家平台,进行如下图操作:

在产品中心、AppID帐号管理、关联 AppID(即申请的服务号) 

另外一个重要配置是支付目录,我们写的支付程序需要在这里设置,如下图:

关键代码

操作界面

界面上会显示最近一笔的微信订单支付情况,包括订单号、交费时间、交费金额、退款金额。其中退款金额不能大于成功交费金额,否则会返回失败。另外,还可以显示微信交易跟踪日志列表信息,如果订单号、交易价格、openid、返回信息、交易状态等。

示例界面如下:

退款订单类及方法

实现微信退款,需要在支付商家平台申请退款证书,证书文件保存到自定义的目录中,在退款时指定路径。

退款示例代码如下:

                const string RefundOrderUrl = "https://api.mch.weixin.qq.com/secapi/pay/refund";   //退款申请API地址
                const string RefundQueryUrl = "https://api.mch.weixin.qq.com/pay/refundquery";  //退款查询API地址
//退款订单明细类
public class RefundOrderDetail
            {
                /// <summary>
                /// 返回状态码,SUCCESS/FAIL 此字段是通信标识,非交易标识,交易是否成功需要查看trade_state来判断
                /// </summary>
                public string return_code = "";

                /// <summary>
                /// 返回信息返回信息,如非空,为错误原因 签名失败 参数格式校验错误
                /// </summary>
                public string return_msg = "";

                /// <summary>
                /// 业务结果,SUCCESS/FAIL
                /// </summary>
                public string result_code = "";

                /// <summary>
                /// 错误代码
                /// </summary>
                public string err_code = "";

                /// <summary>
                /// 错误代码描述
                /// </summary>
                public string err_code_des = "";
                /// <summary>
                /// 公众号ID(微信分配的公众账号 ID)
                /// </summary>
                public string appid = "";

                /// <summary>
                /// 商户号(微信支付分配的商户号)
                /// </summary>
                public string mch_id = "";

                /// <summary>
                /// 微信支付分配的终端设备号
                /// </summary>
                public string device_info = "";

                /// <summary>
                /// 随机字符串,不长于32位
                /// </summary>
                public string nonce_str = "";

                /// <summary>
                /// 签名
                /// </summary>
                public string sign = "";
                /// <summary>
                /// 微信支付订单号
                /// </summary>
                public string transaction_id = "";
                /// <summary>
                /// 商户系统的订单号,与请求一致。
                /// </summary>
                public string out_trade_no = "";
                public string out_refund_no = "";
                public string refund_id = "";
                public string refund_fee = "";
                public string settlement_refund_fee = "";
                /// <summary>
                /// 订单总金额,单位为分
                /// </summary>
                public string total_fee = "";


                /// </summary>
                public string settlement_total_fee = "";

                public string fee_type = "";

                public string cash_fee = "";

                public string cash_fee_type = "";

                public string cash_refund_fee = "";

                public string coupon_type_0 = "";

                public string coupon_refund_fee = "";

                public string coupon_refund_fee_0 = "";
                public string coupon_refund_count = "";
                public string coupon_refund_id_0 = "";

            }
//退款订单类
            public class RefundOrder
            {
                /// <summary>
                /// 公众号ID(微信分配的公众账号 ID)
                /// </summary>
                public string appid = "";
                /// <summary>
                /// 商户号(微信支付分配的商户号)
                /// </summary>
                public string mch_id = "";
                /// <summary>
                /// 微信支付分配的终端设备号
                /// </summary>
                public string device_info = "";
                /// <summary>
                /// 随机字符串,不长于 32 位
                /// </summary>
                public string nonce_str = "";
                /// <summary>
                /// 签名
                public string sign = "";

                public string sign_type = "";
                /// <summary>
                /// 商户系统内部的订单号,32个字符内、可包含字母,确保在商户系统唯一,详细说明
                /// </summary>
                public string transaction_id = "";
                public string out_trade_no = "";
                public string out_refund_no = "";
                /// <summary>
                /// 订单总金额,单位为分,不能带小数点
                /// </summary>
                public int total_fee = 0;
                public int refund_fee = 0;
                public string  refund_fee_type = "";
                public string op_user_id = "";
                /// <summary>
                public string refund_account = "";
                /// <summary>
            }
//查询对帐订单类
            public class QueryOrder
            {
                /// <summary>
                /// 公共号ID(微信分配的公众账号 ID)
                /// </summary>
                public string appid = "";

                /// <summary>
                /// 商户号(微信支付分配的商户号)
                /// </summary>
                public string mch_id = "";

                /// <summary>
                /// 微信订单号,优先使用
                /// </summary>
                public string transaction_id = "";

                /// <summary>
                /// 商户系统内部订单号
                /// </summary>
                public string out_trade_no = "";

                /// <summary>
                /// 随机字符串,不长于 32 位
                /// </summary>
                public string nonce_str = "";

                /// <summary>
                /// 签名,参与签名参数:appid,mch_id,transaction_id,out_trade_no,nonce_str,key
                /// </summary>
                public string sign = "";
            }


//申请退款方法,返回退款订单明细类
//参数refundorder为退款订单类, key 为支付签名KEY,cert为证书地址,password 为证书密码
                public RefundOrderDetail getRefundOrderDetail(RefundOrder refundorder, string key,string cert,string password)
                {
 

                    string post_data = getRefundOrderXml(refundorder, key);
                    string request_data = PostXmlAndCertToUrl(RefundOrderUrl, post_data,cert,password);
                    RefundOrderDetail orderdetail = new RefundOrderDetail();
                    SortedDictionary<string, string> requestXML = GetInfoFromXml(request_data);
                    foreach (KeyValuePair<string, string> k in requestXML)
                    {
                        switch (k.Key)
                        {
                            case "retuen_code":
                                orderdetail.result_code = k.Value;
                                break;
                            case "return_msg":
                                orderdetail.return_msg = k.Value;
                                break;
                            case "result_code":
                                orderdetail.result_code = k.Value;
                                break;
                            case "err_code":
                                orderdetail.err_code = k.Value;
                                break;
                            case "err_code_des":
                                orderdetail.err_code_des = k.Value;
                                break;
                            case "appid":
                                orderdetail.appid = k.Value;
                                break;
                            case "mch_id":
                                orderdetail.mch_id = k.Value;
                                break;
                            case "device_info":
                                orderdetail.device_info = k.Value;
                                break;
                            case "nonce_str":
                                orderdetail.nonce_str = k.Value;
                                break;
                            case "sign":
                                orderdetail.sign = k.Value;
                                break;
                            case "transaction_id":
                                orderdetail.transaction_id = k.Value;
                                break;
                            case "out_trade_no":
                                orderdetail.out_trade_no = k.Value;
                                break;
                            case "out_refund_no":
                                orderdetail.out_refund_no = k.Value;
                                break;
                            case "refund_id":
                                orderdetail.refund_id = k.Value;
                                break;
                            case "refund_fee":
                                orderdetail.refund_fee = k.Value;
                                break;
                            case "total_fee":
                                orderdetail.total_fee = k.Value;
                                break;
                            case "settlement_refund_fee":
                                orderdetail.settlement_refund_fee = k.Value;
                                break;
                            case "settlement_total_fee":
                                orderdetail.settlement_total_fee = k.Value;
                                break;
                            case "fee_type":
                                orderdetail.fee_type = k.Value;
                                break;
                            case "cash_fee":
                                orderdetail.cash_fee = k.Value;
                                break;
                            case "cash_fee_type ":
                                orderdetail.cash_fee_type = k.Value;
                                break;
                            case "cash_refund_fee":
                                orderdetail.cash_refund_fee = k.Value;
                                break;
                            case "coupon_type_0":
                                orderdetail.coupon_type_0 = k.Value;
                                break;
                            case "coupon_refund_fee":
                                orderdetail.coupon_refund_fee = k.Value;
                                break;
                            case "coupon_refund_fee_0":
                                orderdetail.coupon_refund_fee_0 = k.Value;
                                break;
                            case "coupon_refund_count":
                                orderdetail.coupon_refund_count = k.Value;
                                break;
                            case "coupon_refund_id_0":
                                orderdetail.coupon_refund_id_0 = k.Value;
                                break;
                            default:
                                break;
                        }
                    }
                    return orderdetail;
                }
                protected string getRefundOrderXml(RefundOrder refundorder, string key)
                {
                    string return_string = string.Empty;
                    SortedDictionary<string, string> sParams = new SortedDictionary<string, string>();
                    sParams.Add("appid", refundorder.appid);
                    sParams.Add("mch_id", refundorder.mch_id);
//                    sParams.Add("transaction_id", refundorder.transaction_id);
                    sParams.Add("out_trade_no", refundorder.out_trade_no);
                    sParams.Add("nonce_str", refundorder.nonce_str);
                    sParams.Add("out_refund_no", refundorder.out_refund_no);
                    sParams.Add("total_fee", refundorder.total_fee.ToString());
                    sParams.Add("refund_fee", refundorder.refund_fee.ToString());
                    sParams.Add("op_user_id", refundorder.op_user_id);

                    refundorder.sign = getsign(sParams, key);
                    sParams.Add("sign", refundorder.sign);

                    //拼接成XML请求数据
                    StringBuilder sbPay = new StringBuilder();
                    foreach (KeyValuePair<string, string> k in sParams)
                    {
                        if (k.Key == "attach" || k.Key == "body" || k.Key == "sign")
                        {
                            sbPay.Append("<" + k.Key + "><![CDATA[" + k.Value + "]]></" + k.Key + ">");
                        }
                        else
                        {
                            sbPay.Append("<" + k.Key + ">" + k.Value + "</" + k.Key + ">");
                        }
                    }
                    return_string = string.Format("<xml>{0}</xml>", sbPay.ToString().TrimEnd(','));
                    return return_string;
                }


public string PostXmlAndCertToUrl(string url, string postData,string cert,string password)
                {
                    string resp = string.Empty;

                    ServicePointManager.ServerCertificateValidationCallback = new System.Net.Security.RemoteCertificateValidationCallback(CheckValidationResult);
                    //调用证书
                    System.Security.Cryptography.X509Certificates.X509Certificate2 cer = new System.Security.Cryptography.X509Certificates.X509Certificate2(cert, password, System.Security.Cryptography.X509Certificates.X509KeyStorageFlags.PersistKeySet | System.Security.Cryptography.X509Certificates.X509KeyStorageFlags.MachineKeySet);

                    HttpWebRequest webrequest = (HttpWebRequest)HttpWebRequest.Create(url);
                    webrequest.ClientCertificates.Add(cer);
                    webrequest.Method = "post";
                    webrequest.ContentType = "application/x-www-form-urlencoded";
                    webrequest.ContentLength = postData.Length;
                    //webrequest.ContentType = "text/xml";
                    //byte[] data = System.Text.Encoding.UTF8.GetBytes(postData);
                    //webrequest.ContentLength = data.Length;

                    HttpWebResponse response = null;
                    try
                    {
                        StreamWriter swRequestWriter = new StreamWriter(webrequest.GetRequestStream());
                        swRequestWriter.Write(postData);

                        if (swRequestWriter != null)
                            swRequestWriter.Close();

                        response = (HttpWebResponse)webrequest.GetResponse();
                        using (StreamReader reader = new StreamReader(response.GetResponseStream(), Encoding.UTF8))
                        {
                            resp = reader.ReadToEnd();
                        }
                    }
                    catch (Exception exp)
                    {
                        throw exp;
                    }
                    finally
                    {
                        if (response != null)
                            response.Close();
                    }
                    return resp;
                }
                public string getNoncestr()
                {
                    Random random = new Random();
                    return GetMD5(random.Next(1000).ToString(), "GBK").ToLower().Replace("s", "S");
                }

退款功能实现

假设点击退款按钮事件

protected void Button_Click(object sender, EventArgs e)
{
        string appId = “”; //服务号的appId
        string paySignKey = “”; //申请的支付签名KEY;
        string mch_id = “”;  //申请的支付商户ID

        string OrderID = "";  //支付订单号
        string OrderAmount = (Convert.ToInt32((float.Parse(Amount.Text) * 100))).ToString();  //订单支付金额,Amount.Text 支付金额
        string RefundOrderAmount = (Convert.ToInt32((float.Parse(Amount.Text) * 100))).ToString();   //退款金额(Amount.Text)这里表示全额退款
        string RefundOrderID = Guid.NewGuid().ToString().Replace("-", "");   //生成退款订单号


//创建退款订单
        RefundOrder order = new RefundOrder();
        order.appid = appId;
        order.mch_id = mch_id;
        order.out_trade_no = OrderID;
        order.nonce_str = tenpay.getNoncestr();
        order.out_refund_no = RefundOrderID;
        order.total_fee = int.Parse(OrderAmount);
        order.refund_fee = int.Parse(RefundOrderAmount);
        order.op_user_id = mch_id;

        string cert = “d:\\apiclient_cert.p12";  //退款证书路径

        //私钥(在安装证书时设置)
        string password =""; //证书密码
//创建订单明细类,调用getRefundOrderDetail方法进行退款
        RefundOrderDetail orderdetail = getRefundOrderDetail(order, paySignKey, cert, password);

        string rv = ("退款订单号:" + RefundOrderID + "<br>");
        try
        {
            rv += ("退款金额:" + (double.Parse(orderdetail.total_fee) / 100).ToString() + "<br>");
        }
        catch (Exception eee)
        {
            rv += ("退款金额:<br>");
        }
        rv += ("<b>交易状态:&nbsp;" + (orderdetail.result_code == "SUCCESS" ? "退款申请成功" : "退款申请失败") + "(" + orderdetail.result_code + ")" + "</b><br>");
        rv += ("可能的错误描述:" + orderdetail.err_code_des);
}

对帐

退款申请成功后,仅为申请状态,需要通过查询退款情况以确定是否完成,该功能可以在考生方进行实现,考生可随时查询自己的对帐情况。

以下是参考代码,该代码可实现支付与退款的查询:

protected void queryOrder(object sender, EventArgs e)
{
    string OrderID =”“; //订单号
    string paytype = ”“;  //查询类型,支付消费或退款
    string appId = "";   //服务号 appid
    string paySignKey = "";   //支付签名key
    string mch_id = "";    //支付商户号
    if (paytype == "消费")
    {
        try
        {

            string openid = ”“;   


            QueryOrder order = new QueryOrder();
            order.appid = appId;
            order.mch_id = mch_id;
            order.out_trade_no = OrderID;
            order.nonce_str = getNoncestr();
            OrderDetail orderdetail = getOrderDetail(order, paySignKey);

            string rv = ("订单号:" + OrderID + "<br>");
            rv += ("付款人ID比对识别:" + (openid == orderdetail.openid ? "成功" : "失败") + "<br>");
            rv += ("交易金额:" + (double.Parse(orderdetail.total_fee) / 100).ToString() + "<br>");
            rv += ("<b>交易状态:&nbsp;" + (orderdetail.trade_state == "SUCCESS" ? "成功" : "失败") + "(" + orderdetail.trade_state + ")" + "</b><br>");
            rv += ("支付交易时间:" + (orderdetail.time_end != "" && orderdetail.time_end.Length == 14 ? orderdetail.time_end.Substring(0, 4) + "-" + orderdetail.time_end.Substring(4, 2) + "-" + orderdetail.time_end.Substring(6, 2) + " " + orderdetail.time_end.Substring(8, 2) + ":" + orderdetail.time_end.Substring(10, 2) + ":" + orderdetail.time_end.Substring(12, 2) : "") + "<br>");

        }
        catch (Exception ex)
        {
            return;
        }
    }
    else if (paytype == "退款")
    {
        try
        {

            RefundOrder order = new RefundOrder();
            order.appid = appId;
            order.mch_id = mch_id;
            order.out_trade_no = OrderID;
            order.nonce_str = getNoncestr();


            RefundOrderDetail orderdetail = getRefundQueryOrderDetail(order, paySignKey);
            string rv = ("<b>交易状态:&nbsp;" + (orderdetail.result_code == "SUCCESS" ? "成功" : "失败") + "(" + orderdetail.result_code + ")" + "</b><br>");
            rv += ("其它说明:" + orderdetail.err_code_des);

        }
        catch (Exception ex)
        {
        }
    }
}

支付商家后台相关要点

实时交易帐单查询

登录后台后,该操作可以进行实时交易的帐单对帐功能,以备在争议的时候进行查询,基本操作如下图:

点击交易中心、交易订单、批量订单查询、查询即可下载EXCEL格式的订单。

精确交易帐单查询

登录后台后,可查询精确交易帐单,该帐单每天10:00更新前一天的数据交易,我们可以进行CSV格式的下载,操作如下图:

点击交易中心、交易帐单、打包下载即可,请注意图中圈注的提示。 

小结

以上提供的代码仅供参考,在实际的应用中,我们还可以根据业务需要编写其它功能,如下载微信官方对帐单,导入到应用系统中,与业务数据进行对帐,以排查争议数据;查询订单结果状态以更新业务争议状态信息等。

以上就是自己的一些分享,时间仓促,不妥之处还请大家批评指正!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1262867.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

救命,不会还有体制内姐妹不知道这个神器吧

体制内&#xff0c;每天各种写材料啊啊啊&#xff01;&#xff01;&#xff01;什么用词、结构、形式都要严谨&#xff0c; 有时候憋不出话来说&#xff0c;真的太难了&#xff0c;谁懂啊&#xff01;&#xff01;&#xff01;&#xff01;&#xff01; 这个好东西真的救我大…

软工2021上下午第六题(组合模式)

阅读下列说明和Java代码&#xff0c;将应填入&#xff08;n&#xff09;处的字句写在答题纸的对应栏内。 【说明】 层叠菜单是窗口风格的软件系统中经常采用的一种系统功能组织方式。层叠菜单中包含的可能是一个菜单项&#xff08;直接对应某个功能&#xff09;&#xff0c;也可…

大语言模型(LLMs)在 Amazon SageMaker 上的动手实践(一)

本期文章&#xff0c;我们将通过三个动手实验从浅到深地解读和演示大语言模型&#xff08;LLMs&#xff09;&#xff0c;如何结合 Amazon SageMaker 的模型部署、模型编译优化、模型分布式训练等。 实验一&#xff1a;使用 Amazon SageMaker 构建基于开源 GPT-J 模型的对话机器…

Unity3d 灯光阴影开启,法线贴图出现BUG

URP项目打开灯光的阴影后&#xff0c;法线贴图出现BUG 解决方案&#xff1a;按照下图所示调整材质的选项即可

通义千问 Qwen-7B-Chat-Int4 模型本地化部署

如需在本地或离线环境下运行本项目&#xff0c;需要首先将项目所需的模型下载至本地&#xff0c;通常开源 LLM 与 Embedding 模型可以从 HuggingFace 下载。 以本项目中默认使用的 LLM 模型 THUDM/ChatGLM2-6B 与 Embedding 模型 moka-ai/m3e-base 为例&#xff1a; 下载模型…

【Flutter】graphic图表实现自定义tooltip

renderer graphic中tooltip的TooltipGuide类提供了renderer方法,接收三个参数Size类型,Offset类型,Map<int, Tuple>类型。可查到的文档是真的少,所以只能在源码中扒拉例子,做符合需求的修改。 官方github示例 官方示例 这个例子感觉像是tooltip和提供的那些属性的…

error “you should set MAGICKCORE_HDRI_ENABLE

最近做一个项目需要配置ImageMagick库&#xff0c;本项目配置环境如下&#xff1a; ImageMagick version 7 Operating system, version and so on ubuntu 20.04 Description error "you should set MAGICKCORE_HDRI_ENABLE 查阅网上的资料&#xff1a; 默认的是DMAGICKC…

《孙子兵法》与商务谈判在销售中的应用

《孙子兵法》是中国古代一部伟大的军事战略书籍&#xff0c;也是一部深深影响着中华民族的哲学经典。它的思想深刻而全面&#xff0c;无论是战争策略、战术执行&#xff0c;还是对人性与社会的理解&#xff0c;都有着独到的见解。在商业领域&#xff0c;尤其是销售中&#xff0…

鸿蒙开发已成新趋势

随着华为鸿蒙操作系统的快速崭露头角&#xff0c;鸿蒙开发已然成为当前技术领域的热门新趋势。本文将深入探讨鸿蒙开发的重要性和独特优势&#xff0c;并详细介绍一些关键的鸿蒙开发技术和工具&#xff0c;以及它们对开发者个人和整个行业带来的深远影响。 首先&#xff0c;鸿蒙…

手写数字识别加法器--深度学习实验

上次老师布置了一个实验&#xff1a; 手写数字识别--深度学习实验-CSDN博客 这次在上次的基础上又布置了一个实验&#xff0c;也是做了好久才做出&#xff0c;所以把实验报告放到CSDN保存&#xff0c;自己忘了方便查阅&#xff0c;也为其他人提供借鉴。 实验源码自取&#x…

FFA 2023|字节跳动 7 项议题入选

Flink Forward 是由 Apache 官方授权的 Apache Flink 社区官方技术大会&#xff0c;作为最受 Apache Flink 社区开发者期盼的年度峰会之一&#xff0c;FFA 2023 将持续集结行业最佳实践以及 Flink 最新技术动态&#xff0c;是中国 Flink 开发者和使用者不可错过的的技术盛宴。 …

C#中的async/await异步编程模型

前言 当谈到异步编程时&#xff0c;C#中的async/await是一个强大且方便的工具。它使得编写并发和异步操作变得更加简单和可读&#xff0c;同时提供良好的可维护性。本文将详细解释async/await的使用&#xff0c;以及如何在C#中有效地利用它来实现异步操作。 目录 前言1. async…

项目监控:项目跟踪和控制的工具和步骤

项目管理不仅仅是分配和审查任务&#xff0c;还包括平衡团队成员的工作量、创建预测和避免障碍的工作流程。整个过程涉及许多步骤&#xff0c;因此&#xff0c;项目监控成为了成功业务活动的关键之一&#xff0c;是项目经理确保与团队共同实施的计划顺利进行的方式。 项目监控为…

细胞级浮游藻类智能检测系统

产品信息 新一代浮游藻类智能检测系统问世&#xff01;英视江河首次将藻类检测精度提升到细胞级&#xff01;英视江河致力于新一代浮游生物的识别、计数。特征是群体藻类和群体种个体均精准检测&#xff01;目前设备已在山东、宁夏、内蒙多地实际应用。 郑州英视江河生态环境科…

爬虫http代理有什么用处?怎么高效使用HTTP代理?

在进行网络爬虫工作时&#xff0c;我们有时会遇到一些限制&#xff0c;比如访问频率限制、IP被封等问题。这时&#xff0c;使用HTTP代理可以有效地解决这些问题&#xff0c;提高爬虫的工作效率。本文将介绍爬虫HTTP代理的用处以及如何高效地使用HTTP代理。 一、爬虫HTTP代理的用…

leetCode 17.电话号码的字母组合 + 回溯算法 + 图解 + 笔记

17. 电话号码的字母组合 - 力扣&#xff08;LeetCode&#xff09; 给定一个仅包含数字 2-9 的字符串&#xff0c;返回所有它能表示的字母组合。答案可以按 任意顺序 返回。 给出数字到字母的映射如下&#xff08;与电话按键相同&#xff09;。注意 1 不对应任何字母。 示例 1&…

汽车电子 -- 车载ADAS之DOW(开门预警 )

相关法规文件: DOW&#xff1a; GB/T XXXXX—XXXX 乘用车车门开启预警系统性能要求及试验方法 一、开门预警 DOW&#xff08;Door open Warning&#xff09; 参看&#xff1a;功能定义-开门碰撞预警 在停车状态即将开启车门时&#xff0c;监测车辆侧方及侧后方的其它道路使…

pdf文件能扫码查看吗?一键做文本二维码

pdf格式是常用的一种文件格式&#xff0c;很多资料、展示性的内容都会选择这种格式&#xff0c;现在很多人都需要将文件生成二维码图片后分享给他人&#xff0c;那么文件存入二维码展示的方法有哪些呢&#xff1f;下面给大家分享一招使用二维码生成器来生成二维码图片的操作方法…

UE5学习(游戏存档,两种适应性的射线检测,时间膨胀)

游戏存档 0.建立游戏存档类 1.建立存档 命名要用规律&#xff0c;读档时根据命名调用 2.读取存档 这里是用存档时间&#xff08;秒&#xff09;验证是否有存档成功。 两种鼠标位置射线检测方法 两种适用性未使用大量项目验证&#xff0c;为个人观点 1.适用于游戏中 2.适用于…

关于Linux服务器高并发场景下系统参数优化的诸多奇技淫巧

文章目录 &#x1f50a;博主介绍&#x1f964;本文内容开篇内存优化——马达与燃油磁盘优化——加油与换胎网络参数优化——挂挡与提速进程优化——适度开疆拓土 &#x1f4e2;文章总结&#x1f4e5;博主目标 &#x1f50a;博主介绍 &#x1f31f;我是廖志伟&#xff0c;一名Ja…