This commit is contained in:
YeMingfei666 2025-11-07 16:22:28 +08:00
commit e8c93e8ddb
8 changed files with 3626 additions and 2359 deletions

256
App.vue
View File

@ -25,135 +25,135 @@ App.vue本身不是页面这里不能编写视图元素也就是没有<tem
uni.hideTabBar()
//#ifdef APP-PLUS
//
plus.runtime.getProperty(plus.runtime.appid, widgetInfo => {
//
console.log("widgetInfo==",widgetInfo)
getFindBySource({source:'点餐宝'}).then(res => {
if (res.url && widgetInfo.version < res.version) {
let downloadLink = res.url;
console.log(downloadLink)
let ready = false;
//
if (res.isUp == 1) {
uni.showModal({
showCancel: false,
title: '发现新版本',
confirmText: '立即更新',
content: res.message,
success: res => {
if (res.confirm) {
uni.showLoading({title:'下载中...'});
if (uni.getSystemInfoSync().platform ==
'android') {
uni.hideLoading()
uni.downloadFile({
url: downloadLink,
success: downloadResult => {
uni.hideLoading()
if (downloadResult.statusCode === 200) {
plus.io.resolveLocalFileSystemURL(downloadResult.tempFilePath, entry => {
entry.getParent(_oldFile=>{
entry.moveTo(_oldFile,'.apk',newFilePath=>{
console.log('newFilePath',newFilePath.fullPath)
plus.runtime
.install(newFilePath.fullPath, { force: false },
d => {
console
.log(
'install success...'
);
plus.runtime
.restart();
},
e => {
console.log(e)
console
.error(
'install fail...'
);
}
);
})
})
})
}
}
});
}
if (uni.getSystemInfoSync().platform ==
'ios') {
plus.runtime.openURL(downloadLink, function(
res) {});
}
} else if (res.cancel) {
console.log('取消');
}
}
});
} else {
uni.showModal({
title: '发现新版本',
confirmText: '立即更新',
cancelText: '下次更新',
content: res.message,
success: res => {
if (res.confirm) {
uni.showLoading({title:'下载中...'});
if (uni.getSystemInfoSync().platform ==
'android') {
uni.downloadFile({
url: downloadLink,
success: downloadResult => {
if (downloadResult
.statusCode ===
200) {
plus.io.resolveLocalFileSystemURL(downloadResult.tempFilePath, entry => {
entry.getParent(_oldFile=>{
entry.moveTo(_oldFile,'.apk',newFilePath=>{
console.log('newFilePath',newFilePath.fullPath)
plus.runtime
.install(newFilePath.fullPath, { force: false },
d => {
console
.log(
'install success...'
);
plus.runtime
.restart();
},
e => {
console.log(e)
console
.error(
'install fail...'
);
}
);
})
})
})
// plus.runtime.getProperty(plus.runtime.appid, widgetInfo => {
// //
// console.log("widgetInfo==",widgetInfo)
// getFindBySource({source:''}).then(res => {
// if (res.url && widgetInfo.version < res.version) {
// let downloadLink = res.url;
// console.log(downloadLink)
// let ready = false;
// //
// if (res.isUp == 1) {
// uni.showModal({
// showCancel: false,
// title: '',
// confirmText: '',
// content: res.message,
// success: res => {
// if (res.confirm) {
// uni.showLoading({title:'...'});
// if (uni.getSystemInfoSync().platform ==
// 'android') {
// uni.hideLoading()
// uni.downloadFile({
// url: downloadLink,
// success: downloadResult => {
// uni.hideLoading()
// if (downloadResult.statusCode === 200) {
// plus.io.resolveLocalFileSystemURL(downloadResult.tempFilePath, entry => {
// entry.getParent(_oldFile=>{
// entry.moveTo(_oldFile,'.apk',newFilePath=>{
// console.log('newFilePath',newFilePath.fullPath)
// plus.runtime
// .install(newFilePath.fullPath, { force: false },
// d => {
// console
// .log(
// 'install success...'
// );
// plus.runtime
// .restart();
// },
// e => {
// console.log(e)
// console
// .error(
// 'install fail...'
// );
// }
// );
// })
// })
// })
// }
// }
// });
// }
// if (uni.getSystemInfoSync().platform ==
// 'ios') {
// plus.runtime.openURL(downloadLink, function(
// res) {});
// }
// } else if (res.cancel) {
// console.log('');
// }
// }
// });
// } else {
// uni.showModal({
// title: '',
// confirmText: '',
// cancelText: '',
// content: res.message,
// success: res => {
// if (res.confirm) {
// uni.showLoading({title:'...'});
// if (uni.getSystemInfoSync().platform ==
// 'android') {
// uni.downloadFile({
// url: downloadLink,
// success: downloadResult => {
// if (downloadResult
// .statusCode ===
// 200) {
// plus.io.resolveLocalFileSystemURL(downloadResult.tempFilePath, entry => {
// entry.getParent(_oldFile=>{
// entry.moveTo(_oldFile,'.apk',newFilePath=>{
// console.log('newFilePath',newFilePath.fullPath)
// plus.runtime
// .install(newFilePath.fullPath, { force: false },
// d => {
// console
// .log(
// 'install success...'
// );
// plus.runtime
// .restart();
// },
// e => {
// console.log(e)
// console
// .error(
// 'install fail...'
// );
// }
// );
// })
// })
// })
}
}
});
}
if (uni.getSystemInfoSync().platform ==
'ios') {
plus.runtime.openURL(downloadLink, function(
res) {});
}
} else if (res.cancel) {
uni.hideLoading()
console.log('取消');
}
}
});
}
}
}).catch((res)=>{
console.log(res)
})
});
// }
// }
// });
// }
// if (uni.getSystemInfoSync().platform ==
// 'ios') {
// plus.runtime.openURL(downloadLink, function(
// res) {});
// }
// } else if (res.cancel) {
// uni.hideLoading()
// console.log('');
// }
// }
// });
// }
// }
// }).catch((res)=>{
// console.log(res)
// })
// });
// #endif

