| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314 |
- <template>
- <view class="login">
- <view class="content">
- <!-- 头部logo -->
- <view class="header">
- <image :src="logoImage"></image>
- </view>
- <!-- 主体表单 -->
- <view class="main">
- <wInput v-model="username" type="text" placeholder="用户名" :focus="isFocus"></wInput>
- <wInput v-model="password" type="text" placeholder="登录密码"></wInput>
- </view>
- <wButton class="wbutton" text="登 录" :rotate="isRotate" @click="startLogin"></wButton>
- <view style="height: 100rpx;"></view>
- </view>
- </view>
- </template>
- <script>
- import wInput from '../../components/watch-login/watch-input.vue'
- import wButton from '../../components/watch-login/watch-button.vue'
- var _self
- var code
- export default {
- data() {
- return {
- logoImage: '',
- username: 'aaaaa', //用户/电话
- password: 'aaaaa', //密码
- isRotate: false, //是否加载旋转
- isFocus: true // 是否聚焦
- };
- },
- components: {
- wInput,
- wButton,
- },
- mounted() {
- },
- onLoad() {
- _self = this
- _self.isLogin()
- wx.login({
- success(res) {
- if (res.code) {
- code = res.code
- }
- }
- })
- },
- methods: {
- isLogin() {
- //判断缓存中是否登录过,直接登录
- try {
- const token = uni.getStorageSync('equipment_token');
- const equipmentManage = uni.getStorageSync('equipment_manage');
- if (token) {
- //有登录信息
- getApp().globalData.token = token
- getApp().globalData.equipmentManage = equipmentManage
- const eventChannel = _self.getOpenerEventChannel()
- eventChannel.emit('isLoginFromLogin', {
- isLogin: true
- })
- uni.$emit('loginStatusEvent', {
- isLogin: true
- })
- }
- } catch (e) {
- // error
- }
- },
- startLogin(e) {
- //登录
- if (_self.isRotate) {
- //判断是否加载中,避免重复点击请求
- return false
- }
- if (_self.username.length == "") {
- _self.tui.toast('用户名不能为空')
- return
- }
- if (_self.password.length < 5) {
- _self.tui.toast('登录密码不正确')
- return
- }
- _self.isRotate = true
- uni.showLoading({
- title: '登录中.....'
- })
- // 特殊登录逻辑:测试用户
- if (_self.username === 'aaaaa' && _self.password === 'aaaaa') {
- setTimeout(() => {
- // 显示登录成功提示
- uni.showToast({
- title: '登录成功',
- icon: 'success',
- position: 'center'
- })
- // 延迟跳转首页
- setTimeout(function() {
- console.log('执行跳转操作...');
- uni.switchTab({
- url: '/pages/index/index',
- success: function() {
- console.log('跳转成功!');
- },
- fail: function(err) {
- console.error('跳转失败:', err);
- }
- })
- }, 500)
- uni.hideLoading()
- _self.isRotate = false
- // 模拟登录成功,设置token和用户信息
- const mockToken = 'aaaaa_token_123456'
- const mockUserInfo = { id: 999, username: 'aaaaa', role: 'aaaaa', building: 'D栋', room: '001', pen: '004' }
- // 提取编号信息
- const building = mockUserInfo.building || '';
- const room = mockUserInfo.room || '';
- const pen = mockUserInfo.pen || '';
- // 存储到本地
- uni.setStorageSync('equipment_token', mockToken)
- uni.setStorageSync('user_info', mockUserInfo)
- uni.setStorageSync('building', building)
- uni.setStorageSync('room', room)
- uni.setStorageSync('pen', pen)
- // 同时存储名称字段
- uni.setStorageSync('buildingName', building);
- uni.setStorageSync('roomName', room);
- uni.setStorageSync('penNo', pen);
- uni.setStorageSync('equipment_manage', '')
- // 更新全局数据
- const app = getApp();
- app.globalData.token = mockToken
- app.globalData.userInfo = mockUserInfo
- app.globalData.isLoggedIn = true
- app.globalData.building = building
- app.globalData.room = room
- app.globalData.pen = pen
- // 同时设置名称字段,保持一致性
- app.globalData.buildingName = building;
- app.globalData.roomName = room;
- app.globalData.penNo = pen;
- // 触发登录成功事件
- uni.$emit('loginStatusEvent', {
- isLogin: true
- })
- }, 1000)
- return
- }
- // 其他情况调用接口登录
- uni.request({
- url: 'http://dev-rfid.7in6.com/index.php/api/index/get_login',
- method: 'POST', // 登录请求使用POST方法更安全
- data: {
- username: _self.username,
- password: _self.password
- },
- header: {
- 'content-type': 'application/x-www-form-urlencoded' // 设置合适的Content-Type
- },
- success: (res) => {
- uni.hideLoading()
- _self.isRotate = false
- console.log('登录接口响应:', res); // 输出完整响应,帮助调试
- // 检查响应是否有效
- if (!res.data) {
- _self.password = ''
- console.error('登录失败: 响应数据为空');
- // 使用uni.showToast替代可能有问题的tui.toast
- uni.showToast({
- title: '登录失败: 服务器响应异常',
- icon: 'none',
- position: 'center'
- })
- return;
- }
- if (res.data.msg === '登录成功') {
- // 使用uni.showToast替代tui.toast
- uni.showToast({
- title: '登录成功',
- icon: 'success',
- position: 'center'
- })
- // 提取用户信息、token和新添加的字段
- const userInfo = res.data.data.user_info || {};
- const token = res.data.data.token || '';
- // 处理编号字段:有值时赋值,无值时为空
- // 优先从res.data.data中获取,如果不存在则使用user_info中的值,如果都不存在则为空字符串
- const building = res.data.data.building !== undefined ? res.data.data.building : (userInfo.building || '');
- const room = res.data.data.room !== undefined ? res.data.data.room : (userInfo.room || '');
- const pen = res.data.data.pen !== undefined ? res.data.data.pen : (userInfo.pen || '');
- // 调试日志:显示字段值及其来源
- console.log('提取的building值:', building, '来源:', res.data.data.building !== undefined ? 'res.data.data' : (userInfo.building ? 'user_info' : '默认空值'));
- console.log('提取的room值:', room, '来源:', res.data.data.room !== undefined ? 'res.data.data' : (userInfo.room ? 'user_info' : '默认空值'));
- console.log('提取的pen值:', pen, '来源:', res.data.data.pen !== undefined ? 'res.data.data' : (userInfo.pen ? 'user_info' : '默认空值'));
- // 设置全局登录状态和编号字段
- const app = getApp();
- app.globalData.token = token;
- app.globalData.userInfo = userInfo;
- app.globalData.isLoggedIn = true;
- app.globalData.building = building; // 栋舍编号
- app.globalData.room = room; // 房间编号
- app.globalData.pen = pen; // 栏位编号
- // 同时设置名称字段,保持一致性
- app.globalData.buildingName = building;
- app.globalData.roomName = room;
- app.globalData.penNo = pen;
- // 存储登录信息和编号字段到本地缓存
- uni.setStorageSync('equipment_token', token);
- uni.setStorageSync('user_info', userInfo);
- uni.setStorageSync('building', building); // 持久化存储栋舍编号
- uni.setStorageSync('room', room); // 持久化存储房间编号
- uni.setStorageSync('pen', pen); // 持久化存储栏位编号
- // 同时存储名称字段
- uni.setStorageSync('buildingName', building);
- uni.setStorageSync('roomName', room);
- uni.setStorageSync('penNo', pen);
- // 初始化equipment_manage存储
- uni.setStorageSync('equipment_manage', '');
- // 触发登录状态更新事件
- uni.$emit('loginStatusEvent', {
- isLogin: true
- });
- // 延迟一小段时间后跳转,确保提示信息能显示
- setTimeout(function() {
- console.log('准备跳转到首页...');
- // 登录成功后跳转到首页
- uni.switchTab({
- url: '/pages/index/index',
- success: function() {
- console.log('跳转成功!');
- // 跳转成功后,通知首页加载用户编号信息
- uni.$emit('reloadUserSettings', {});
- },
- fail: function(err) {
- console.error('跳转失败:', err);
- }
- })
- }, 500)
- } else {
- const errorMsg = res.data.msg || '登录失败';
- console.log('登录失败:', errorMsg, res);
- _self.password = ''
- // 使用uni.showToast替代可能有问题的tui.toast
- uni.showToast({
- title: errorMsg,
- icon: 'none',
- position: 'center'
- })
- }
- },
- fail: (err) => {
- uni.hideLoading()
- _self.password = ''
- _self.isRotate = false
- console.error('登录请求失败:', err)
- }
- })
- },
- login_weixin() {
- //微信登录
- uni.showToast({
- icon: 'none',
- position: 'bottom',
- title: '...'
- });
- },
- forget() {
- uni.showModal({
- title: '提示',
- content: '请联系系统管理员',
- showCancel: false,
- confirmText: '知道了',
- confirmColor: '#333333'
- });
- }
- }
- }
- </script>
- <style>
- @import url("../../components/watch-login/css/icon.css");
- @import url("./css/main.css");
- page {
- background-color: #FFFFFF;
- }
- </style>
|