vue2设置自定义域名跳转

需求:首次登录域名为aa.com,之后登录系统后在系统内某个模块设置三级域名为second,之后退出登录到aa.com,登录进入系统后域名自动变为second.aa.com最后退出的域名也是second.aa.com,通过不同的域名配置动态的登录页面和系统内布局样式等

1.效果

原域名

输入账号登录后,添加了自定义的域名test在最前面

2.环境配置

要实现这个功能需要区分生产环境(本地)development和开发环境(线上)production

3.登录页请求

需要在登录页http://test.xx.com.cn/#/login页面直接调用后端接口,后端会返回登录页的公司图标等样式文件。在登录页肯定没有token,需要后端根据域名判断

4.登录系统后

登录系统后需要根据登录返回的domain域名来跳转,需要区分环境判断。例子如下

javascript 复制代码
this.$store
            .dispatch("userInfo/Login", this.userLoginForm)
            .then((domain) => {

              if (process.env.NODE_ENV === "development") {
                this.$router.push({ path: "/" });
              } else {
                // 构建跳转URL
                const targetUrl = this.buildRedirectUrl(domain);
                // // 跳转到目标地址
                window.location.href = targetUrl;
              }
            })
            .catch(() => {
   
            });
    // 构建跳转URL的方法
    buildRedirectUrl(domain) {

      const primaryDomain = domain
        ? `http://${domain}.xx.com.cn/`
        : `http://xx.com.cn/`;
      // 构建完整URL
      return primaryDomain;
    },

5.axios设置

跳转后会出现跨域的问题,所以axios配置也要添加判断,

javascript 复制代码
const instance = axios.create({
    baseURL: process.env.NODE_ENV === 'production' ? undefined : 'http://xx.com.cn/',
    withCredentials: process.env.NODE_ENV === 'production' ? true : false  // 线上必须要设置允许跨域
})

6.退出登录

在清空了token后直接跳转到login即可,路由拦截的话也是直接跳转到/login就行

javascript 复制代码
       this.$router.replace("/login");

文章到此结束,希望对你有所帮助~

相关推荐
Zestia12 分钟前
页面点击跳转源代码?——element-jumper插件实现
前端·javascript
前端小白199512 分钟前
面试取经:工程化篇-webpack性能优化之优化loader性能
前端·面试·前端工程化
PineappleCoder12 分钟前
大小写 + 标点全搞定!JS 如何精准统计单词频率?
前端·javascript·算法
zhangbao90s14 分钟前
Web组件:使用Shadow DOM
前端
hhy前端之旅14 分钟前
语义版本控制:掌握版本管理的艺术
前端
coding随想14 分钟前
深入浅出DOM操作的隐藏利器:Range(范围)对象——掌控文档的“手术刀”
前端
前端小白199515 分钟前
面试取经:工程化篇-webpack性能优化之减少模块解析
前端·面试·前端工程化
一枚前端小能手15 分钟前
🏗️ 项目越来越大维护不动了,微前端架构了解一下
前端
KasukabeTsumugi15 分钟前
TypeScript:联合类型可以转化为元组类型吗?数组如何用联合类型逐项约束?
javascript
文艺理科生24 分钟前
Nuxt.js入门指南-Vue生态下的高效渲染技术
前端·vue.js·nuxt.js