uniapp 请求 添加header 同步读写缓存

本文介绍了uni-app在处理本地存储uni.setStorage和请求uni.request的方法,包括设置数据、成功回调、错误处理,并展示了如何在不同平台获取token。文章还探讨了在不同屏幕尺寸下的适配问题,以及使用uni.getStorage获取存储信息的流程。
摘要由CSDN通过智能技术生成

uni.setStorage({
                            key: 'token',
                            data: res[1].data.msg,
                            success: function () {
                                console.log('success');
                            }
                        });
                    
                        _this.$store.commit('SET_TOKEN',res[1].data.msg) //
                        _this.$store.commit('SET_CUSTOMER_NAME',_this.customerName) //
                        _this.$store.commit('SET_CARD_NUMBER',_this.cardNumber) //
                        _this.$store.commit('SET_PHONE',_this.phone) // 

 

 console.log(this.$store.state.user.orgcode)    


const baseurl='/api/'

export function request(path,data,orgcode) {
	console.log("request path :" ,path)
	//console.log(data)
	//	console.log("begin get token")
	var token =''
	uni.getStorage({
	    key: 'token',
	    success: function (res) {
			//console.log("success get token")
				//console.log(res)
	       token=res.data
	    },
		fail:function(){
			console.log("fail get token")
		}
	});
	//console.log("end get token")
	console.log("缓存中的token",token)
  return uni.request({
    url: baseurl+path,
	 header:{
	        'orgcode': '0377000001', //自定义请求头信息
			'reportToken':token
	    },
    method: 'POST',
    data: data
  })
}

<template>
	<view class="login">
		<view class="content">
			<!-- 头部logo -->
			<view class="header">
				<image src="/static/yt.png"></image>
			</view>
			<!-- 主体表单 -->
			<view class="main">
				<wInput
					v-model="customerName"
					type="text"
					maxlength="11"
					placeholder="姓名"
					:focus="isFocus"
				></wInput>
				<wInput
					v-model="cardNumber"
					type="text"
					maxlength="18"
					placeholder="身份证号"
					:focus="isFocus"
				></wInput>
				<wInput
					v-model="phone"
					type="text"
					maxlength="11"
					placeholder="联系电话"
					:focus="isFocus"
					
					
				></wInput>
				
				<wInput
					v-model="verifyCode"
					:focus="isFocus"
					type="number"
					maxlength="6"
					placeholder="验证码"					
					isShowCode
					codeText="获取验证码"
					setTime="60"
					ref="runCode"
					@setCode="requestPhoneCode"
				></wInput>
				
			</view>
			<wButton 
				class="wbutton"
				text="立 即 查 询"
				:rotate="isRotate" 
				@click="startLogin"
			></wButton>
			
			<!-- 其他登录 -->
			<view class="other_login cuIcon">
				<view class="login_icon">
					<view class="cuIcon-weixin" @tap="login_weixin"></view>
				</view>
				<view class="login_icon">
					<view class="cuIcon-weibo" @tap="login_weibo"></view>
				</view>
				<view class="login_icon">
					<view class="cuIcon-github" @tap="login_github"></view>
				</view>
			</view>
			
			<!-- 底部信息 -->
			<view class="footer">
				<navigator url="forget" open-type="navigate">找回密码</navigator>
				<text>|</text>
				<navigator url="register" open-type="navigate">注册账号</navigator>
			</view>
		</view>
	</view>
</template>

