一个微信开发URL转跳的问题
先贴代码:
<code> public function getWxopneURL() { $code = I('get.code','','trim'); if(empty($code)){ $redirect_uri = urlencode(get_url()); $url = 'https://open.weixin.qq.com/connect/oauth2/authorize?appid='.$this->appid.'&redirect_uri='.$redirect_uri.'&response_type=code&scope=snsapi_base&state=oauth&connect_redirect=1#wechat_redirect'; file_put_contents('url.log', $url); return header("Location:".$url); } //获取access_token $access_token = file_get_contents("https://api.weixin.qq.com/sns/oauth2/access_token?appid=".$this->appid."&secret=".$this->key."&code=".$code."&grant_type=authorization_code"); $access_token = json_decode($access_token,true); return $access_token['openid']; }</code>
<code>/** * 获取当前页面完整URL地址 */ function get_url($val='',$valb='',$var=array()) { $sys_protocal = isset($_SERVER['SERVER_PORT']) && $_SERVER['SERVER_PORT'] == '443' ? 'https://' : 'http://'; if($valb == 'img'){ if (strstr($val,'http:')) return $val; return $sys_protocal.(isset($_SERVER['HTTP_HOST']) ? $_SERVER['HTTP_HOST'] : '').$val; }elseif($valb == 'url'){ $var['token'] = $GLOBALS['userinfo']['token']; if (strstr($val,'http:')) return $val; return $sys_protocal.(isset($_SERVER['HTTP_HOST']) ? $_SERVER['HTTP_HOST'] : '').U($val,$var); } if ($GLOBALS['userinfo']){ $var = $_GET; if(count(explode('emp_car',$_SERVER['REQUEST_URI'])) == 1) { $var['token'] = $GLOBALS['userinfo']['token']; } $relate_url = U('',$var) ; }else{ $php_self = $_SERVER['PHP_SELF'] ? $_SERVER['PHP_SELF'] : $_SERVER['SCRIPT_NAME']; $path_info = isset($_SERVER['PATH_INFO']) ? $_SERVER['PATH_INFO'] : ''; $relate_url = isset($_SERVER['REQUEST_URI']) ? $_SERVER['REQUEST_URI'] : $php_self.(isset($_SERVER['QUERY_STRING']) ? '?'.$_SERVER['QUERY_STRING'] : $path_info); } return $sys_protocal.(isset($_SERVER['HTTP_HOST']) ? $_SERVER['HTTP_HOST'] : '').$relate_url; }</code>
===================================
出现问题如下:
微信菜单中需要打开一个连接,
链接长这个样子:
http://rusice.tunnel.qydev.co...
在本地我是用ugrok做穿透,win平台。是可以访问的。
但是今天放到服务器上,linux环境。就出现了问题了。
抓取到的url是这样的:
<code>https://open.weixin.qq.com/connect/oauth2/authorize?appid=wxdd658ea6d4dbc597&redirect_uri=http%3A%2F%2Fwx.mytbu.cn%2Findex.php%3Fg%3DActivity%26m%3DDoVote&response_type=code&scope=snsapi_base&state=oauth&connect_redirect=1#wechat_redirect</code>
后来我试了一下,不带参数,只有域名 是可能的。
然后带一个参数 也是可以的,带2个参数就不行了。 这个问题找了一整天了,希望有人可以出手相助,谢谢!
回复内容:
先贴代码:
<code> public function getWxopneURL() { $code = I('get.code','','trim'); if(empty($code)){ $redirect_uri = urlencode(get_url()); $url = 'https://open.weixin.qq.com/connect/oauth2/authorize?appid='.$this->appid.'&redirect_uri='.$redirect_uri.'&response_type=code&scope=snsapi_base&state=oauth&connect_redirect=1#wechat_redirect'; file_put_contents('url.log', $url); return header("Location:".$url); } //获取access_token $access_token = file_get_contents("https://api.weixin.qq.com/sns/oauth2/access_token?appid=".$this->appid."&secret=".$this->key."&code=".$code."&grant_type=authorization_code"); $access_token = json_decode($access_token,true); return $access_token['openid']; }</code>
<code>/** * 获取当前页面完整URL地址 */ function get_url($val='',$valb='',$var=array()) { $sys_protocal = isset($_SERVER['SERVER_PORT']) && $_SERVER['SERVER_PORT'] == '443' ? 'https://' : 'http://'; if($valb == 'img'){ if (strstr($val,'http:')) return $val; return $sys_protocal.(isset($_SERVER['HTTP_HOST']) ? $_SERVER['HTTP_HOST'] : '').$val; }elseif($valb == 'url'){ $var['token'] = $GLOBALS['userinfo']['token']; if (strstr($val,'http:')) return $val; return $sys_protocal.(isset($_SERVER['HTTP_HOST']) ? $_SERVER['HTTP_HOST'] : '').U($val,$var); } if ($GLOBALS['userinfo']){ $var = $_GET; if(count(explode('emp_car',$_SERVER['REQUEST_URI'])) == 1) { $var['token'] = $GLOBALS['userinfo']['token']; } $relate_url = U('',$var) ; }else{ $php_self = $_SERVER['PHP_SELF'] ? $_SERVER['PHP_SELF'] : $_SERVER['SCRIPT_NAME']; $path_info = isset($_SERVER['PATH_INFO']) ? $_SERVER['PATH_INFO'] : ''; $relate_url = isset($_SERVER['REQUEST_URI']) ? $_SERVER['REQUEST_URI'] : $php_self.(isset($_SERVER['QUERY_STRING']) ? '?'.$_SERVER['QUERY_STRING'] : $path_info); } return $sys_protocal.(isset($_SERVER['HTTP_HOST']) ? $_SERVER['HTTP_HOST'] : '').$relate_url; }</code>
===================================
出现问题如下:
微信菜单中需要打开一个连接,
链接长这个样子:
http://rusice.tunnel.qydev.co...
在本地我是用ugrok做穿透,win平台。是可以访问的。
但是今天放到服务器上,linux环境。就出现了问题了。
抓取到的url是这样的:
<code>https://open.weixin.qq.com/connect/oauth2/authorize?appid=wxdd658ea6d4dbc597&redirect_uri=http%3A%2F%2Fwx.mytbu.cn%2Findex.php%3Fg%3DActivity%26m%3DDoVote&response_type=code&scope=snsapi_base&state=oauth&connect_redirect=1#wechat_redirect</code>
后来我试了一下,不带参数,只有域名 是可能的。
然后带一个参数 也是可以的,带2个参数就不行了。 这个问题找了一整天了,希望有人可以出手相助,谢谢!
配置了授权登录的可信域名吗
这是url解析规则问题啊,因为&m=默认认定为微信接口的参数。redirect_uri=http://wx.mytbu.cn/index.php?g=Activity&m=DoVote
?
后的参数g认为是你页面index.php的参数,而&
后的m认为是前面微信接口authorize页面的参数。
弄了2天的问题终于解决了,原来是需要配置回调域名。找了半天才在下面找到一个修改的入口。。。这算是一个坑吗
更坑的是微信官方demo的bug

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

JWT是一种基于JSON的开放标准,用于在各方之间安全地传输信息,主要用于身份验证和信息交换。1.JWT由Header、Payload和Signature三部分组成。2.JWT的工作原理包括生成JWT、验证JWT和解析Payload三个步骤。3.在PHP中使用JWT进行身份验证时,可以生成和验证JWT,并在高级用法中包含用户角色和权限信息。4.常见错误包括签名验证失败、令牌过期和Payload过大,调试技巧包括使用调试工具和日志记录。5.性能优化和最佳实践包括使用合适的签名算法、合理设置有效期、

在PHP8 中,match表达式是一种新的控制结构,用于根据表达式的值返回不同的结果。1)它类似于switch语句,但返回值而非执行语句块。2)match表达式使用严格比较(===),提升了安全性。3)它避免了switch语句中可能的break遗漏问题,增强了代码的简洁性和可读性。

