热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

前后端交互1

1.config.js配置文件exportdefault{#ifndefH5baseUrl:'http:127.0.0.1:7001',#endif#ifdefH5

1. config.js配置文件


export default {
// #ifndef H5
baseUrl: ‘http://127.0.0.1:7001‘,
// #endif
// #ifdef H5
baseUrl: ‘/api‘,
// #endif
socketUrl: ‘ws://127.0.0.1:7001/ws‘,
env: ‘dev‘
}

 

2. util.js工具类文件 用于获取和存储缓存 


import $C from ‘./config.js‘
export default {
// 获取存储列表数据
getStorage(key){
let data = null;
if($C.env === ‘dev‘){
data = window.sessionStorage.getItem(key)
} else {
data = uni.getStorageSync(key)
}
return data
},
// 设置存储
setStorage(key,data){
if($C.env === ‘dev‘){
return window.sessionStorage.setItem(key,data)
} else {
return uni.setStorageSync(key,data)
}
},
// 删除存储
removeStorage(key){
if($C.env === ‘dev‘){
return window.sessionStorage.removeItem(key);
} else {
return uni.removeStorageSync(key)
}
}
}

  

3. request请求文件,封装发送请求


import $C from ‘./config.js‘;
import $U from ‘./util.js‘
export default {
// 全局配置
common:{
baseUrl:$C.baseUrl,
header:{
‘Content-Type‘:‘application/json;charset=UTF-8‘,
},
data:{},
method:‘GET‘,
dataType:‘json‘,
token:true
},
// 请求 返回promise
request(optiOns= {}){
// 组织参数
options.url = this.common.baseUrl + options.url
options.header = options.header || this.common.header
options.data = options.data || this.common.data
options.method = options.method || this.common.method
options.dataType = options.dataType || this.common.dataType
options.token = options.token === false ? false : this.common.token
// 请求之前验证...
// token验证
if (options.token) {
let token = $U.getStorage(‘token‘)
// 二次验证
if (!token) {
uni.showToast({ title: ‘请先登录‘, icon: ‘none‘ });
// token不存在时跳转
return uni.reLaunch({
url: ‘/pages/login/login‘,
});
}
// 往header头中添加token
options.header.token = token
}
// 请求
return new Promise((res,rej)=>{
// 请求中...
uni.request({
...options,
success: (result) => {
// 返回原始数据
if(options.native){
return res(result)
}
// 服务端失败
if(result.statusCode !== 200){
if (options.toast !== false) {
uni.showToast({
title: result.data.data || ‘服务端失败‘,
icon: ‘none‘
});
}
return rej(result.data)
}
// 其他验证...
// 成功
let data = result.data.data
res(data)
},
fail: (error) => {
uni.showToast({ title: error.errMsg || ‘请求失败‘, icon: ‘none‘ });
return rej(error)
}
});
})
},
// get请求
get(url,data = {},optiOns= {}){
options.url = url
options.data = data
options.method = ‘GET‘
return this.request(options)
},
// post请求
post(url,data = {},optiOns= {}){
options.url = url
options.data = data
options.method = ‘POST‘
return this.request(options)
},
// delete请求
del(url,data = {},optiOns= {}){
options.url = url
options.data = data
options.method = ‘DELETE‘
return this.request(options)
},
}

 

4. 全局mixin auth.js 用于验证是否登录(是否有token缓存)


import $U from ‘@/common/free-lib/util.js‘;
export default {
onShow() {
let token = $U.getStorage(‘token‘)
if(!token){
return uni.reLaunch({
url:"/pages/common/login/login"
})
}
},
}

 


推荐阅读
  • PHP 5.2.5 安装与配置指南
    本文详细介绍了 PHP 5.2.5 的安装和配置步骤,帮助开发者解决常见的环境配置问题,特别是上传图片时遇到的错误。通过本教程,您可以顺利搭建并优化 PHP 运行环境。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 本文介绍了一款用于自动化部署 Linux 服务的 Bash 脚本。该脚本不仅涵盖了基本的文件复制和目录创建,还处理了系统服务的配置和启动,确保在多种 Linux 发行版上都能顺利运行。 ... [详细]
  • 本文详细分析了JSP(JavaServer Pages)技术的主要优点和缺点,帮助开发者更好地理解其适用场景及潜在挑战。JSP作为一种服务器端技术,广泛应用于Web开发中。 ... [详细]
  • 本文详细介绍了如何解决Uploadify插件在Internet Explorer(IE)9和10版本中遇到的点击失效及JQuery运行时错误问题。通过修改相关JavaScript代码,确保上传功能在不同浏览器环境中的一致性和稳定性。 ... [详细]
  • Linux 系统启动故障排除指南:MBR 和 GRUB 问题
    本文详细介绍了 Linux 系统启动过程中常见的 MBR 扇区和 GRUB 引导程序故障及其解决方案,涵盖从备份、模拟故障到恢复的具体步骤。 ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • CentOS7源码编译安装MySQL5.6
    2019独角兽企业重金招聘Python工程师标准一、先在cmake官网下个最新的cmake源码包cmake官网:https:www.cmake.org如此时最新 ... [详细]
  • 本文介绍了如何使用JQuery实现省市二级联动和表单验证。首先,通过change事件监听用户选择的省份,并动态加载对应的城市列表。其次,详细讲解了使用Validation插件进行表单验证的方法,包括内置规则、自定义规则及实时验证功能。 ... [详细]
  • 几何画板展示电场线与等势面的交互关系
    几何画板是一款功能强大的物理教学软件,具备丰富的绘图和度量工具。它不仅能够模拟物理实验过程,还能通过定量分析揭示物理现象背后的规律,尤其适用于难以在实际实验中展示的内容。本文将介绍如何使用几何画板演示电场线与等势面之间的关系。 ... [详细]
  • 本文介绍如何通过Windows批处理脚本定期检查并重启Java应用程序,确保其持续稳定运行。脚本每30分钟检查一次,并在需要时重启Java程序。同时,它会将任务结果发送到Redis。 ... [详细]
  • 本文介绍如何在应用程序中使用文本输入框创建密码输入框,并通过设置掩码来隐藏用户输入的内容。我们将详细解释代码实现,并提供专业的补充说明。 ... [详细]
  • 本文详细介绍了如何通过命令行启动MySQL服务,包括打开命令提示符窗口、进入MySQL的bin目录、输入正确的连接命令以及注意事项。文中还提供了更多相关命令的资源链接。 ... [详细]
  • 本文介绍了在Windows环境下使用pydoc工具的方法,并详细解释了如何通过命令行和浏览器查看Python内置函数的文档。此外,还提供了关于raw_input和open函数的具体用法和功能说明。 ... [详细]
  • 本文介绍如何使用阿里云的fastjson库解析包含时间戳、IP地址和参数等信息的JSON格式文本,并进行数据处理和保存。 ... [详细]
author-avatar
蔡佩琬62777
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有