<script>
	let _this;
	import wInput from '../../components/watch-login/watch-input.vue' //input
	import wButton from '../../components/watch-login/watch-button.vue' //button
	import {request} from '../../api/request'
	
	export default {
		data() {
			return {
				//logo图片 base64
				logoImage: '',
				phoneData:'', //用户/电话
				passData:'', //密码
				customerName:'',
				cardNumber:'',
				phone:'',
				verifyCode:'',
				isRotate: false, //是否加载旋转
				isFocus: true, // 是否聚焦
				orgcode:''
			};
		},
		components:{
			wInput,
			wButton,
		},
		mounted() {
			_this= this;
			//this.isLogin();
		},
		methods: {
			isLogin(){
				//判断缓存中是否登录过,直接登录
				// try {
				// 	const value = uni.getStorageSync('setUserData');
				// 	if (value) {
				// 		//有登录信息
				// 		console.log("已登录用户:",value);
				// 		_this.$store.dispatch("setUserData",value); //存入状态
				// 		uni.reLaunch({
				// 			url: '../../../pages/index',
				// 		});
				// 	}
				// } catch (e) {
				// 	// error
				// }
			},
		    startLogin(e){
				
                console.log(e)
				//登录
				if(this.isRotate){
					//判断是否加载中,避免重复点击请求
					return false;
				}
				if (this.customerName.length == "") {
				     uni.showToast({
				        icon: 'none',
						position: 'bottom',
				        title: '用户名不能为空'
				    });
				    return;
				}
		        if (this.cardNumber.length < 10) {
		            uni.showToast({
		                icon: 'none',
						position: 'bottom',
		                title: '身份证不正确'
		            });
		            return;
		        }
				if (this.phone.length < 10) {
				    uni.showToast({
				        icon: 'none',
						position: 'bottom',
				        title: '联系电话不正确'
				    });
				    return;
				}
				if (this.verifyCode.length < 4) {
				    uni.showToast({
				        icon: 'none',
						position: 'bottom',
				        title: '验证码无效'
				    });
				    return;
				}
				
				//console.log("登录成功")
				
				_this.isRotate=true
				/*setTimeout(function(){
					_this.isRotate=false
				},3000)*/
				
				uni.showLoading({
					title: '登录中'
				});				
				request('tj/phone_report/verify_code',
				{
					customerName:_this.customerName,
				cardNumber:_this.cardNumber,
				phone:_this.phone,verifyCode:_this.verifyCode,
				},
				_this.orgcode)
				.then(res => {
					console.log("res[1].data.msg",res[1].data.msg)					
					 console.log('success');
					if(res[1].data.code==200)
					{
						uni.setStorage({
						    key: 'token',
						    data: res[1].data.msg,
						    success: function () {
						        console.log('success');
						    }
						});
					
						_this.$store.commit('SET_TOKEN',res[1].data.msg) //
						_this.$store.commit('SET_CUSTOMER_NAME',_this.customerName) //
						_this.$store.commit('SET_CARD_NUMBER',_this.cardNumber) //
						_this.$store.commit('SET_PHONE',_this.phone) //
						console.log('200')
						uni.reLaunch({
							url: '/pages/index/index',
						});
					}else
					{
						uni.showToast({
							icon: 'error',
							position: 'bottom',
							title: res[1].data.msg
						});
					}
					//简单验证下登录(不安全)
					/*
					if((res.data.data!=null)&&(res.data.data.length>0)){
						
						_this.$store.commit('SET_HISS',res.data.data) //存入体检记录					
					
						try {
							//uni.setStorageSync('setUserData', userdata); //存入缓存
						} catch (e) {
							// error
						}
						uni.showToast({
							icon: 'success',
							position: 'bottom',
							title: '登录成功'
						});
						uni.reLaunch({
							url: '/pages/index/index',
						});
						
					}else{
						_this.passData=""
						uni.showToast({
							icon: 'error',
							position: 'bottom',
							title: '账号或密码错误'
						});
					}
					*/
					uni.hideLoading();
				}).catch(err => {
					
					console.log('request fail', err);
					uni.showModal({
						content: err.errMsg,
						showCancel: false
					});
					
					
					uni.hideLoading();
				})
					_this.isRotate=false
				
		    },
			login_weixin() {
				//微信登录
				uni.showToast({
					icon: 'none',
					position: 'bottom',
					title: '...'
				});
			},
			login_weibo() {
				//微博登录
				uni.showToast({
					icon: 'none',
					position: 'bottom',
					title: '...'
				});
			},
			login_github() {
				//github登录
				uni.showToast({
					icon: 'none',
					position: 'bottom',
					title: '...'
				});
			},
			requestPhoneCode(){
				if (this.customerName.length == "") {
				     uni.showToast({
				        icon: 'none',
						position: 'bottom',
				        title: '用户名不能为空'
				    });
				    return;
				}
				if (this.cardNumber.length < 10) {
				    uni.showToast({
				        icon: 'none',
						position: 'bottom',
				        title: '身份证不正确'
				    });
				    return;
				}
				//获取验证码
				if (_this.phone.length != 11) {
				     uni.showToast({
				        icon: 'none',
						position: 'bottom',
				        title: '手机号不正确'
				    });
				    return false;
				}
				console.log("获取验证码")
				
			request('tj/phone_report/send_verify_code?phone='+_this.phone,
			{customerName:_this.customerName,
			cardNumber:_this.cardNumber,
			phone:_this.phone},null).then(res=>{
					
					
				}).catch(err=>{
					
				})
				
				
				
				this.$refs.runCode.$emit('runCode'); //触发倒计时(一般用于请求成功验证码后调用)
				/*uni.showToast({
				    icon: 'none',
					position: 'bottom',
				    title: '模拟倒计时触发'
				});*/
				
				/*setTimeout(function(){
					_this.$refs.runCode.$emit('runCode',0); //假装模拟下需要 终止倒计时
					uni.showToast({
					    icon: 'none',
						position: 'bottom',
					    title: '模拟倒计时终止'
					});
				},3000)*/
			}
		},
		onLoad: function (option) { //option为object类型,会序列化上个页面传递的参数
		        console.log(option.orgcode)
		       this.orgcode=option.orgcode
			   
			   this.$store.commit('SET_ORGCODE',this.orgcode)
			   console.log(this.$store.state.user.orgcode)	
			   
		    },
			 created() {
			           // uni.$on('setCode', this.recive)
			           
			        },
			        beforeDestroy() { 
			          //  uni.$off('setCode',this.recive)
			           
			        },
	}
</script>

<style>
	@import url("../../components/watch-login/css/icon.css");
	@import url("./css/main.css");
</style>

 

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值