在PHP中可以通过使用不可预测的令牌来有效防范CSRF攻击。具体方法包括:1.生成并在表单中嵌入CSRF令牌;2.在处理请求时验证令牌的有效性。

PHP中的...(splat)操作符用于函数参数和数组解包,提升代码简洁性和效率。1)函数参数解包:将数组元素作为参数传递给函数。2)数组解包:将一个数组解包到另一个数组中或作为函数参数。

在PHP中,final关键字用于防止类被继承和方法被重写。1)标记类为final时,该类不能被继承。2)标记方法为final时,该方法不能被子类重写。使用final关键字可以确保代码的稳定性和安全性。

无法以 root 身份登录 MySQL 的原因主要在于权限问题、配置文件错误、密码不符、socket 文件问题或防火墙拦截。解决方法包括:检查配置文件中 bind-address 参数是否正确配置。查看 root 用户权限是否被修改或删除,并进行重置。验证密码是否准确无误,包括大小写和特殊字符。检查 socket 文件权限设置和路径。检查防火墙是否阻止了 MySQL 服务器的连接。

PHP中的严格类型通过在文件顶部添加declare(strict_types=1);来启用。1)它强制对函数参数和返回值进行类型检查,防止隐式类型转换。2)使用严格类型可以提高代码的可靠性和可预测性,减少bug,提升可维护性和可读性。

C语言条件编译是一种根据编译时条件选择性编译代码块的机制,入门方法有:使用#if和#else指令根据条件选择代码块。常用条件表达式包括STDC、_WIN32和linux。实战案例:根据操作系统打印不同消息。根据系统位数使用不同的数据类型。根据编译器支持不同的头文件。条件编译增强了代码的可移植性和灵活性,使其适应编译器、操作系统和CPU架构变化。
