session.ctrl.php 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. <?php
  2. /**
  3. * [WeEngine System] Copyright (c) 2014 WE7.CC
  4. * WeEngine is NOT a free software, it under the license terms, visited http://www.we7.cc/ for more details.
  5. */
  6. defined('IN_IA') or exit('Access Denied');
  7. load()->model('mc');
  8. $dos = array('openid', 'userinfo', 'touch');
  9. $do = in_array($do, $dos) ? $do : 'openid';
  10. $account_api = WeAccount::create();
  11. if ($do == 'openid') {
  12. $code = $_GPC['code'];
  13. if (empty($_W['account']['oauth']) || empty($code)) {
  14. exit('通信错误,请在微信中重新发起请求');
  15. }
  16. $oauth = $account_api->getOauthInfo($code);
  17. if (!empty($oauth) && !is_error($oauth)) {
  18. $_SESSION['openid'] = $oauth['openid'];
  19. $_SESSION['session_key'] = $oauth['session_key'];
  20. $fans = mc_fansinfo($oauth['openid']);
  21. if (empty($fans)) {
  22. $record = array(
  23. 'openid' => $oauth['openid'],
  24. 'uid' => 0,
  25. 'acid' => $_W['acid'],
  26. 'uniacid' => $_W['uniacid'],
  27. 'salt' => random(8),
  28. 'updatetime' => TIMESTAMP,
  29. 'nickname' => '',
  30. 'follow' => '1',
  31. 'followtime' => TIMESTAMP,
  32. 'unfollowtime' => 0,
  33. 'tag' => '',
  34. );
  35. $email = md5($oauth['openid']).'@we7.cc';
  36. $email_exists_member = pdo_getcolumn('mc_members', array('email' => $email), 'uid');
  37. if (!empty($email_exists_member)) {
  38. $uid = $email_exists_member;
  39. } else {
  40. $default_groupid = pdo_fetchcolumn('SELECT groupid FROM ' .tablename('mc_groups') . ' WHERE uniacid = :uniacid AND isdefault = 1', array(':uniacid' => $_W['uniacid']));
  41. $data = array(
  42. 'uniacid' => $_W['uniacid'],
  43. 'email' => $email,
  44. 'salt' => random(8),
  45. 'groupid' => $default_groupid,
  46. 'createtime' => TIMESTAMP,
  47. 'password' => md5($message['from'] . $data['salt'] . $_W['config']['setting']['authkey']),
  48. 'nickname' => '',
  49. 'avatar' => '',
  50. 'gender' => '',
  51. 'nationality' => '',
  52. 'resideprovince' => '',
  53. 'residecity' => '',
  54. );
  55. pdo_insert('mc_members', $data);
  56. $uid = pdo_insertid();
  57. }
  58. $record['uid'] = $uid;
  59. $_SESSION['uid'] = $uid;
  60. pdo_insert('mc_mapping_fans', $record);
  61. }
  62. $account_api->result(0, '', array('sessionid' => $_W['session_id']));
  63. } else {
  64. $account_api->result(1, $oauth['message']);
  65. }
  66. } elseif ($do == 'userinfo') {
  67. $encrypt_data = $_GPC['encryptedData'];
  68. $iv = $_GPC['iv'];
  69. if (empty($_SESSION['session_key']) || empty($encrypt_data) || empty($iv)) {
  70. $account_api->result(1, '请先登录');
  71. }
  72. $sign = sha1($_POST['rawData'].$_SESSION['session_key']);
  73. if ($sign !== $_GPC['signature']) {
  74. $account_api->result(1, '签名错误');
  75. }
  76. $userinfo = $account_api->pkcs7Encode($encrypt_data, $iv);
  77. $userinfo['nickname'] = $userinfo['nickName'];
  78. $_SESSION['userinfo'] = base64_encode(iserializer($userinfo));
  79. $fans = mc_fansinfo($userinfo['openId']);
  80. $fans_update = array(
  81. 'nickname' => $userinfo['nickName'],
  82. 'unionid' => $userinfo['unionId'],
  83. 'tag' => base64_encode(iserializer(array(
  84. 'subscribe' => 1,
  85. 'openid' => $userinfo['openId'],
  86. 'nickname' => $userinfo['nickName'],
  87. 'sex' => $userinfo['gender'],
  88. 'language' => $userinfo['language'],
  89. 'city' => $userinfo['city'],
  90. 'province' => $userinfo['province'],
  91. 'country' => $userinfo['country'],
  92. 'headimgurl' => $userinfo['avatarUrl'],
  93. ))),
  94. );
  95. if (!empty($userinfo['unionId'])) {
  96. $union_fans = pdo_get('mc_mapping_fans', array('unionid' => $userinfo['unionId'], 'openid !=' => $userinfo['openId']));
  97. if (!empty($union_fans['uid'])) {
  98. if (!empty($fans['uid'])) {
  99. pdo_delete('mc_members', array('uid' => $fans['uid']));
  100. }
  101. $fans_update['uid'] = $union_fans['uid'];
  102. $_SESSION['uid'] = $union_fans['uid'];
  103. }
  104. }
  105. pdo_update('mc_mapping_fans', $fans_update, array('fanid' => $fans['fanid']));
  106. pdo_update('mc_members', array('nickname' => $userinfo['nickName'], 'avatar' => $userinfo['avatarUrl'], 'gender' => $userinfo['gender']), array('uid' => $fans['uid']));
  107. $member = mc_fetch($fans['uid']);
  108. unset($member['password']);
  109. unset($member['salt']);
  110. $account_api->result(0, '', $member);
  111. }