View File

@ -8,7 +8,7 @@ const appConfig = {
// 环境变量相关
env: {},
wss: "ws://192.168.1.42:2348", //
wss: "ws://192.168.1.42:2348", // ws://192.168.1.42:2348
// wss: "wss://sockets.sxczgkj.com/wss", //
// 环境变量常量
ENV_ENUM: {

View File

@ -7,7 +7,8 @@
"js-base64": "^3.7.2",
"jsencrypt": "^3.3.2",
"lodash": "^4.17.21",
"uview-plus": "^3.3.32"
"uview-plus": "^3.3.32",
"ysk-utils": "^1.0.50"
},
"devDependencies": {
"copy-webpack-plugin": "^12.0.2",

View File

@ -1,25 +1,19 @@
<template>
<view class="login-wrapper">
<view class="login-top">
<text>欢迎回来请登录</text>
<image @tap="envChangeTipsRef.tapFunc()" style="width: 320rpx; height: 76rpx"
:src="vdata.siteInfos.appTopImgUrl" />
<image @tap="envChangeTipsRef.tapFunc()" style="width: 320rpx; height: 76rpx" :src="vdata.siteInfos.appTopImgUrl" />
</view>
<view class="login-bottom jeepay-form">
<!-- 不需要label, 需要修改 label-width="0" -->
<uni-forms ref="loginFormRef" label-width="0" :model="vdata.formData" :rules="rules">
<view class="u-p-b-30">
<my-tabs size="large" @change="accountTypeChange" v-model="accountType.sel" :list="accountType.list"
textKey="label"></my-tabs>
<my-tabs size="large" @change="accountTypeChange" v-model="accountType.sel" :list="accountType.list" textKey="label"></my-tabs>
</view>
<view v-if="vdata.loginType == 'pwd'">
<template v-if="accountType.sel == 1">
<uni-forms-item name="merchantName">
<uni-easyinput class='jeepay-easyinput' placeholder="请输入商户号"
v-model="vdata.formData.merchantName" :clearable="false">
<uni-easyinput class="jeepay-easyinput" placeholder="请输入商户号" v-model="vdata.formData.merchantName" :clearable="false">
<template #prefixIcon>
<image src="@/static/login/icon-user.svg" class="input-icon" />
</template>
@ -28,8 +22,7 @@
</template>
<uni-forms-item name="username">
<uni-easyinput class='jeepay-easyinput' placeholder="请输入登录名/手机号"
v-model="vdata.formData.username" :clearable="false">
<uni-easyinput class="jeepay-easyinput" placeholder="请输入登录名/手机号" v-model="vdata.formData.username" :clearable="false">
<template #prefixIcon>
<image src="@/static/login/icon-user.svg" class="input-icon" />
</template>
@ -37,13 +30,18 @@
</uni-forms-item>
<uni-forms-item name="pwd">
<uni-easyinput class='jeepay-easyinput' :type="vdata.isShowPwd ? 'text' : 'password'"
v-model="vdata.formData.pwd" :clearable="false" placeholder="请输入登录密码">
<uni-easyinput
class="jeepay-easyinput"
:type="vdata.isShowPwd ? 'text' : 'password'"
v-model="vdata.formData.pwd"
:clearable="false"
placeholder="请输入登录密码"
>
<template #prefixIcon>
<image src="@/static/login/icon-pw.svg" class="input-icon" />
</template>
<template #suffixIcon>
<view class='show-tips' @tap="vdata.isShowPwd = !vdata.isShowPwd ">
<view class="show-tips" @tap="vdata.isShowPwd = !vdata.isShowPwd">
{{ vdata.isShowPwd ? '隐藏' : '显示' }}
</view>
</template>
@ -52,60 +50,57 @@
<uni-forms-item name="code">
<!-- 手机验证码 不限制数字还是本文 如果发送为文本则无需app升级 -->
<view style="display: flex;" class="u-flex u-flex-y-center">
<uni-easyinput class='jeepay-easyinput' :maxlength="6" placeholder="请输入验证码"
v-model="vdata.formData.code" :clearable="false">
<view style="display: flex" class="u-flex u-flex-y-center">
<uni-easyinput class="jeepay-easyinput" :maxlength="6" placeholder="请输入验证码" v-model="vdata.formData.code" :clearable="false">
<template #prefixIcon>
<image src="@/static/login/icon-sms-code.svg" class="input-icon" />
</template>
</uni-easyinput>
<image :src="vdata.formData.img" class=" u-m-b-50"
style="width: 200rpx; height: 80rpx;margin-left: 10rpx;" @click="getCode" mode="">
</image>
<image :src="vdata.formData.img" class="u-m-b-50" style="width: 200rpx; height: 80rpx; margin-left: 10rpx" @click="getCode" mode=""></image>
</view>
</uni-forms-item>
</view>
<view v-if="vdata.loginType == 'sms'">
<uni-forms-item name="loginPhone">
<uni-easyinput class='jeepay-easyinput' v-model="vdata.formData.loginPhone" type="number"
:maxlength="11" :disabled="!vdata.allowSendMsgFlag" placeholder="请输入手机号" :clearable="false">
<uni-easyinput
class="jeepay-easyinput"
v-model="vdata.formData.loginPhone"
type="number"
:maxlength="11"
:disabled="!vdata.allowSendMsgFlag"
placeholder="请输入手机号"
:clearable="false"
>
<template #prefixIcon>
<image src="@/static/login/icon-phone.svg" class="input-icon" />
</template>
<template #suffixIcon>
<view class='show-tips' @tap="sendSmscodeFunc">{{ vdata.sendMsgText }}</view>
<view class="show-tips" @tap="sendSmscodeFunc">{{ vdata.sendMsgText }}</view>
</template>
</uni-easyinput>
</uni-forms-item>
<uni-forms-item>
<!-- 手机验证码 不限制数字还是本文 如果发送为文本则无需app升级 -->
<view style="display: flex;">
<uni-easyinput class='jeepay-easyinput' :maxlength="6" placeholder="请输入验证码"
v-model="vdata.formData.vercode" :clearable="false">
<view style="display: flex">
<uni-easyinput class="jeepay-easyinput" :maxlength="6" placeholder="请输入验证码" v-model="vdata.formData.vercode" :clearable="false">
<template #prefixIcon>
<image src="@/static/login/icon-sms-code.svg" class="input-icon" />
</template>
</uni-easyinput>
<image :src="vdata.formData.imgCodeUrl"
style="width: 200rpx; height: 110rpx;margin-left: 10rpx;" @click="getCode" mode="">
</image>
<image :src="vdata.formData.imgCodeUrl" style="width: 200rpx; height: 110rpx; margin-left: 10rpx" @click="getCode" mode=""></image>
</view>
</uni-forms-item>
<uni-forms-item name="smsCode">
<!-- 手机验证码 不限制数字还是本文 如果发送为文本则无需app升级 -->
<uni-easyinput class='jeepay-easyinput' :maxlength="6" placeholder="请输入手机验证码"
v-model="vdata.formData.smsCode" :clearable="false">
<uni-easyinput class="jeepay-easyinput" :maxlength="6" placeholder="请输入手机验证码" v-model="vdata.formData.smsCode" :clearable="false">
<template #prefixIcon>
<image src="@/static/login/icon-sms-code.svg" class="input-icon" />
</template>
</uni-easyinput>
</uni-forms-item>
</view>
</uni-forms>
<!-- <view class="agreement-policy">
@ -116,7 +111,6 @@
<text class="policy" @click="toPrivacy">隐私政策</text>
</view> -->
<!-- <view class="agreement-policy">
<JeepayCheckbox v-model:checked="vdata.isSelectedAgreement" />
同意
@ -126,7 +120,6 @@
<text class="policy" @click="go.to('PAGES_STATIC_POLICY')">隐私政策</text>
</view> -->
<Button @tap="loginFunc">登录</Button>
<!-- <view class="register-box">
@ -139,92 +132,68 @@
{{ vdata.loginType == 'pwd' ? '短信验证码登录' : '账号密码登录' }}
<image src="@/static/login/icon-arrow-left.svg"></image>
</view> -->
</view>
</view>
<JAgree service="PAGES_STATIC_AGREEMENT" privacy="PAGES_FORGET_PASSWORD" ref="refAgr"
@agree="vdata.isSelectedAgreement = true" />
<JAgree service="PAGES_STATIC_AGREEMENT" privacy="PAGES_FORGET_PASSWORD" ref="refAgr" @agree="vdata.isSelectedAgreement = true" />
</template>
<script setup>
import {
encrypt
} from '@/commons/utils/rsaEncrypt.js'
import { encrypt } from '@/commons/utils/rsaEncrypt.js';
import {
ref,
reactive,
onMounted,
watch
} from 'vue';
import {
$loginByPwd,
$phoneCodeLogin,
$userInfo,
$sendSms,
$getSiteInfos,
$getUploadImgSize,
$isCode
} from '@/http/apiManager.js';
import storageManage from '@/commons/utils/storageManage.js'
import { ref, reactive, onMounted, watch } from 'vue';
import { $loginByPwd, $phoneCodeLogin, $userInfo, $sendSms, $getSiteInfos, $getUploadImgSize, $isCode } from '@/http/apiManager.js';
import storageManage from '@/commons/utils/storageManage.js';
import infoBox from '@/commons/utils/infoBox.js';
import go from '@/commons/utils/go.js'
import timer from '@/commons/utils/timer.js'
import formUtil from '@/commons/utils/formUtil.js'
import Button from '@/components/Button/Button.vue'
import {
getExtStoreId
} from "@/commons/utils/versionManage.js"
import {
$login
} from '@/http/newApi/login.js';
import {
login,
getCodeImg
} from '@/http/yskApi/login.js';
import go from '@/commons/utils/go.js';
import timer from '@/commons/utils/timer.js';
import formUtil from '@/commons/utils/formUtil.js';
import Button from '@/components/Button/Button.vue';
import { getExtStoreId } from '@/commons/utils/versionManage.js';
import { $login } from '@/http/newApi/login.js';
import { login, getCodeImg } from '@/http/yskApi/login.js';
const accountType = reactive({
list: [{
list: [
{
label: '商户',
value: '0'
},
{
label: '员工',
value: '1'
},
}
],
sel: 0
})
});
const loginFormRef = ref()
const envChangeTipsRef = ref()
const refAgr = ref()
const loginFormRef = ref();
const envChangeTipsRef = ref();
const refAgr = ref();
const rules = {
merchantName: {
rules: [formUtil.rules.requiredInputShowToast('商户号')],
rules: [formUtil.rules.requiredInputShowToast('商户号')]
},
username: {
rules: [formUtil.rules.requiredInputShowToast('用户名')],
rules: [formUtil.rules.requiredInputShowToast('用户名')]
},
pwd: {
rules: [formUtil.rules.requiredInputShowToast('密码')],
rules: [formUtil.rules.requiredInputShowToast('密码')]
},
safetyCode: {
rules: [formUtil.rules.requiredInputShowToast('安全码')],
rules: [formUtil.rules.requiredInputShowToast('安全码')]
},
code: {
rules: [formUtil.rules.requiredInputShowToast('验证码')],
rules: [formUtil.rules.requiredInputShowToast('验证码')]
},
loginPhone: {
rules: [formUtil.rules.requiredInputShowToast('手机号')],
rules: [formUtil.rules.requiredInputShowToast('手机号')]
},
smsCode: {
rules: [formUtil.rules.requiredInputShowToast('短信验证码')],
},
rules: [formUtil.rules.requiredInputShowToast('短信验证码')]
}
};
const vdata = reactive({
isShowPwd: false, //
loginType: 'pwd', // pwd or sms
isShowSafetyCode: false, //
@ -242,12 +211,11 @@
uuid: '',
merchantName: '',
loginType: 'merchant'
},
})
}
});
// #ifdef H5
vdata.formData.username = 'xpc'
vdata.formData.pwd = '123'
vdata.formData.username = 'xpc';
vdata.formData.pwd = '123';
// #endif
// #ifdef MP-WEIXIN
// vdata.formData.username = '15699991111'
@ -257,23 +225,29 @@
function accountTypeChange(e) {
// #ifdef H5
if (e == 1) {
vdata.formData.merchantName = '18049104914'
vdata.formData.username = '13666666666'
vdata.formData.pwd = '123456'
vdata.formData.merchantName = '18049104914';
vdata.formData.username = '13666666666';
vdata.formData.pwd = '123456';
} else {
vdata.formData.pwd = 'qwer1234'
vdata.formData.pwd = 'qwer1234';
}
// #endif
}
const getCode = () => {
getCodeImg().then(res => {
vdata.formData.img = res.data.code
vdata.formData.uuid = res.data.uuid
})
const getCode = async () => {
try {
const res = await getCodeImg();
vdata.formData.img = res.data.code;
vdata.formData.uuid = res.data.uuid;
} catch (error) {
uni.showToast({
title: error.message,
icon: 'none'
});
}
};
getCode()
getCode();
onMounted(() => {
// getExtStoreId()
@ -286,12 +260,12 @@
// })
// }
// ,
let info = uni.getStorageSync('MerchantId')
let info = uni.getStorageSync('MerchantId');
if (info.merchantName) {
vdata.formData.merchantName = info.merchantName
vdata.formData.username = info.username
vdata.formData.merchantName = info.merchantName;
vdata.formData.username = info.username;
}
})
});
//
function changeLoginType() {
@ -306,7 +280,8 @@
// return false
// }
let loginPromise = null;
if (vdata.loginType == 'pwd') { //
if (vdata.loginType == 'pwd') {
//
// loginPromise = $loginByPwd(vdata.formData.username, vdata.formData.pwd, vdata.formData.safetyCode)
loginPromise = login({
username: vdata.formData.username,
@ -317,35 +292,35 @@
uuid: vdata.formData.uuid,
merchantName: vdata.formData.merchantName,
loginType: accountType.list[accountType.sel].value
})
} else if (vdata.loginType == 'sms') { //
loginPromise = $phoneCodeLogin(vdata.formData.loginPhone, vdata.formData.smsCode)
});
} else if (vdata.loginType == 'sms') {
//
loginPromise = $phoneCodeLogin(vdata.formData.loginPhone, vdata.formData.smsCode);
}
if (loginPromise == null) {
return false;
}
//
loginPromise.then(res => {
loginPromise
.then((res) => {
//
loginFinishFunc(res.data)
loginFinishFunc(res.data);
//
uni.setStorageSync('MerchantId', {
merchantName: vdata.formData.merchantName,
username: vdata.formData.username,
username: vdata.formData.username
});
})
}).catch(e => {
getCode()
})
})
.catch((e) => {
getCode();
});
});
}
const toPrivacy = () => {
// #ifdef APP-PLUS
go.to('PAGES_STATIC_POLICY')
go.to('PAGES_STATIC_POLICY');
// #endif
//
// #ifdef MP-WEIXIN
@ -354,27 +329,30 @@
uni.showToast({
title: '打开失败请稍后重试', //
icon: 'none'
})
},
})
});
}
});
// #endif
}
watch(() => accountType.sel, (newval) => {
};
watch(
() => accountType.sel,
(newval) => {
if (newval == 1) {
vdata.formData.merchantName = uni.getStorageSync('merchantName') || ''
vdata.formData.merchantName = uni.getStorageSync('merchantName') || '';
} else {
vdata.formData.username = ''
vdata.formData.username = '';
}
})
}
);
//
async function loginFinishFunc(loginBizData) {
// token
uni.setStorageSync('shopInfo',loginBizData.shopInfo)
uni.setStorageSync('tokenInfo',loginBizData.tokenInfo)
uni.setStorageSync('shopId',loginBizData.shopInfo.id)
uni.setStorageSync('loginType',loginBizData.loginType)
uni.setStorageSync('shopInfo', loginBizData.shopInfo);
uni.setStorageSync('tokenInfo', loginBizData.tokenInfo);
uni.setStorageSync('shopId', loginBizData.shopInfo.id);
uni.setStorageSync('loginType', loginBizData.loginType);
//
go.to("PAGES_CREATE_ORDER")
go.to('PAGES_CREATE_ORDER');
// uni.navigateTo({
// url:'pagesCreateOrder/index/index'
// })
@ -389,41 +367,39 @@
//
if (!formUtil.regexp.mobile.test(vdata.formData.loginPhone)) {
return infoBox.showToast("请输入正确的手机号")
return infoBox.showToast('请输入正确的手机号');
}
if (!vdata.formData.vercode) {
return infoBox.showToast("请输入图像验证码");
return infoBox.showToast('请输入图像验证码');
}
vdata.allowSendMsgFlag = false; //
let data = {
phone: vdata.formData.loginPhone,
vercode: vdata.formData.vercode,
vercodeToken: vdata.formData.vercodeToken,
}
vercodeToken: vdata.formData.vercodeToken
};
//
$sendSms(data, 'auth').then(({
bizData
}) => {
infoBox.showSuccessToast('验证码发送成功')
$sendSms(data, 'auth')
.then(({ bizData }) => {
infoBox.showSuccessToast('验证码发送成功');
timer.startTimeoutTask(1, 60, (subTime) => {
if (subTime <= 0) { //
vdata.sendMsgText = '发送验证码'
if (subTime <= 0) {
//
vdata.sendMsgText = '发送验证码';
vdata.allowSendMsgFlag = true;
return false;
}
vdata.sendMsgText = `${subTime}s后可重新发送`
vdata.sendMsgText = `${subTime}s后可重新发送`;
});
})
}).catch(() => {
.catch(() => {
vdata.allowSendMsgFlag = true;
})
});
}
</script>
@ -439,7 +415,7 @@
height: 376rpx;
padding: 176rpx 70rpx 0;
box-sizing: border-box;
background: url("/static/indexImg/user-bg.svg") center center no-repeat;
background: url('/static/indexImg/user-bg.svg') center center no-repeat;
background-size: cover;
text:first-child {
@ -452,7 +428,7 @@
text:last-child {
font-size: 50rpx;
font-weight: 600;
color: #48C0FF;
color: #48c0ff;
}
}
@ -477,7 +453,7 @@
margin-top: 10rpx;
margin-bottom: 50rpx;
font-size: 26rpx;
color: #8C8C8C;
color: #8c8c8c;
.select-box {
display: flex;
@ -491,7 +467,7 @@
.agreement,
.policy {
color: #1D79FD;
color: #1d79fd;
}
}
@ -505,12 +481,12 @@
.register {
text:last-child {
color: #1D79FD;
color: #1d79fd;
}
}
.forget {
color: #1D79FD;
color: #1d79fd;
}
}

File diff suppressed because it is too large Load Diff

1304
pnpm-lock.yaml Normal file

File diff suppressed because it is too large Load Diff

View File

@ -1,4 +1,6 @@
import { defineConfig } from 'vite'
import {
defineConfig
} from 'vite'
import uni from '@dcloudio/vite-plugin-uni'
export default defineConfig({
@ -14,8 +16,8 @@ export default defineConfig({
},
"/ysk": {
// 需要被代理的后台地址
"target" : "http://192.168.1.42",
"changeOrigin": true,
target: "http://192.168.1.42",
changeOrigin: true,
rewrite: (path) => path.replace(/^\/ysk/, '')
},
}

View File

@ -33,7 +33,7 @@ module.exports = {
rewrite: '/' // 重写路径
},
"/ysk": {
"target": "http://192.168.1.42",
target: "http://192.168.1.42",
changeOrigin: true,
pathRewrite: {
"^/ysk": ""