• SPA项目开发之登录注册


    目录

    一、用户登录前置准备

    登录排版

    二、 vue数据交互(登录功能)

     实现:注册跳转

     三、this指针污染

    登录功能实现:

    四、CORS跨域

    五、工具类的作用(post和get的区别)


    一、用户登录前置准备

    操作步骤:

    1.确保后台项目T216_SSH能够成功运行;

    标志:http://localhost:8080/T216_SSH/vue/treeNodeAction.action

    2、要将api文件夹导入src的目录

    3、下载js依赖

    axios:前端向后台发送请求

    qs:解决发送post请求 代码冗余问题

    elemenetUi:快速布局

    vue-axios:将axios依赖整合进vue里

    导入已经准备好的项目T216_SSH

    正在上传…重新上传取消

    修改连接信息

    说明项目导入成功! 

     打开Hbuild  X添加文件api

     数据库导入该表

     就可显示数据

     

    安装开发模块

    npm install element-ui -S  

    npm install axios -S

    npm install qs -S  

    npm install vue-axios -S

     

     依赖已经加入

     

    登录排版

    测试

    main.js

    // The Vue build version to load with the `import` command
    // (runtime-only or standalone) has been set in webpack.base.conf with an alias.
    import Vue from 'vue'
    import ElementUI from 'element-ui' // 新添加 1
    import 'element-ui/lib/theme-chalk/index.css' // 新添加 2 ,避免后期打包样式不同,要放在import App from './App'; 之前

    import App from './App'
    import router from './router'

    Vue.use(ElementUI)   // 新添加 3

    Vue.config.productionTip = false

    /* eslint-disable no-new */
    new Vue({
      el: '#app',
      router,//挂载边界
      components: { App },
      template: ''
    })
     

     index.js

    import Vue from 'vue'
    import Router from 'vue-router'
    import HelloWorld from '@/components/HelloWorld'

    Vue.use(Router)

    export default new Router({
      routes: [//定义组件和路由关系
        {
          path: '/',
          name: 'HelloWorld',
          component: HelloWorld
        }

      ]
    })
     

     app.vue


     

     重启项目 在命令中运行npm run dev

     复制路径:测试可用

     

     index.js

    import Vue from 'vue'
    import Router from 'vue-router'
    import HelloWorld from '@/components/HelloWorld'
    import Login from '@/views/Login'

    Vue.use(Router)

    export default new Router({
      routes: [//定义组件和路由关系
        {
          path: '/',
          name: 'Login',
          component: Login
        },
        {
          path: '/Login',
          name: 'Login',
          component: Login
        }


      ]
    })
     

     app.vue


     

     form表单

     layout布局

     文字链接

     login.vue


     


    二、 vue数据交互(登录功能)

     实现:注册跳转

    登录界面

    1. <template>
    2. <div class="login-wrap">
    3. <el-form :model="ruleForm" status-icon label-width="100px" class="demo-ruleForm login-container">
    4. <el-row>
    5. <el-col :span="24">
    6. <div style="text-align: center;" class="grid-content bg-purple-dark">
    7. <h3>用户登录</h3>
    8. </div>
    9. </el-col>
    10. </el-row>
    11. <el-form-item label="用户" prop="uname">
    12. <el-input type="text" v-model="ruleForm.uname" autocomplete="off"></el-input>
    13. </el-form-item>
    14. <el-form-item label="密码" prop="pwd">
    15. <el-input type="password" v-model="ruleForm.pwd" autocomplete="off"></el-input>
    16. </el-form-item>
    17. <el-form-item>
    18. <el-row>
    19. <el-col :span="24">
    20. <div style="text-align: center;" class="grid-content bg-purple-dark">
    21. <el-button style="width:100% ;" type="primary" @click="submitForm">提交</el-button>
    22. </div>
    23. </el-col>
    24. </el-row>
    25. </el-form-item>
    26. <!--两个页面跳转 -->
    27. <el-form-item>
    28. <el-row>
    29. <el-col :span="12">
    30. <div style="text-align: center;" class="grid-content bg-purple-dark">
    31. <el-link type="success" @click="toReg" >用户注册</el-link>
    32. </div>
    33. </el-col>
    34. <el-col :span="12">
    35. <div style="text-align: center;" class="grid-content bg-purple-dark">
    36. <el-link type="warning" click="" >忘记密码</el-link>
    37. </div>
    38. </el-col>
    39. </el-row>
    40. </el-form-item>
    41. </el-form>
    42. </div>
    43. </template>
    44. <script>
    45. export default {
    46. name: 'Reg',
    47. data() {
    48. return {
    49. ruleForm: {}
    50. }
    51. },
    52. methods: {
    53. submitForm() {
    54. },
    55. resetForm() {
    56. },toReg(){//跳转
    57. this.$router.push({path:'/Reg'});
    58. }
    59. }
    60. }
    61. </script>
    62. <style scoped>
    63. .login-wrap {
    64. box-sizing: border-box;
    65. width: 100%;
    66. height: 100%;
    67. padding-top: 10%;
    68. background-image: url();
    69. /* background-color: #112346; */
    70. background-repeat: no-repeat;
    71. background-position: center right;
    72. background-size: 100%;
    73. }
    74. .login-container {
    75. border-radius: 10px;
    76. margin: 0px auto;
    77. width: 350px;
    78. padding: 30px 35px 15px 35px;
    79. background: #fff;
    80. border: 1px solid #eaeaea;
    81. text-align: left;
    82. box-shadow: 0 0 20px 2px rgba(0, 0, 0, 0.1);
    83. }
    84. .title {
    85. margin: 0px auto 40px auto;
    86. text-align: center;
    87. color: #505458;
    88. }
    89. </style>

     注册界面

    1. <template>
    2. <div class="login-wrap">
    3. <el-form :model="ruleForm" status-icon label-width="100px" class="demo-ruleForm login-container">
    4. <el-row>
    5. <el-col :span="24">
    6. <div style="text-align: center;" class="grid-content bg-purple-dark">
    7. <h3>用户注册</h3>
    8. </div>
    9. </el-col>
    10. </el-row>
    11. <el-form-item label="用户" prop="uname">
    12. <el-input type="text" v-model="ruleForm.uname" autocomplete="off"></el-input>
    13. </el-form-item>
    14. <el-form-item label="密码" prop="pwd">
    15. <el-input type="password" v-model="ruleForm.pwd" autocomplete="off"></el-input>
    16. </el-form-item>
    17. <el-form-item>
    18. <el-row>
    19. <el-col :span="24">
    20. <div style="text-align: center;" class="grid-content bg-purple-dark">
    21. <el-button style="width:100% ;" type="primary" @click="submitForm">提交</el-button>
    22. </div>
    23. </el-col>
    24. </el-row>
    25. </el-form-item>
    26. <!--两个页面跳转 -->
    27. <el-form-item>
    28. <el-row>
    29. <el-col :span="12">
    30. <div style="text-align: center;" class="grid-content bg-purple-dark">
    31. <el-link type="success" @click="toLogin" >用户登录</el-link>
    32. </div>
    33. </el-col>
    34. <el-col :span="12">
    35. <div style="text-align: center;" class="grid-content bg-purple-dark">
    36. <el-link type="warning" click="" >忘记密码</el-link>
    37. </div>
    38. </el-col>
    39. </el-row>
    40. </el-form-item>
    41. </el-form>
    42. </div>
    43. </template>
    44. <script>
    45. export default {
    46. name: 'Reg',
    47. data() {
    48. return {
    49. ruleForm: {}
    50. }
    51. },
    52. methods: {
    53. submitForm() {
    54. },
    55. resetForm() {
    56. },toLogin(){
    57. this.$router.push({path:'/Login'});
    58. }
    59. }
    60. }
    61. </script>
    62. <style scoped>
    63. .login-wrap {
    64. box-sizing: border-box;
    65. width: 100%;
    66. height: 100%;
    67. padding-top: 10%;
    68. background-image: url();
    69. /* background-color: #112346; */
    70. background-repeat: no-repeat;
    71. background-position: center right;
    72. background-size: 100%;
    73. }
    74. .login-container {
    75. border-radius: 10px;
    76. margin: 0px auto;
    77. width: 350px;
    78. padding: 30px 35px 15px 35px;
    79. background: #fff;
    80. border: 1px solid #eaeaea;
    81. text-align: left;
    82. box-shadow: 0 0 20px 2px rgba(0, 0, 0, 0.1);
    83. }
    84. .title {
    85. margin: 0px auto 40px auto;
    86. text-align: center;
    87. color: #505458;
    88. }
    89. </style>

     路由代码更新reg

    1. import Vue from 'vue'
    2. import Router from 'vue-router'
    3. import HelloWorld from '@/components/HelloWorld'
    4. import Login from '@/views/Login'
    5. import Reg from '@/views/Reg'
    6. Vue.use(Router)
    7. export default new Router({
    8. routes: [//定义组件和路由关系
    9. {
    10. path: '/',
    11. name: 'Login',
    12. component: Login
    13. },
    14. {
    15. path: '/Login',
    16. name: 'Login',
    17. component: Login
    18. },
    19. {
    20. path: '/Reg',
    21. name: 'Reg',
    22. component: Reg
    23. }
    24. ]
    25. })

    成功效果:点击用户注册出现用户注册界面

     三、this指针污染

    登录功能实现:

    数据交互:获取后台数据,做局部刷新;.axios相当于jquery的ajax

    语法:this.axios.post(url,this.param).then(function(resp){}).catch(function(error){})

     login.vue

    添加信息提示

     

     main.js

    1. // The Vue build version to load with the `import` command
    2. // (runtime-only or standalone) has been set in webpack.base.conf with an alias.
    3. import Vue from 'vue'
    4. import ElementUI from 'element-ui' // 新添加 1
    5. import 'element-ui/lib/theme-chalk/index.css' // 新添加 2 ,避免后期打包样式不同,要放在import App from './App'; 之前
    6. import App from './App'
    7. import router from './router'
    8. import axios from '@/api/http' //#vue项目对axios的全局配置
    9. import VueAxios from 'vue-axios'
    10. Vue.use(VueAxios,axios)
    11. Vue.use(ElementUI) // 新添加 3
    12. Vue.config.productionTip = false
    13. /* eslint-disable no-new */
    14. new Vue({
    15. el: '#app',
    16. router,//挂载边界
    17. components: { App },
    18. template: ''
    19. })

     

    1. <script>
    2. export default {
    3. name: 'Reg',
    4. data() {
    5. return {
    6. ruleForm: {}
    7. }
    8. },
    9. methods: {
    10. submitForm() {//提交功能
    11. // debugger;
    12. //相当于 $.post(url,function(){})
    13. let url=this.axios.urls.SYSTEM_USER_DOLOGIN;
    14. // {uname:'zs',pwd:'123'}
    15. // console.log(url);
    16. //this指的是vue实例
    17. this.axios.post(url,this.ruleForm)
    18. .then(resp => {//登录成功
    19. // console .log(resp);
    20. if(resp.data.code==1){
    21. this.$message({
    22. message: resp.data.msg,
    23. type: 'success'
    24. });
    25. }
    26. else if (resp.data.code==0){
    27. this.$message({
    28. message:resp.data.msg,
    29. type: 'warning'
    30. });
    31. }
    32. }).catch(function(){//登录失败
    33. });
    34. },
    35. resetForm() {
    36. },toReg(){//跳转
    37. this.$router.push({path:'/Reg'});
    38. }
    39. }
    40. }
    41. </script>

     action.js

     /**
     * 对后台请求的地址的封装,URL格式如下:
     * 模块名_实体名_操作
     */
    export default {
        'SERVER': 'http://localhost:8080/T216_SSH', //服务器
        'SYSTEM_USER_DOLOGIN': '/vue/userAction_login.action', //用户登陆
        'SYSTEM_USER_DOREG': '/vue/userAction_reg.action', //用户注册
        'SYSTEM_MENU_TREE': '/vue/treeNodeAction.action', //左侧树形菜单加载
        'SYSTEM_ARTICLE_LIST': '/vue/articleAction_list.action', //文章列表
        'SYSTEM_ARTICLE_ADD': '/vue/articleAction_add.action', //文章新增
        'SYSTEM_ARTICLE_EDIT': '/vue/articleAction_edit.action', //文章修改
        'SYSTEM_ARTICLE_DEL': '/vue/articleAction_del.action', //文章删除
        'SYSTEM_USER_GETASYNCDATA': '/vue/userAction_getAsyncData.action', //vuex中的异步加载数据
        'getFullPath': k => { //获得请求的完整地址,用于mockjs测试时使用
            return this.SERVER + this[k];
        }
    }

     运行过程中容易出现缓存问题需要重启elicse项目

     输入错误用户名zz


     

    四、CORS跨域

     

    跨域现象:Access to XMLHttpRequest at 'http://localhost:8080/T216_SSH/vue/userAction_login.action' from origin 'http://localhost:8083' has been blocked by CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource.

    产生因素:协议;端口;ip;有任意一处发生改变都会产生跨域

     

     解决方案:web.xml

    1. <!-- 解决cors跨域问题过滤器 -->
    2. <filter>
    3. <filter-name>corsFilter</filter-name>
    4. <filter-class>com.zking.vue.util.CorsFilter</filter-class>
    5. </filter>
    6. <filter-mapping>
    7. <filter-name>corsFilter</filter-name>
    8. <url-pattern>/*</url-pattern>
    9. </filter-mapping>

    CorsFilter

     


    五、工具类的作用(post和get的区别)

     main.js

    // The Vue build version to load with the `import` command
    // (runtime-only or standalone) has been set in webpack.base.conf with an alias.
    import Vue from 'vue'
    import ElementUI from 'element-ui' // 新添加 1
    import 'element-ui/lib/theme-chalk/index.css' // 新添加 2 ,避免后期打包样式不同,要放在import App from './App'; 之前
    import App from './App'
    import router from './router'
    // import axios from '@/api/http'  //#vue项目对axios的全局配置
    import axios from 'axios'
    import VueAxios from 'vue-axios'


    Vue.use(VueAxios,axios)
    Vue.use(ElementUI)   // 新添加 3
    Vue.config.productionTip = false

    /* eslint-disable no-new */
    new Vue({
      el: '#app',
      router,//挂载边界
      components: { App },
      template: ''
    })
     

     login.vue


     

     效果图


     

     

  • 相关阅读:
    利用向导创建MFC
    内网渗透之内网信息收集(五)
    YOLOv8改进 | SPPF | 双通道特征处理的池化结构——SPPFCSPC【全网独家】
    Vue——多页面不共用token进行拦截
    Excel 数据透视表教程大全之 06 数据透视表八大优势,辅助列用途
    数据结构与算法-队列
    uni-app 使用uni.getLocation获取经纬度配合腾讯地图api获取当前地址
    Linux 访问系统日志文件
    云服务器部署LNMP Web环境教程合集(多版linux系统安装方法)
    vue3+ts 登陆页面,前端实现滑块验证
  • 原文地址:https://blog.csdn.net/qq_66924116/article/details/126788223