|  |  | 
 |  |  |       <!-- 登录信息 --> | 
 |  |  |       <view class="user-info"> | 
 |  |  |          <view class="user-info-item shadow-warp"> | 
 |  |  |             <view class="icons"><uni-icons type="person" size="20"></uni-icons></view> | 
 |  |  |             <text>账号:</text> | 
 |  |  |             <input type="text" placeholder="请输入账号!" v-model="user.userName" | 
 |  |  |             placeholder-style="font-size:14px;color:#ccc;"> | 
 |  |  |             <view class="icons"> | 
 |  |  |                <uni-icons type="person" size="20"></uni-icons> | 
 |  |  |             </view> | 
 |  |  |             <text>手机号:</text> | 
 |  |  |             <input type="text" placeholder="请输入账号!" v-model="user.phone" | 
 |  |  |                placeholder-style="font-size:14px;color:#ccc;"> | 
 |  |  |          </view> | 
 |  |  |          <view class="user-info-item shadow-warp"> | 
 |  |  |             <view class="icons"><uni-icons type="locked" size="20"></uni-icons></view> | 
 |  |  |             <text>密码:</text> | 
 |  |  |             <input :password="!showPassword" v-model="user.password" placeholder="请输入密码!" | 
 |  |  |             placeholder-style="font-size:14px;color:#ccc;"> | 
 |  |  |             <view class="showPassword" v-if="showPassword" @click="changePassword"><uni-icons type="eye" size="20"></uni-icons></view> | 
 |  |  |             <view class="showPassword" v-if="!showPassword" @click="changePassword"><uni-icons type="eye-slash" size="20"></uni-icons></view> | 
 |  |  |             <view class="icons"> | 
 |  |  |                <uni-icons type="locked" size="20"></uni-icons> | 
 |  |  |             </view> | 
 |  |  |             <text>验证码:</text> | 
 |  |  |             <input :password="!showPassword" v-model="user.code" placeholder="请输入验证码!" | 
 |  |  |                placeholder-style="font-size:14px;color:#ccc;"> | 
 |  |  |             <view style="font-size: 24rpx;" > | 
 |  |  |                <text @click="getCode" v-show="!codeTimeShow">获取验证码</text> | 
 |  |  |                <text v-show="codeTimeShow">{{codeTime}}秒后重获</text> | 
 |  |  |             </view> | 
 |  |  |             <!-- <view class="showPassword" v-if="showPassword" @click="changePassword"> | 
 |  |  |                <uni-icons type="eye" size="20"></uni-icons> | 
 |  |  |             </view> | 
 |  |  |             <view class="showPassword" v-if="!showPassword" @click="changePassword"> | 
 |  |  |                <uni-icons type="eye-slash" size="20"></uni-icons> | 
 |  |  |             </view> --> | 
 |  |  |          </view> | 
 |  |  |       </view> | 
 |  |  |       <!-- 登录按钮 --> | 
 |  |  |       <view class="loging"> | 
 |  |  |          <button class="button" @click="onLogin()" :loading="load.loading">{{load.btnText}}</button> | 
 |  |  |       </view> | 
 |  |  | 		 | 
 |  |  |       <view> | 
 |  |  |          <!-- 提示窗示例 --> | 
 |  |  |          <uni-popup ref="upVersion" type="dialog"> | 
 |  |  |             <uni-popup-dialog :type="msgType" title="通知" :content="dialogContent" @confirm="dialogConfirm" | 
 |  |  |                @close="dialogClose"></uni-popup-dialog> | 
 |  |  |          </uni-popup> | 
 |  |  |       </view> | 
 |  |  | 		 | 
 |  |  |       <!-- #ifdef APP-PLUS --> | 
 |  |  |       <view class="version"> | 
 |  |  |          当前版本: {{version}} | 
 |  |  | 
 |  |  |       data() { | 
 |  |  |          return { | 
 |  |  |             version: '', | 
 |  |  |             showPassword: false, | 
 |  |  |             showPassword: true, | 
 |  |  |             user: { | 
 |  |  |                userName: '', | 
 |  |  |                password: '', | 
 |  |  |                phone: '', | 
 |  |  |                code: '', | 
 |  |  |             }, | 
 |  |  |             load: { | 
 |  |  |                loading: false, | 
 |  |  |                btnText: '登录' | 
 |  |  |             } | 
 |  |  |             }, | 
 |  |  |             msgType: 'success', | 
 |  |  |             filename: '', | 
 |  |  |             dialogContent: '', | 
 |  |  |             codeTime: 60, | 
 |  |  |             codeTimeShow: false | 
 |  |  |          } | 
 |  |  |       }, | 
 |  |  |       onLoad:function(){ | 
 |  |  |       onLoad: function() { | 
 |  |  |          this.user.userName = uni.getStorageSync('userName') | 
 |  |  |          this.user.password = uni.getStorageSync('password') | 
 |  |  |          // #ifdef APP-PLUS | 
 |  |  |          var that=this | 
 |  |  |          plus.runtime.getProperty( plus.runtime.appid, function ( wgtinfo ) { | 
 |  |  |             that.version=wgtinfo.version | 
 |  |  |          var that = this | 
 |  |  |          plus.runtime.getProperty(plus.runtime.appid, function(wgtinfo) { | 
 |  |  |             that.version = wgtinfo.version | 
 |  |  |          }); | 
 |  |  |          // #endif | 
 |  |  | 			 | 
 |  |  | 			 | 
 |  |  |       }, | 
 |  |  |       onShow() { | 
 |  |  |          this.getVersion() | 
 |  |  |       }, | 
 |  |  |       methods: { | 
 |  |  |          // 获取验证码 | 
 |  |  |          getCode() { | 
 |  |  |             let _this = this | 
 |  |  |             uni.request({ | 
 |  |  |                url: `${_this.baseUrl}/smsCode/sendCode`, | 
 |  |  |                header: {'content-type': 'application/x-www-form-urlencoded;charset=UTF-8'}, | 
 |  |  |                data: {phone: _this.user.phone}, | 
 |  |  |                sslVerify: false, | 
 |  |  |                method: 'POST', | 
 |  |  |                success(res) { | 
 |  |  |                   res = res.data  | 
 |  |  |                   console.log(res); | 
 |  |  |                   _this.codeTimeShow = true | 
 |  |  |                   let time = setInterval(()=>{ | 
 |  |  |                      _this.codeTime-- | 
 |  |  |                   },1000) | 
 |  |  |                   setTimeout(()=>{ | 
 |  |  |                      _this.codeTimeShow = false | 
 |  |  |                      clearTimeout(time); | 
 |  |  |                      _this.codeTime = 60 | 
 |  |  |                   },60000) | 
 |  |  |                } | 
 |  |  |             }) | 
 |  |  |          }, | 
 |  |  |          changePassword: function() { | 
 |  |  |              this.showPassword = !this.showPassword; | 
 |  |  |             this.showPassword = !this.showPassword; | 
 |  |  |          }, | 
 |  |  |          //检测当前平台,如果是安卓则启动安卓更新 | 
 |  |  |          getVersion() { | 
 |  |  |             let that = this; | 
 |  |  |             uni.getSystemInfo({ | 
 |  |  |                success: (res) => { | 
 |  |  |                   if (res.platform == "android") { | 
 |  |  |                      that.AndroidCheckUpdate(); | 
 |  |  |                   } | 
 |  |  |                } | 
 |  |  |             }) | 
 |  |  |          }, | 
 |  |  |          // 获取当前版本号 | 
 |  |  |          AndroidCheckUpdate() { | 
 |  |  |             let that = this; | 
 |  |  |             plus.runtime.getProperty(plus.runtime.appid, (wgtinfo) => { | 
 |  |  |                that.version = wgtinfo.version //客户端版本号 | 
 |  |  |             }) | 
 |  |  |             setTimeout(()=>{ | 
 |  |  |                that.getUpdateVersion() | 
 |  |  |             },100) | 
 |  |  |          }, | 
 |  |  |          // 校验版本 | 
 |  |  |          getUpdateVersion() { | 
 |  |  |             let that = this | 
 |  |  |             let type = 0 | 
 |  |  |             if (that.baseUrl == 'http://undefined:undefined/undefined') { | 
 |  |  |                return | 
 |  |  |             } | 
 |  |  | 				 | 
 |  |  |             let url = that.baseUrl + '/appVersion/checkUpdate/' + that.version + '/' + type | 
 |  |  |             uni.request({ | 
 |  |  |                url: url, | 
 |  |  |                method: 'GET', | 
 |  |  |                success(res) { | 
 |  |  |                   console.log(res); | 
 |  |  |                   var res = res.data | 
 |  |  |                   if (res.data) { | 
 |  |  |                      that.filename = res.data.path | 
 |  |  |                      that.dialogContent = '发现新版本:' + res.data.version + ', 是否立即更新' | 
 |  |  |                      that.$refs.upVersion.open() | 
 |  |  |                   } else { | 
 |  |  |                      uni.showToast({ | 
 |  |  |                         title: res.msg, | 
 |  |  |                         icon: "none", | 
 |  |  |                         position: 'top' | 
 |  |  |                      }) | 
 |  |  |                   } | 
 |  |  | 						 | 
 |  |  |                } | 
 |  |  |             }) | 
 |  |  |          }, | 
 |  |  |          dialogConfirm() { | 
 |  |  |             this.$refs.upVersion.close() | 
 |  |  |             this.downWgt() | 
 |  |  |          }, | 
 |  |  |          dialogClose() { | 
 |  |  |             this.$refs.upVersion.close() | 
 |  |  |          }, | 
 |  |  |          downWgt() { | 
 |  |  |             let that = this; | 
 |  |  |             const downloadUrl = that.baseUrl + "/appVersion/downloadApp/" + that.filename | 
 |  |  |             uni.showLoading({ | 
 |  |  |                title: '更新中……' | 
 |  |  |             }) | 
 |  |  |             const downloadTask = uni.downloadFile({ //执行下载 | 
 |  |  |                url: downloadUrl, //下载地址 | 
 |  |  |                timeout: 1000 * 30, //30秒超时时间 | 
 |  |  |                success: downloadResult => { //下载成功 | 
 |  |  |                   console.log(downloadResult); | 
 |  |  |                   that.showdownLine = false | 
 |  |  |                   uni.hideLoading(); | 
 |  |  |                   if (downloadResult.statusCode == 200) { | 
 |  |  |                      uni.showModal({ | 
 |  |  |                         title: '', | 
 |  |  |                         content: '更新成功,确定现在重启吗?', | 
 |  |  |                         confirmText: '重启', | 
 |  |  |                         confirmColor: '#EE8F57', | 
 |  |  |                         success: function(res) { | 
 |  |  |                            if (res.confirm == true) { | 
 |  |  |                               plus.runtime.install( //安装 | 
 |  |  |                                  downloadResult.tempFilePath, { | 
 |  |  |                                     force: true | 
 |  |  |                                  }, | 
 |  |  |                                  function(res) { | 
 |  |  |                                     utils.showToast('更新成功,重启中'); | 
 |  |  |                                     plus.runtime.restart(); | 
 |  |  |                                  } | 
 |  |  |                               ); | 
 |  |  |                            } | 
 |  |  |                         } | 
 |  |  |                      }); | 
 |  |  |                   } else { | 
 |  |  |                      uni.hideLoading(); | 
 |  |  |                      that.showdownLine = false | 
 |  |  |                      uni.showToast({ | 
 |  |  |                         title:'请先上传安装包', | 
 |  |  |                         icon: 'error' | 
 |  |  |                      }) | 
 |  |  |                   } | 
 |  |  |                }, | 
 |  |  |                fail: err => { | 
 |  |  |                   uni.hideLoading(); | 
 |  |  |                   that.showdownLine = false | 
 |  |  |                   that.$u.toast(downloadResult.errMsg) | 
 |  |  |                }, | 
 |  |  |                complete: com => { | 
 |  |  | 						 | 
 |  |  |                   console.log(com) | 
 |  |  |                } | 
 |  |  |             }); | 
 |  |  | 			 | 
 |  |  |             // 下载进度 | 
 |  |  |             downloadTask.onProgressUpdate(res => { | 
 |  |  |                that.downloadNum = res.progress | 
 |  |  |                console.log('下载进度' + that.downloadNum); | 
 |  |  |             }); | 
 |  |  |          }, | 
 |  |  |          onLogin() { | 
 |  |  |             let that = this | 
 |  |  |             if (that.user.phone == '') { | 
 |  |  |                uni.showToast({ title: '请输入手机号', icon: "none" }) | 
 |  |  |                return | 
 |  |  |             } | 
 |  |  |             if (that.user.code == '') { | 
 |  |  |                uni.showToast({ title: '验证码不能为空', icon: "none" }) | 
 |  |  |                return | 
 |  |  |             } | 
 |  |  |             uni.request({ | 
 |  |  |                url: 'http://127.0.0.1:9528/login.action', | 
 |  |  |                url: that.baseUrl + '/smsLogin.action', | 
 |  |  |                fail(result) { | 
 |  |  |                   uni.showToast({title: '请求失败'}) | 
 |  |  |                   uni.showToast({ | 
 |  |  |                      icon: 'error', | 
 |  |  |                      title: '请求失败' | 
 |  |  |                   }) | 
 |  |  |                }, | 
 |  |  |                data: { | 
 |  |  |                  username:that.user.userName, | 
 |  |  |                  password:md5.hex_md5(that.user.password)  | 
 |  |  |                   phone: that.user.phone, | 
 |  |  |                   code: that.user.code | 
 |  |  |                }, | 
 |  |  |                header: { | 
 |  |  |                   "content-type": "application/json" | 
 |  |  |                }, | 
 |  |  |                header: { "content-type": "application/json" }, | 
 |  |  |                success(result) { | 
 |  |  |                   if (result.statusCode === 404) { | 
 |  |  |                      uni.showToast({ | 
 |  |  |                         title: '登录失败', | 
 |  |  |                         icon: "error" | 
 |  |  |                      }) | 
 |  |  |                      return | 
 |  |  |                   } | 
 |  |  |                   let res = result.data | 
 |  |  |                   if (res.code === 200 ){ | 
 |  |  |                   if (res.code === 200) { | 
 |  |  |                      that.load.loading = true; | 
 |  |  |                      that.load.btnText = '登录中'; | 
 |  |  |                      uni.setStorageSync('token', res.data.token); | 
 |  |  |                      uni.setStorageSync('userName', that.user.userName); | 
 |  |  |                      setTimeout(()=> { | 
 |  |  |                         uni.showToast({title: '登录成功'}) | 
 |  |  |                         setTimeout(()=> { | 
 |  |  |                      uni.setStorageSync('password', that.user.password); | 
 |  |  |                      setTimeout(() => { | 
 |  |  |                         uni.showToast({ | 
 |  |  |                            title: '登录成功' | 
 |  |  |                         }) | 
 |  |  |                         setTimeout(() => { | 
 |  |  |                            uni.reLaunch({ | 
 |  |  |                               url: '../index/index' | 
 |  |  |                            }); | 
 |  |  |                         },300) | 
 |  |  |                      },700) | 
 |  |  |                         }, 300) | 
 |  |  |                      }, 700) | 
 |  |  |                   } else { | 
 |  |  |                      uni.showToast({title: res.msg}) | 
 |  |  |                      uni.showToast({ | 
 |  |  |                         title: res.msg | 
 |  |  |                      }) | 
 |  |  |                   } | 
 |  |  |                }, | 
 |  |  | 					 | 
 |  |  | 					 | 
 |  |  |  | 
 |  |  |  | 
 |  |  |             }) | 
 |  |  |          }, | 
 |  |  |       } | 
 |  |  | 
 |  |  |       width: 100%; | 
 |  |  |       min-height: 93.4vh; | 
 |  |  |    } | 
 |  |  |  | 
 |  |  |    .logo { | 
 |  |  |       width: 300px; | 
 |  |  |       height: 163px; | 
 |  |  | 
 |  |  |       margin-right: auto; | 
 |  |  |       margin-bottom: 50rpx; | 
 |  |  |    } | 
 |  |  |  | 
 |  |  |    .user-info { | 
 |  |  |       display: flex; | 
 |  |  |       align-items:center; | 
 |  |  |       align-items: center; | 
 |  |  |       flex-direction: column; | 
 |  |  |       width: 100%; | 
 |  |  |       height: 400rpx; | 
 |  |  |       font-size: 14px; | 
 |  |  |       letter-spacing:1px; | 
 |  |  |       letter-spacing: 1px; | 
 |  |  |    } | 
 |  |  |  | 
 |  |  |    .user-info-item { | 
 |  |  |       display: flex; | 
 |  |  |       width:650rpx; | 
 |  |  |       width: 650rpx; | 
 |  |  |       height: 100rpx; | 
 |  |  |       line-height: 100rpx; | 
 |  |  |       align-items:center; | 
 |  |  |       align-items: center; | 
 |  |  |       background-color: #fff; | 
 |  |  |       margin-bottom: 30rpx; | 
 |  |  |       font-size: 28rpx; | 
 |  |  |       font-weight: 500; | 
 |  |  |    } | 
 |  |  |    .user-info-item>input{ | 
 |  |  |       width: 400rpx; | 
 |  |  |       color:#606266; | 
 |  |  |  | 
 |  |  |    .user-info-item>input { | 
 |  |  |       width: 300rpx; | 
 |  |  |       color: #606266; | 
 |  |  |       font-weight: 500; | 
 |  |  |       caret-color:#606266; // 光标颜色 | 
 |  |  |       caret-color: #606266; // 光标颜色 | 
 |  |  |    } | 
 |  |  |  | 
 |  |  |    .icons { | 
 |  |  |       margin-left: 20rpx; | 
 |  |  |       margin-right: 18rpx; | 
 |  |  |    } | 
 |  |  |  | 
 |  |  |    .showPassword { | 
 |  |  |       position: absolute; | 
 |  |  |       right: 10rpx; | 
 |  |  |    } | 
 |  |  |  | 
 |  |  |    .shadow-warp { | 
 |  |  |       position: relative; | 
 |  |  |       box-shadow: 0 0 10upx rgba(0, 0, 0, 0.1); | 
 |  |  |    } | 
 |  |  |  | 
 |  |  |    .shadow-warp:before, | 
 |  |  |    .shadow-warp:after { | 
 |  |  |       position: absolute; | 
 |  |  | 
 |  |  |       transform: rotate(-3deg); | 
 |  |  |       z-index: -1; | 
 |  |  |    } | 
 |  |  |  | 
 |  |  |    .shadow-warp:after { | 
 |  |  |       right: 20upx; | 
 |  |  |       left: auto; | 
 |  |  |       transform: rotate(3deg); | 
 |  |  |    } | 
 |  |  |  | 
 |  |  |    .loging { | 
 |  |  |       position: fixed; | 
 |  |  |       bottom: 100rpx; | 
 |  |  |       left:0; | 
 |  |  |       right:0; | 
 |  |  |       margin-left:auto; | 
 |  |  |       margin-right:auto; | 
 |  |  |       left: 0; | 
 |  |  |       right: 0; | 
 |  |  |       margin-left: auto; | 
 |  |  |       margin-right: auto; | 
 |  |  |    } | 
 |  |  |  | 
 |  |  |    .button { | 
 |  |  |       color: #fff; | 
 |  |  |       background-color: #409EFF; | 
 |  |  | 
 |  |  |       height: 40px; | 
 |  |  |       line-height: 40px; | 
 |  |  |    } | 
 |  |  |    button::after{border: initial;} | 
 |  |  |    .button-hover { | 
 |  |  |       color:#fff; | 
 |  |  |       background-color:#6fc1ff; | 
 |  |  |  | 
 |  |  |    button::after { | 
 |  |  |       border: initial; | 
 |  |  |    } | 
 |  |  |  | 
 |  |  |    .button-hover { | 
 |  |  |       color: #fff; | 
 |  |  |       background-color: #6fc1ff; | 
 |  |  |    } | 
 |  |  |  | 
 |  |  |    .version { | 
 |  |  |       width: 100%; | 
 |  |  |       position: fixed; | 
 |  |  |       bottom: 30rpx; | 
 |  |  |       left:0; | 
 |  |  |       right:0; | 
 |  |  |       margin-left:auto; | 
 |  |  |       margin-right:auto; | 
 |  |  |       left: 0; | 
 |  |  |       right: 0; | 
 |  |  |       margin-left: auto; | 
 |  |  |       margin-right: auto; | 
 |  |  |       text-align: center; | 
 |  |  |       font-size: 10px; | 
 |  |  |       color: #C0C4CC; | 
 |  |  |    } | 
 |  |  |  | 
 |  |  |    .input { | 
 |  |  |       display: block; | 
 |  |  |       font-size: 14px; | 
 |  |  |    } | 
 |  |  |  | 
 |  |  |    .uni-input { | 
 |  |  |       height: 50rpx; | 
 |  |  |       padding: 15rpx 25rpx; | 
 |  |  |       line-height:50rpx; | 
 |  |  |       font-size:28rpx; | 
 |  |  |       background:#FFF; | 
 |  |  |       line-height: 50rpx; | 
 |  |  |       font-size: 28rpx; | 
 |  |  |       background: #FFF; | 
 |  |  |       flex: 1; | 
 |  |  |    } | 
 |  |  | 	 | 
 |  |  | </style> | 
 |  |  | </style> |