开放平台无跳转微信登录 PHP版

  • index.html
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  6. <meta http-equiv="X-UA-Compatible" content="ie=edge">
  7. <title>测试微信扫码登陆</title>
  8. </head>
  9. <body>
  10. <img id="qrcode" src="" />
  11. <h1 id="code"></h1>
  12. <p style="font-weight: 600">使用您的应用测试?</p>
  13. <p>您的AppID:<input type="text" id="appid" /></p>
  14. <p>开放平台设置的授权回调域(以http/https开头):<input type="text" id="redirectUri" /></p>
  15. <p><input type="button" value="测试" id="test" /></p>
  16. <a href="https://github.com/yi-ge/weixin-login-php"><img style="position: absolute; top: 0; right: 0; border: 0;" src="" alt="Fork me on GitHub"></a>
  17. <script src="https://cdn.staticfile.org/jquery/3.3.1/jquery.min.js"></script>
  18. <script>
  19. function GetQueryString(name) {
  20. var reg = new RegExp("(^|&)"+ name +"=([^&]*)(&|$)");
  21. var r = window.location.search.substr(1).match(reg);
  22. if(r!=null)return unescape(r[2]); return '';
  23. }
  24. $(function () {
  25. var getCode = function (uuid, last) {
  26. $.ajax({
  27. type: "GET",
  28. url: window.location.origin + "/weixin-login-php/weixin.php?uuid=" + uuid + (last ? '&last=' + last : ''),
  29. dataType: "json",
  30. cache: !1,
  31. timeout: 6e4,
  32. success: function (data) {
  33. if (data.status === 405) {
  34. $('#code').text('登陆成功,code = ' + data.result.code)
  35. } else if (data.status === 404) {
  36. $('#code').text(data.msg.title + ', ' + data.msg.content)
  37. getCode(uuid, data.result.wxErrCode)
  38. } else if (data.status === 403) {
  39. $('#code').text(data.msg.title + ', ' + data.msg.content)
  40. getCode(uuid, data.result.wxErrCode)
  41. } else if (data.status === 500) {
  42. getUUID()
  43. } else {
  44. setTimeout(function () {
  45. getCode(uuid)
  46. }, 2000)
  47. }
  48. },
  49. error: function () {
  50. setTimeout(function () {
  51. getCode(uuid)
  52. }, 2000)
  53. }
  54. })
  55. }
  56. var getUUID = function (uuid) {
  57. $.ajax({
  58. type: "GET",
  59. url: window.location.origin + "/weixin-login-php/weixin.php?appid=" + GetQueryString("appid") + "&redirect_uri=" + GetQueryString("redirect_uri"),
  60. dataType: "json",
  61. cache: !1,
  62. timeout: 6e4,
  63. success: function (data) {
  64. if (data.status === 1) {
  65. var uuid = data.result.wxUUID
  66. $('#qrcode').attr('src', data.result.imgData)
  67. getCode(uuid)
  68. } else {
  69. setTimeout(function () {
  70. window.location.reload();
  71. }, 2000)
  72. }
  73. },
  74. error: function () {
  75. setTimeout(function () {
  76. window.location.reload();
  77. }, 2000)
  78. }
  79. })
  80. }
  81. $("#appid").val(GetQueryString("appid"))
  82. $("#redirectUri").val(GetQueryString("redirect_uri"))
  83. $("#test").click(function () {
  84. window.location.href = window.location.origin + "/weixin-login-php/index.html?appid=" + $("#appid").val() + "&redirect_uri=" + $("#redirectUri").val();
  85. })
  86. getUUID()
  87. });
  88. </script>
  89. </body>
  90. </html>
  • index.php
  1. <?php
  2. header('Content-Type: application/json; charset=utf-8');
  3. header('Access-Control-Allow-Headers: Authorization, DNT, User-Agent, Keep-Alive, Origin, X-Requested-With, Content-Type, Accept, x-clientid');
  4. header('Access-Control-Allow-Methods: PUT, POST, GET, DELETE, OPTIONS');
  5. header('Access-Control-Allow-Origin: *');
  6. if (!empty($_GET['uuid'])) {
  7. $ch = curl_init();
  8. curl_setopt($ch, CURLOPT_URL, 'https://long.open.weixin.qq.com/connect/l/qrconnect?uuid=' . $_GET['uuid'] . (empty($_GET['last']) ? '' : '&last=' . $_GET['last']));
  9. curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
  10. curl_setopt($ch, CURLOPT_HEADER, 0);
  11. curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 60);
  12. curl_setopt($ch, CURLOPT_HTTPHEADER, array('Cache-Control: no-cache', 'User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_13_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/70.0.3522.0 Safari/537.36'));
  13. $output = curl_exec($ch);
  14. curl_close($ch);
  15. $preg = '/window.wx_errcode=(.*?);w/i';
  16. $preg1 = "/window.wx_code='(.*?)';/i";
  17. preg_match_all($preg, $output, $res);
  18. $wxErrCode = $res[1][0];
  19. switch ($wxErrCode) {
  20. case 405:
  21. preg_match_all($preg1, $output, $res);
  22. $wxCode = $res[1][0];
  23. $r = array(
  24. 'status' => 405,
  25. 'msg' => '登陆成功',
  26. 'result' => array(
  27. 'code' => $wxCode,
  28. ),
  29. );
  30. break;
  31. case 404:
  32. $r = array(
  33. 'status' => 404,
  34. 'msg' => array(
  35. 'title' => '登陆成功',
  36. 'content' => '请在微信中点击确认即可登录',
  37. ),
  38. 'result' => array(
  39. 'wxErrCode' => $wxErrCode,
  40. ),
  41. );
  42. break;
  43. case 403:
  44. $r = array(
  45. 'status' => 403,
  46. 'msg' => array(
  47. 'title' => '您已取消此次登录',
  48. 'content' => '您可再次扫描登录,或关闭窗口',
  49. ),
  50. 'result' => array(
  51. 'wxErrCode' => $wxErrCode,
  52. ),
  53. );
  54. break;
  55. case 402:
  56. case 500:
  57. $r = array(
  58. 'status' => 500,
  59. 'msg' => '需要重新获取uuid',
  60. );
  61. break;
  62. case 408:
  63. $r = array(
  64. 'status' => 408,
  65. 'msg' => '需要再次请求',
  66. );
  67. break;
  68. }
  69. echo json_encode($r);
  70. } else {
  71. $ch = curl_init();
  72. $appid = empty($_GET['appid']) ? 'wx827225356b689e24' : $_GET['appid'];
  73. $redirect_uri = empty($_GET['redirect_uri']) ? 'https://qq.jd.com/' : $_GET['redirect_uri'];
  74. $redirect_uri = urlencode(iconv('gb2312', 'UTF-8', $redirect_uri));
  75. curl_setopt($ch, CURLOPT_URL, 'https://open.weixin.qq.com/connect/qrconnect?appid=' . $appid . '&scope=snsapi_login&redirect_uri=' . $redirect_uri . '&state=&login_type=jssdk&self_redirect=default');
  76. curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
  77. curl_setopt($ch, CURLOPT_HEADER, 0);
  78. curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 60);
  79. curl_setopt($ch, CURLOPT_HTTPHEADER, array('Cache-Control: no-cache', 'User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_13_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/70.0.3522.0 Safari/537.36'));
  80. $output = curl_exec($ch);
  81. curl_close($ch);
  82. $preg = '/src="\/connect\/qrcode\/(.*?)" \/>/i';
  83. preg_match_all($preg, $output, $res);
  84. $uuid = $res[1][0];
  85. if (isset($_GET['img'])) { // 不推荐 - 如果设置了img参数,则返回图片的下载地址,但此地址无法解决Chrome70不信任腾讯域名证书的问题
  86. $r = array('status' => 1, 'result' => array('wxUUID' => $uuid, 'imgURL' => 'https://open.weixin.qq.com/connect/qrcode/' . $uuid));
  87. } else {
  88. $ch = curl_init();
  89. curl_setopt($ch, CURLOPT_URL, 'https://open.weixin.qq.com/connect/qrcode/' . $uuid);
  90. curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
  91. curl_setopt($ch, CURLOPT_HEADER, 0);
  92. curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 60);
  93. curl_setopt($ch, CURLOPT_HTTPHEADER, array('Cache-Control: no-cache', 'User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_13_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/70.0.3522.0 Safari/537.36'));
  94. $output = curl_exec($ch);
  95. curl_close($ch);
  96. $r = array('status' => 1, 'result' => array('wxUUID' => $uuid, 'imgData' => 'data:image/jpeg;base64,' . base64_encode($output)));
  97. }
  98. echo json_encode($r);
  99. }


评论 1

发表评论

Top