/// <summary> /// <para>查询企业付款银行卡</para> /// <para>注意:请求需要双向证书</para> /// </summary> /// <param name="dataInfo"></param> /// <param name="timeOut"></param> /// <param name="cert">证书路径</param> /// <param name="certPassword">证书密码</param> /// <returns></returns> public static QueryBankResult QueryBank( IServiceProvider serviceProvider, TenPayV3QueryBankRequestData dataInfo, #if NET451 string cert, string certPassword, #endif int timeOut = Config.TIME_OUT) { var urlFormat = ReurnPayApiUrl("https://api.mch.weixin.qq.com/{0}mmpaysptrans/query_bank"); var data = dataInfo.PackageRequestHandler.ParseXML();//获取XML #region 弃用 //var formDataBytes = data == null ? new byte[0] : Encoding.UTF8.GetBytes(data); //MemoryStream ms = new MemoryStream(); //ms.Write(formDataBytes, 0, formDataBytes.Length); //ms.Seek(0, SeekOrigin.Begin);//设置指针读取位置 //var resultXml = RequestUtility.HttpPost(CommonDI.CommonSP, url, null, ms); #endregion #if NET451 string responseContent = CertPost(cert, certPassword, data, urlFormat, timeOut); #else string responseContent = CertPost_NetCore(serviceProvider, dataInfo.MchId, dataInfo.SubMchId, data, urlFormat, timeOut); #endif return(new QueryBankResult(responseContent)); }
/// <summary> /// <para>获取 RSA 加密公钥接口</para> /// <para>https://pay.weixin.qq.com/wiki/doc/api/tools/mch_pay.php?chapter=24_7&index=4</para> /// </summary> /// <param name="dataInfo"></param> /// <param name="cert">证书路径</param> /// <param name="certPassword">证书密码</param> /// <returns></returns> public static async Task <GetPublicKeyResult> GetPublicKeyAsync( IServiceProvider serviceProvider, TenPayV3QueryBankRequestData dataInfo, #if NET451 string cert, string certPassword, #endif int timeOut = Config.TIME_OUT) { //TODO:官方文档没有明确此接口是否支持沙箱 var urlFormat = ReurnPayApiUrl("https://fraud.mch.weixin.qq.com/{0}risk/getpublickey"); var data = dataInfo.PackageRequestHandler.ParseXML();//获取XML #region 弃用 //var formDataBytes = data == null ? new byte[0] : Encoding.UTF8.GetBytes(data); //MemoryStream ms = new MemoryStream(); //await ms.WriteAsync(formDataBytes, 0, formDataBytes.Length); //ms.Seek(0, SeekOrigin.Begin);//设置指针读取位置 //var resultXml = await RequestUtility.HttpPostAsync(CommonDI.CommonSP, urlFormat, null, ms); #endregion #if NET451 string responseContent = CertPost(cert, certPassword, data, urlFormat, timeOut); #else string responseContent = await CertPost_NetCoreAsync(serviceProvider, dataInfo.MchId, dataInfo.SubMchId, data, urlFormat, timeOut).ConfigureAwait(false); #endif return(new GetPublicKeyResult(responseContent)); }
/// <summary> /// <para>查询企业付款银行卡</para> /// <para>注意:请求需要双向证书</para> /// </summary> /// <param name="dataInfo"></param> /// <param name="timeOut"></param> /// <param name="cert">证书路径</param> /// <param name="certPassword">证书密码</param> /// <returns></returns> public static async Task <QueryBankResult> QueryBankAsync( IServiceProvider serviceProvider, TenPayV3QueryBankRequestData dataInfo, #if NET462 string cert, string certPassword, #endif int timeOut = Config.TIME_OUT) { var urlFormat = ReurnPayApiUrl(Senparc.Weixin.Config.TenPayV3Host + "/{0}mmpaysptrans/query_bank"); var data = dataInfo.PackageRequestHandler.ParseXML();//获取XML #region 弃用 //var formDataBytes = data == null ? new byte[0] : Encoding.UTF8.GetBytes(data); //MemoryStream ms = new MemoryStream(); //await ms.WriteAsync(formDataBytes, 0, formDataBytes.Length); //ms.Seek(0, SeekOrigin.Begin);//设置指针读取位置 //var resultXml = await RequestUtility.HttpPostAsync(CommonDI.CommonSP, urlFormat, null, ms); #endregion #if NET462 string responseContent = CertPost(cert, certPassword, data, urlFormat, timeOut); #else string responseContent = await CertPost_NetCoreAsync(serviceProvider, dataInfo.MchId, dataInfo.SubMchId, data, urlFormat, timeOut).ConfigureAwait(false); #endif return(new QueryBankResult(responseContent)); }
/// <summary> /// <para>查询企业付款银行卡</para> /// <para>注意:请求需要双向证书</para> /// </summary> /// <param name="dataInfo"></param> /// <param name="cert">证书路径</param> /// <param name="certPassword">证书密码</param> /// <returns></returns> public static QueryBankResult QueryBank(TenPayV3QueryBankRequestData dataInfo, string cert, string certPassword) { var urlFormat = ReurnPayApiUrl("https://api.mch.weixin.qq.com/{0}mmpaysptrans/query_bank"); var data = dataInfo.PackageRequestHandler.ParseXML();//获取XML #region 弃用 //var formDataBytes = data == null ? new byte[0] : Encoding.UTF8.GetBytes(data); //MemoryStream ms = new MemoryStream(); //ms.Write(formDataBytes, 0, formDataBytes.Length); //ms.Seek(0, SeekOrigin.Begin);//设置指针读取位置 //var resultXml = RequestUtility.HttpPost(url, null, ms); #endregion var resultXml = CertPost(cert, certPassword, data, urlFormat); return(new QueryBankResult(resultXml)); }
/// <summary> /// <para>获取 RSA 加密公钥接口</para> /// <para>https://pay.weixin.qq.com/wiki/doc/api/tools/mch_pay.php?chapter=24_7&index=4</para> /// </summary> /// <param name="dataInfo"></param> /// <param name="cert">证书路径</param> /// <param name="certPassword">证书密码</param> /// <returns></returns> public static async Task <GetPublicKeyResult> GetPublicKeyAsync(TenPayV3QueryBankRequestData dataInfo, string cert, string certPassword) { //TODO:官方文档没有明确此接口是否支持沙箱 var urlFormat = ReurnPayApiUrl("https://fraud.mch.weixin.qq.com/{0}risk/getpublickey"); var data = dataInfo.PackageRequestHandler.ParseXML();//获取XML #region 弃用 //var formDataBytes = data == null ? new byte[0] : Encoding.UTF8.GetBytes(data); //MemoryStream ms = new MemoryStream(); //await ms.WriteAsync(formDataBytes, 0, formDataBytes.Length); //ms.Seek(0, SeekOrigin.Begin);//设置指针读取位置 //var resultXml = await RequestUtility.HttpPostAsync(urlFormat, null, ms); #endregion var resultXml = await CertPostAsync(cert, certPassword, data, urlFormat); return(new GetPublicKeyResult(resultXml)); }