由于商家传入的H5交易参数有误,该笔交易暂时无法完成,请联系商家解决。

昨天遇到一个问题,项目在线上跑的好好的,突然出现了这个

就是这个
赶紧上网查找一波,没有!!!找不到这个类型的问题
没办法看日志,经过比对,发现了这个
这个是能正常付款的

<spbill_create_ip>223.104.111.97</spbill_create_ip>

这个是付款失败的

<spbill_create_ip>127.0.0.1</spbill_create_ip>

赶紧再去翻微信文档
在这里插入图片描述
这个地方标红了
找到问题了,就是这里

获取用户ip指引
背景介绍
H5支付要求商户在统一下单接口中上传用户真实ip地址“spbill_create_ip”,为保证微信端获取的用户ip地址与商户端获取的一致,提供了以下获取用户ip的指引,希望对大家有所帮助。

没有代理的情况
在商户的前端接入层没有做代理的情况下获取ip的方式比较简单,直接获取’REMOTE_ADDR '即可。

有代理的情况
在有代理的情况下,因为要代替客户端去访问服务器,所以,当请求包经过反向代理后,在代理服务器这里这个IP数据包的IP包头做了修改,最终后端WEB服务器得到的数据包的头部源IP地址是代理服务器的IP地址。这样一来,后端服务器的程序就无法获取用户的真实ip。

nginx有代理的情况:

在nginx中配置中加入

proxy_set_header Host $host;

proxy_set_header X-Real-IP $remote_addr;

proxy_set_header X-Real-Port $remote_port;

proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

Apache有代理的情况:

vi /usr/local/apache/conf/httpd.conf

Include conf/extra/httpd-remoteip.conf

vi /usr/local/apache/conf/extra/httpd-remoteip.conf

LoadModule remoteip_module modules/mod_remoteip.so

RemoteIPHeader X-Forwarded-For

RemoteIPInternalProxy 127.0.0.1

代码 示例

string GetClientIp(CgiInput* poInput)

{

string client_ip = “”;

string strClientIPList;

GetHttpHeader(“X-Forwarded-For”, strClientIPList);

if (strClientIPList.empty())

{

GetHttpHeader(“X-Real-IP”, strClientIPList);

}

if (!strClientIPList.empty())

{

size_t iPos = strClientIPList.find( “,” );

if( iPos != std::string::npos )

{

client_ip = strClientIPList.substr( iPos );

}

else

{

client_ip = strClientIPList;

}

}

if (client_ip.empty())

{

GetHttpHeader(“PROXY_FORWARDED_FOR”, strClientIPList);

// 做下兼容

if(strClientIPList.empty())

{

client_ip = getRemoteAddr();

}

else

{

size_t iPos = strClientIPList.find( “,” );

if( iPos != std::string::npos )

{

client_ip = strClientIPList.substr( iPos );

}

else

{

client_ip = strClientIPList;

}

}

}

if(!MMPayCommFunc::IsIp(client_ip))

client_ip = getRemoteAddr();

return client_ip;

}

再次运行,成功!!!

猜你喜欢

转载自blog.csdn.net/fengshen_f/article/details/106214946