webmanger.php 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450
  1. <?php
  2. /**
  3. * Created by PhpStorm.
  4. * User: sicilon_IT
  5. * Date: 2020/1/22
  6. * Time: 21:19
  7. */
  8. namespace app\index\logic;
  9. use app\index\model\rolesmodel;
  10. use app\index\model\roleusermodel;
  11. use app\index\model\webusermodel;
  12. use think\Log;
  13. class webmanger
  14. {
  15. public function getlogininfo($lname, $lpwd)
  16. {
  17. $webusertable = new webusermodel();
  18. $userinfo = $webusertable->getlogininfo($lname, $lpwd);
  19. //var_dump($userinfo);
  20. return $userinfo;
  21. }
  22. /**
  23. * 校验登录 并修改token
  24. */
  25. public function userlogin($lname, $lpwd, $updateToken = true)
  26. {
  27. $m_wu = new webusermodel();
  28. $userinfo = $m_wu->getlogininfomd5($lname, $lpwd);
  29. if (empty($userinfo)) {
  30. return backarr(0, '无用户信息');
  31. }
  32. $token = $userinfo['token'];
  33. if ($updateToken) {
  34. $result = $this->updateToken($userinfo['id']);
  35. if (1 != $result['status']) {
  36. return $result;
  37. }
  38. }
  39. $token = $result['data']['token'];
  40. return backarr(1, '登录成功', ['token' => $token, 'id' => $userinfo['id']]);
  41. }
  42. /**
  43. * 用户登出
  44. * 改用户token
  45. * 20211204
  46. * wj
  47. */
  48. public function updateToken($uid = 0)
  49. {
  50. $m_wu = new webusermodel();
  51. $m_r = new rolesmodel();
  52. $m_ru = new roleusermodel();
  53. $rwhere = ['name' => '普通用户', 'is_active' => 1];
  54. $rid = 0; //不改token组id
  55. $userinfo = [];
  56. $rinfo = $m_r->getInfo($rwhere);
  57. if (!empty($rinfo)) {
  58. $rid = $rinfo['id'];
  59. }
  60. if (empty($uid)) {
  61. $token = request()->server('HTTP_TOKEN');
  62. if (empty($token)) {
  63. return backarr(0, "无token数据");
  64. }
  65. $where = ['token' => $token];
  66. $field = ['id', 'user_name', 'token'];
  67. $userinfo = $m_wu->getInfo($where, $field);
  68. } else {
  69. $where = ['id' => $uid];
  70. $field = ['id', 'user_name', 'token'];
  71. $userinfo = $m_wu->getInfo($where);
  72. }
  73. if (empty($userinfo)) {
  74. return backarr(0, "无用户信息");
  75. }
  76. $ruwhere = ['uid' => $userinfo['id']];
  77. $ruinfo = $m_ru->getInfo($ruwhere);
  78. $changeToken = true;
  79. if (!empty($ruinfo) && !empty($rid)) {
  80. if ($ruinfo['rid'] == $rid) {
  81. $changeToken = false;
  82. }
  83. }
  84. if ($changeToken) {
  85. $token = $this->getToken($userinfo['user_name']);
  86. $updateData = [
  87. 'token' => $token,
  88. ];
  89. $where = ['id' => $userinfo['id']];
  90. $row = $m_wu->updateinfo($where, $updateData);
  91. if (empty($row)) {
  92. log::info($userinfo['user_name'] . " token 修改失败");
  93. return backarr(0, "token 修改失败");
  94. }
  95. } else {
  96. $token = $userinfo['token'];
  97. }
  98. return backarr(1, "操作成功", ['uid' => $userinfo['id'], 'token' => $token]);
  99. }
  100. /***
  101. * 获取用户token
  102. */
  103. private function getToken($username)
  104. {
  105. $str = md5(uniqid(md5(microtime(true)), true));
  106. $token = sha1($str . $username);
  107. return $token;
  108. }
  109. /**
  110. * 获取用户信息 权限组名 和头像 待改
  111. * 20211101
  112. * wj
  113. */
  114. public function queryinfobytoken($arr)
  115. {
  116. if (!isset($arr['token']) || empty($arr['token'])) {
  117. return backarr(0, "请求错误");
  118. }
  119. $defaultData = [
  120. //'access' => 'admin',
  121. 'avatar' => 'https://file.iviewui.com/dist/a0e88e83800f138b94d2414621bd9704.png',
  122. ];
  123. $token = $arr['token'];
  124. $m_wu = new webusermodel();
  125. $where = ['token' => $token];
  126. $field = ['id', 'user_name'];
  127. $userinfo = $m_wu->getInfo($where, $field);
  128. if (empty($userinfo)) {
  129. return backarr(0, "无用户数据");
  130. }
  131. //获取权限组名
  132. $m_ru = new roleusermodel();
  133. $ruwhere = [
  134. 'uid' => $userinfo['id'],
  135. ];
  136. $ruinfo = $m_ru->getInfo($ruwhere);
  137. if (!empty($ruinfo)) {
  138. $rwhere = [
  139. 'id' => $ruinfo['rid'],
  140. 'is_active' => 1,
  141. ];
  142. $m_r = new rolesmodel();
  143. $rinfo = $m_r->getInfo($rwhere);
  144. if ($rinfo) {
  145. $userinfo['access'] = $rinfo['flag_bit'];
  146. }
  147. }
  148. if (!isset($userinfo['access'])) {
  149. $userinfo['access'] = "";
  150. }
  151. if (empty($userinfo)) {
  152. return backarr(0, "无数据");
  153. } else {
  154. $userinfo = array_merge($defaultData, $userinfo->toArray());
  155. return backarr(1, "查询成功", $userinfo);
  156. }
  157. }
  158. /***
  159. * 获取用户信息 通过id
  160. * 20211103
  161. * wj
  162. */
  163. public function queryinfobyid($arr)
  164. {
  165. $id = $arr['id'];
  166. $m_wu = new webusermodel();
  167. $where = ['id' => $id];
  168. $fields = ['id', 'user_name', 'email', 'create_date', 'isactive', 'create_id'];
  169. $userinfo = $m_wu->getInfo($where, $fields);
  170. if (empty($userinfo)) {
  171. return backarr(0, "无数据");
  172. }
  173. if (!empty($userinfo['create_id'])) {
  174. $where = ['id' => $userinfo['create_id']];
  175. $createinfo = $m_wu->getInfo($where, ['user_name']);
  176. $userinfo['create_user_name'] = $createinfo['user_name'];
  177. }
  178. return backarr(1, "查询成功", $userinfo);
  179. }
  180. public function queryinfowitchsetting($id)
  181. {
  182. $m_wu = new webusermodel();
  183. $m_ru = new roleusermodel();
  184. $where = ['id' => $id];
  185. $fields = ['id', 'user_name', 'email', 'create_date', 'isactive', 'create_id'];
  186. $userinfo = $m_wu->getInfo($where, $fields);
  187. if (empty($userinfo)) {
  188. return backarr(0, "无数据");
  189. }
  190. if (!empty($userinfo['create_id'])) {
  191. $where = ['id' => $userinfo['create_id']];
  192. $createinfo = $m_wu->getInfo($where, ['user_name']);
  193. $userinfo['create_user_name'] = $createinfo['user_name'];
  194. }
  195. $userinfo['setting'] = ['access' => '', 'access_name' => ''];
  196. $roleinfo = $m_ru->getinfoforuser($id);
  197. if ($roleinfo) {
  198. $roleinfo = $roleinfo[0];
  199. $setting = [
  200. 'access' => $roleinfo['flag_bit'],
  201. 'access_name' => $roleinfo['name'],
  202. ];
  203. $userinfo['setting'] = $setting;
  204. }
  205. return backarr(1, "查询成功", $userinfo);
  206. }
  207. public function editwebuser($arr)
  208. {
  209. if (isset($arr['id']) && !empty($arr['id'])) {
  210. $result = $this->updatewebuserinfo($arr);
  211. } else {
  212. $result = $this->newwebuser($arr);
  213. }
  214. return $result;
  215. }
  216. /**
  217. * 新建web用户
  218. * 登录名不可重复
  219. */
  220. public function newwebuser($arr)
  221. {
  222. $name = $arr['name'];
  223. $m_wu = new webusermodel();
  224. $where = ['user_name' => $name];
  225. $userinfo = $m_wu->getInfo($where);
  226. if ($userinfo) {
  227. return backarr(0, "用户已存在");
  228. }
  229. $insertData = [];
  230. $insertData['user_name'] = $name;
  231. $insertData['user_password'] = md5($name . $arr['password']);
  232. $insertData['token'] = $this->getToken($name);
  233. $insertData['create_date'] = date('Y-m-d H:i:s');
  234. $insertData['create_id'] = $arr['userid'];
  235. if (isset($arr['email']) && !empty($arr['email'])) {
  236. $insertData['email'] = $arr['email'];
  237. }
  238. $id = $m_wu->insertData($insertData);
  239. if (empty($id)) {
  240. return backarr(0, "操作失败");
  241. }
  242. return backarr(1, "操作成功", ['id' => $id]);
  243. }
  244. /***
  245. * 改用户信息
  246. * 20211103
  247. * wj
  248. * 仅改用户邮箱
  249. */
  250. public function updatewebuserinfo($arr)
  251. {
  252. $id = $arr['id'];
  253. $m_wu = new webusermodel();
  254. $where = ['id' => $id];
  255. $userinfo = $m_wu->getInfo($where);
  256. if (empty($userinfo)) {
  257. return backarr(0, "用户不存在");
  258. }
  259. $updateData = [];
  260. if (isset($arr['email']) && !empty($arr['email'])) {
  261. $updateData['email'] = $arr['email'];
  262. }
  263. if (!empty($updateData)) {
  264. $row = $m_wu->updateinfo($where, $updateData);
  265. if (empty($row)) {
  266. return backarr(0, "操作失败");
  267. }
  268. return backarr(1, "操作成功", ['id' => $id]);
  269. }
  270. return backarr(0, "无修改数据");
  271. }
  272. /***
  273. * 改用户密码
  274. * 20211103
  275. * wj
  276. */
  277. public function updatepasswd($arr)
  278. {
  279. $fillfields = [
  280. 'name', 'password',
  281. ];
  282. foreach ($fillfields as $key => $value) {
  283. if (!isset($arr[$value]) || empty($arr[$value])) {
  284. return backarr(0, "请求错误");
  285. }
  286. }
  287. $m_wu = new webusermodel();
  288. $name = trim($arr['name']);
  289. $password = trim($arr['password']);
  290. $where = ['user_name' => $name];
  291. $userinfo = $m_wu->getInfo($where);
  292. if (empty($userinfo)) {
  293. return backarr(0, "用户不存在");
  294. }
  295. $updateData = [
  296. 'user_password' => md5($name . $password),
  297. 'token' => $this->getToken($name),
  298. ];
  299. $id = $userinfo['id'];
  300. $where = ['id' => $id];
  301. $row = $m_wu->updateinfo($where, $updateData);
  302. if (empty($row)) {
  303. return backarr(0, "操作失败");
  304. }
  305. return backarr(1, "操作成功", ['id' => $id]);
  306. }
  307. /***
  308. * 改用户状态
  309. * 20211103
  310. * wj
  311. */
  312. public function updateisactive($arr)
  313. {
  314. $id = $arr['id'];
  315. $isactive = $arr['isactive'];
  316. $m_wu = new webusermodel();
  317. $where = ['id' => $id];
  318. $userinfo = $m_wu->getInfo($where);
  319. if (empty($userinfo)) {
  320. return backarr(0, "用户不存在");
  321. }
  322. //默认 isactive 0
  323. $isactive = in_array($isactive, [0, 1]) ? $isactive : 0;
  324. $updateData = ['isactive' => $isactive];
  325. $row = $m_wu->updateinfo($where, $updateData);
  326. if (empty($row)) {
  327. return backarr(0, "操作失败");
  328. }
  329. return backarr(1, "操作成功", ['id' => $id]);
  330. }
  331. /***
  332. * 获取用户列表
  333. * 20211103
  334. * wj
  335. */
  336. public function getalllist($arr)
  337. {
  338. $searchData = [];
  339. if (isset($arr['userName']) && !empty($arr['userName'])) {
  340. $searchData['user_name'] = ['like', '%' . $arr['userName'] . '%'];
  341. }
  342. if (isset($arr['isactive']) && in_array($arr['isactive'], [0, 1]) && is_numeric($arr['isactive'])) {
  343. $searchData['isactive'] = $arr['isactive'];
  344. }
  345. $m_wu = new webusermodel();
  346. $count = $m_wu->getList($searchData, 'count');
  347. if ($count <= 0) {
  348. return backarr(0, "无数据");
  349. }
  350. $page = !isset($arr['page']) || empty($arr['page']) ? 1 : $arr['page'];
  351. $size = !isset($arr['size']) || empty($arr['size']) ? 10 : $arr['size'];
  352. $fields = ['id'];
  353. $list = $m_wu->getList($searchData, $fields, $page, $size);
  354. foreach ($list as $key => &$value) {
  355. $result = $this->queryinfowitchsetting($value['id']);
  356. if (1 != $result['status']) {
  357. return backarr(0, $result['msg']);
  358. }
  359. $list[$key] = $result['data'];
  360. }
  361. $data = [
  362. 'count' => $count,
  363. 'list' => $list->toArray(),
  364. ];
  365. return backarr(1, "查询成功", $data);
  366. }
  367. /**
  368. * 按照id查用户信息
  369. * 20211110
  370. * wj
  371. */
  372. public function searchUserInfo($arr)
  373. {
  374. $id = 0;
  375. if (isset($arr['id']) && !empty($arr['id'])) {
  376. $id = $arr['id'];
  377. }
  378. if (empty($id)) {
  379. return backarr(0, "无数据");
  380. }
  381. $result = $this->queryinfowitchsetting($id);
  382. return $result;
  383. }
  384. /**
  385. * 保存用户和用户组关系
  386. * 20211110
  387. * wj
  388. */
  389. public function saveuserrole($arr)
  390. {
  391. $fillfields = ['access', 'uid'];
  392. foreach ($fillfields as $key => $value) {
  393. if (!isset($arr[$value]) || !isset($arr[$value])) {
  394. return backarr(0, "请求错误");
  395. }
  396. }
  397. $m_r = new rolesmodel();
  398. $m_wu = new webusermodel();
  399. $m_ru = new roleusermodel();
  400. $userid = $arr['uid'];
  401. $access = $arr['access'];
  402. $mrinfo = $m_r->getInfo(['flag_bit' => $access, 'is_active' => 1]);
  403. if (empty($mrinfo)) {
  404. return backarr(0, "无权限组");
  405. }
  406. $wuinfo = $m_wu->getInfo(['id' => $userid]);
  407. if (empty($wuinfo)) {
  408. return backarr(0, "用户不存在");
  409. }
  410. $ruinfo = $m_ru->getInfo(['uid' => $userid]);
  411. if (empty($ruinfo)) {
  412. $insertData = [
  413. 'uid' => $userid,
  414. 'rid' => $mrinfo['id'],
  415. ];
  416. $id = $m_ru->insertData($insertData);
  417. } else {
  418. $ruwhere = ['id' => $ruinfo['id']];
  419. $updateData = [
  420. 'rid' => $mrinfo['id'],
  421. ];
  422. $row = $m_ru->updateinfo($ruwhere, $updateData);
  423. if ($row <= 0) {
  424. $id = 0;
  425. } else {
  426. $id = $ruinfo['id'];
  427. }
  428. }
  429. if (empty($id)) {
  430. return backarr(0, "操作失败");
  431. }
  432. return backarr(1, "操作成功", ['id' => $id]);
  433. }
  434. }