出入码下拉刷新功能;内网穿透配置文件
This commit is contained in:
parent
00652ee179
commit
eaecc486df
12
README.md
12
README.md
@ -415,6 +415,18 @@ npm run serve
|
|||||||
|
|
||||||
- 启动后端微服务注册中心:nacos
|
- 启动后端微服务注册中心:nacos
|
||||||
|
|
||||||
|
- 在本地启动Gateway及各个微服务项目
|
||||||
|
|
||||||
|
- 在服务器端启动内网穿透Server端,在本地启动内网穿透Client端
|
||||||
|
|
||||||
|
```bash
|
||||||
|
cd ./intranet-penetration/bin
|
||||||
|
# server
|
||||||
|
rathole ../conf/server.toml
|
||||||
|
# client
|
||||||
|
rathole.exe ../conf/client.toml
|
||||||
|
```
|
||||||
|
|
||||||
- 启动接口测试工具:Postman
|
- 启动接口测试工具:Postman
|
||||||
|
|
||||||
- 启动命令行:`npm run dev:alipay`(支付宝小程序)、`npm run dev:weapp`(微信小程序)
|
- 启动命令行:`npm run dev:alipay`(支付宝小程序)、`npm run dev:weapp`(微信小程序)
|
||||||
|
@ -6,6 +6,8 @@ const server = http.createServer();
|
|||||||
|
|
||||||
// 3. 监听请求事件
|
// 3. 监听请求事件
|
||||||
server.on("request", (req, res) => {
|
server.on("request", (req, res) => {
|
||||||
|
console.log(new Date(), "req.url", req.url);
|
||||||
|
|
||||||
//req-->request 请求对象, res-->response 响应对象
|
//req-->request 请求对象, res-->response 响应对象
|
||||||
// 通过响应头设置返回前台数据格式及编码。(解决中文乱码的问题)
|
// 通过响应头设置返回前台数据格式及编码。(解决中文乱码的问题)
|
||||||
// res.setHeader('Content-Type', 'text/html;charset=utf-8');
|
// res.setHeader('Content-Type', 'text/html;charset=utf-8');
|
||||||
|
4
intranet-penetration/.gitignore
vendored
Normal file
4
intranet-penetration/.gitignore
vendored
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
bin/rathole
|
||||||
|
bin/rathole.exe
|
||||||
|
conf/client.toml
|
||||||
|
conf/server.toml
|
29
intranet-penetration/README.md
Normal file
29
intranet-penetration/README.md
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
# 内网穿透
|
||||||
|
|
||||||
|
> 开发时,在本地电脑启动后端服务,然后通过内网穿透进行小程序真机调试。
|
||||||
|
|
||||||
|
需要有一台公网服务器,一个域名(可选),以及服务器打开对应端口
|
||||||
|
|
||||||
|
## bin 二进制文件下载
|
||||||
|
|
||||||
|
GitHub: https://github.com/rapiz1/rathole/
|
||||||
|
|
||||||
|
## 配置
|
||||||
|
|
||||||
|
修改 conf 文件夹中配置文件
|
||||||
|
|
||||||
|
## 启动
|
||||||
|
|
||||||
|
服务端
|
||||||
|
|
||||||
|
```bash
|
||||||
|
cd bin
|
||||||
|
rathole ../conf/server.toml
|
||||||
|
```
|
||||||
|
|
||||||
|
本地
|
||||||
|
|
||||||
|
```bash
|
||||||
|
cd bin
|
||||||
|
rathole.exe ../conf/client.toml
|
||||||
|
```
|
5
intranet-penetration/conf/client.example.toml
Normal file
5
intranet-penetration/conf/client.example.toml
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
[client]
|
||||||
|
remote_addr = "xxx.xxx.xxx.xxx:yyy" # 服务器的地址。端口必须与 `server.bind_addr` 中的端口相同。
|
||||||
|
[client.services.zzzz]
|
||||||
|
token = "xxxxxxxxxxxxxxxxx" # 必须与服务器相同以通过验证
|
||||||
|
local_addr = "127.0.0.1:80" # 需要被转发的服务的地址
|
5
intranet-penetration/conf/server.example.toml
Normal file
5
intranet-penetration/conf/server.example.toml
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
[server]
|
||||||
|
bind_addr = "xxx.xxx.xxx.xxx:yyy" # `yyy` 配置了服务端监听客户端连接的端口
|
||||||
|
[server.services.zzzz]
|
||||||
|
token = "xxxxxxxxxxxxxxxxx" # 用于验证的 token
|
||||||
|
bind_addr = "0.0.0.0:aaaa" # `aaaa` 配置暴露给互联网的端口
|
@ -11,7 +11,9 @@ const App = createApp({
|
|||||||
App.use(setGlobalDataPlugin, {
|
App.use(setGlobalDataPlugin, {
|
||||||
globalData: {
|
globalData: {
|
||||||
debugMode: true, // 是否展示调试内容
|
debugMode: true, // 是否展示调试内容
|
||||||
baseUrl: "http://localhost", // 不带最后的 /
|
baseUrl: true
|
||||||
|
? "http://39.99.244.156:5203"
|
||||||
|
: "http://localhost", // 不带最后的 /
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
@ -62,7 +62,7 @@ export default {
|
|||||||
title: "登录成功",
|
title: "登录成功",
|
||||||
icon: 'success',
|
icon: 'success',
|
||||||
success: function () {
|
success: function () {
|
||||||
Taro.redirectTo({
|
Taro.switchTab({
|
||||||
url: '/pages/index/index'
|
url: '/pages/index/index'
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
export default definePageConfig({
|
export default definePageConfig({
|
||||||
navigationBarTitleText: '身份码'
|
navigationBarTitleText: '身份码',
|
||||||
|
enablePullDownRefresh: true,
|
||||||
})
|
})
|
||||||
|
@ -5,5 +5,7 @@
|
|||||||
#myQrcode {
|
#myQrcode {
|
||||||
display: block;
|
display: block;
|
||||||
margin: 0 auto;
|
margin: 0 auto;
|
||||||
/* border: 20px solid red; */
|
|
||||||
|
margin-top: 50px;
|
||||||
|
margin-bottom: 40px;
|
||||||
}
|
}
|
||||||
|
@ -1,8 +1,5 @@
|
|||||||
<template>
|
<template>
|
||||||
<view>
|
<view>
|
||||||
<view>
|
|
||||||
<image src="../../image/home.jpg" style="width: 100%;height: 150px;"></image>
|
|
||||||
</view>
|
|
||||||
<view style="text-align: center; margin-top: 100px;">
|
<view style="text-align: center; margin-top: 100px;">
|
||||||
<view><text>{{ id }} | {{ name }}</text></view>
|
<view><text>{{ id }} | {{ name }}</text></view>
|
||||||
<canvas type="2d" style="width: 70vw; height: 70vw;" id="myQrcode"></canvas>
|
<canvas type="2d" style="width: 70vw; height: 70vw;" id="myQrcode"></canvas>
|
||||||
@ -15,36 +12,58 @@
|
|||||||
import Taro from '@tarojs/taro'
|
import Taro from '@tarojs/taro'
|
||||||
import { eventCenter, getCurrentInstance } from '@tarojs/taro'
|
import { eventCenter, getCurrentInstance } from '@tarojs/taro'
|
||||||
import drawQrcode from '../../utils/qrcode/index'
|
import drawQrcode from '../../utils/qrcode/index'
|
||||||
|
import utils from '../../utils/utils'
|
||||||
|
|
||||||
import './code.css'
|
import './code.css'
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
|
...Taro.getApp().globalData,
|
||||||
userInfo: null,
|
userInfo: null,
|
||||||
id: 'id',
|
timeInterval: null,
|
||||||
name: '姓名',
|
id: '',
|
||||||
time: 'time',
|
name: '',
|
||||||
|
time: '',
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
mounted() {
|
|
||||||
eventCenter.once(getCurrentInstance().router.onShow, () => {
|
// 对应 onShow
|
||||||
|
onShow() {
|
||||||
console.log('onShow')
|
console.log('onShow')
|
||||||
|
setTimeout(() => {
|
||||||
|
Taro.startPullDownRefresh();
|
||||||
|
}, 100)
|
||||||
|
},
|
||||||
|
|
||||||
|
// 对应 onHide
|
||||||
|
onHide() {
|
||||||
|
console.log('onHide')
|
||||||
|
clearInterval(this.timeInterval);
|
||||||
|
},
|
||||||
|
|
||||||
|
// 对应 onPullDownRefresh
|
||||||
|
onPullDownRefresh() {
|
||||||
|
console.log('onPullDownRefresh')
|
||||||
|
Taro.showNavigationBarLoading();
|
||||||
|
clearInterval(this.timeInterval);
|
||||||
|
this.id = ''
|
||||||
|
this.name = ''
|
||||||
|
this.time = ''
|
||||||
this.userInfo = Taro.getStorageSync("userInfo");
|
this.userInfo = Taro.getStorageSync("userInfo");
|
||||||
if (this.userInfo) {
|
if (!this.userInfo) {
|
||||||
console.log(this.userInfo)
|
|
||||||
this.id = this.userInfo.id
|
|
||||||
this.name = this.userInfo.realname
|
|
||||||
this.drawCode()
|
|
||||||
} else {
|
|
||||||
Taro.redirectTo({
|
Taro.redirectTo({
|
||||||
url: '/pages/index/login'
|
url: '/pages/index/login'
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
})
|
this.id = this.userInfo.id
|
||||||
|
this.name = this.userInfo.realname
|
||||||
|
this.drawCode()
|
||||||
|
Taro.stopPullDownRefresh();
|
||||||
|
Taro.hideNavigationBarLoading();
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
drawCode() {
|
drawCode(text = 'https://www.baidu.com/', foreground = 'red') {
|
||||||
const query = wx.createSelectorQuery()
|
const query = wx.createSelectorQuery()
|
||||||
query.select('#myQrcode')
|
query.select('#myQrcode')
|
||||||
.fields({
|
.fields({
|
||||||
@ -61,28 +80,17 @@ export default {
|
|||||||
width: 260,
|
width: 260,
|
||||||
padding: 30,
|
padding: 30,
|
||||||
background: '#ffffff',
|
background: '#ffffff',
|
||||||
foreground: 'red', // '#000000',
|
foreground: foreground,
|
||||||
text: '大王顶真帅',
|
text: text,
|
||||||
})
|
})
|
||||||
|
|
||||||
// 获取临时路径(得到之后,想干嘛就干嘛了)
|
this.timeInterval = setInterval(this.updateTime, 1000);
|
||||||
wx.canvasToTempFilePath({
|
this.updateTime();
|
||||||
canvasId: 'myQrcode',
|
})
|
||||||
canvas: canvas,
|
|
||||||
x: 0,
|
|
||||||
y: 0,
|
|
||||||
width: 260,
|
|
||||||
height: 260,
|
|
||||||
destWidth: 260,
|
|
||||||
destHeight: 260,
|
|
||||||
success(res) {
|
|
||||||
console.log('二维码临时路径:', res.tempFilePath)
|
|
||||||
},
|
},
|
||||||
fail(res) {
|
updateTime() {
|
||||||
console.error(res)
|
this.time = utils.formatTime(new Date())
|
||||||
}
|
console.log("刷新时间")
|
||||||
})
|
|
||||||
})
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user