• SPA项目开发之登录注册


    目录

    一、前置工作

    二、用户登录界面排版

    三、vue之数据交互登录功能

    四、this指针污染

    五、ajax跨域问题

    六、工具累的作用&post/get区别


    一、前置工作

    ①、导入项目&修改db.properties

    1. db.username=root
    2. db.password=1234
    3. db.driverClass=com.mysql.jdbc.Driver
    4. db.jdbcUrl=jdbc:mysql://127.0.0.1:3306/mysql?useUnicode=true&characterEncoding=utf8&serverTimezone=GMT
    5. db.initialPoolSize=10
    6. db.maxPoolSize=20
    7. db.minPoolSize=5
    8. db.maxIdleTime=60
    9. db.acquireIncrement=5
    10. db.maxStatements=0
    11. db.idleConnectionTestPeriod=60
    12. db.acquireRetryAttempts=30
    13. db.breakAfterAcquireFailure=true
    14. db.testConnectionOnCheckout=false

    注意:一定要勾选xml文件

    ②、运行项目,检查是否导入完成

    效果:

     ③、前端导入api文件夹

     运行效果:

     ④、在spa1项目的根目录中打开cmd

    运行以下命令:

    npm install element-ui -S
    npm install axios -S
    npm install qs -S
    npm install vue-axios -S

    下载完成后package.json会多出以下依赖

    二、用户登录界面排版

    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. Vue.use(ElementUI); // 新添加 3
    9. Vue.config.productionTip = false
    10. /* eslint-disable no-new */
    11. new Vue({
    12. el: '#app',
    13. router,
    14. components: { App },
    15. template: ''
    16. })

    index.js:

    1. import Vue from 'vue'
    2. import Router from 'vue-router'
    3. import HelloWorld from '@/components/HelloWorld'
    4. import Login from '@/views/Login'
    5. Vue.use(Router)
    6. export default new Router({
    7. routes: [
    8. {
    9. path: '/Login',
    10. name: 'Login',
    11. component: Login
    12. },
    13. {
    14. path: '/Login',
    15. name: 'Login',
    16. component: Login
    17. }
    18. ]
    19. })

    App.vue

    1. <template>
    2. <div id="app">
    3. <router-view/>
    4. div>
    5. template>
    6. <script>
    7. export default {
    8. name: 'App'
    9. }
    10. script>
    11. <style>
    12. #app {
    13. font-family: 'Avenir', Helvetica, Arial, sans-serif;
    14. -webkit-font-smoothing: antialiased;
    15. -moz-osx-font-smoothing: grayscale;
    16. text-align: center;
    17. color: #2c3e50;
    18. margin-top: 60px;
    19. }
    20. style>

    login.vue

    1. <template>
    2. <div class="login-wrap">
    3. <el-form :model="ruleForm" ref="ruleForm" 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. <el-form-item>
    27. <el-row>
    28. <el-col :span="12">
    29. <div style="text-align: center;" class="grid-content bg-purple-dark">
    30. <el-link type="success" @click="">用户注册el-link>
    31. div>
    32. el-col>
    33. <el-col :span="12">
    34. <div style="text-align: center;" class="grid-content bg-purple-dark">
    35. <el-link type="warning" @click="">忘记密码el-link> div>
    36. el-col>
    37. el-row>
    38. el-form-item>
    39. el-form>
    40. div>
    41. template>
    42. <script>
    43. export default {
    44. name: 'Login',
    45. data () {
    46. return {
    47. ruleForm:{}
    48. }
    49. },
    50. methods:{
    51. submitForm(){
    52. },
    53. resetForm(){
    54. }
    55. }
    56. }
    57. script>
    58. <style scoped>
    59. .login-wrap {
    60. box-sizing: border-box;
    61. width: 100%;
    62. height: 100%;
    63. padding-top: 10%;
    64. background-image: url();
    65. /* background-color: #112346; */
    66. background-repeat: no-repeat;
    67. background-position: center right;
    68. background-size: 100%;
    69. }
    70. .login-container {
    71. border-radius: 10px;
    72. margin: 0px auto;
    73. width: 350px;
    74. padding: 30px 35px 15px 35px;
    75. background: #fff;
    76. border: 1px solid #eaeaea;
    77. text-align: left;
    78. box-shadow: 0 0 20px 2px rgba(0, 0, 0, 0.1);
    79. }
    80. .title {
    81. margin: 0px auto 40px auto;
    82. text-align: center;
    83. color: #505458;
    84. }
    85. style>

     HelloWorld.vue

    1. <template>
    2. <div class="hello">
    3. <h1>{{ msg }}h1>
    4. <h2>Essential Linksh2>
    5. <ul>
    6. <li>
    7. <a
    8. href="https://vuejs.org"
    9. target="_blank"
    10. >
    11. Core Docs
    12. a>
    13. li>
    14. <li>
    15. <a
    16. href="https://forum.vuejs.org"
    17. target="_blank"
    18. >
    19. Forum
    20. a>
    21. li>
    22. <li>
    23. <a
    24. href="https://chat.vuejs.org"
    25. target="_blank"
    26. >
    27. Community Chat
    28. a>
    29. li>
    30. <li>
    31. <a
    32. href="https://twitter.com/vuejs"
    33. target="_blank"
    34. >
    35. Twitter
    36. a>
    37. li>
    38. <br>
    39. <li>
    40. <a
    41. href="http://vuejs-templates.github.io/webpack/"
    42. target="_blank"
    43. >
    44. Docs for This Template
    45. a>
    46. li>
    47. ul>
    48. <h2>Ecosystemh2>
    49. <ul>
    50. <li>
    51. <a
    52. href="http://router.vuejs.org/"
    53. target="_blank"
    54. >
    55. vue-router
    56. a>
    57. li>
    58. <li>
    59. <a
    60. href="http://vuex.vuejs.org/"
    61. target="_blank"
    62. >
    63. vuex
    64. a>
    65. li>
    66. <li>
    67. <a
    68. href="http://vue-loader.vuejs.org/"
    69. target="_blank"
    70. >
    71. vue-loader
    72. a>
    73. li>
    74. <li>
    75. <a
    76. href="https://github.com/vuejs/awesome-vue"
    77. target="_blank"
    78. >
    79. awesome-vue
    80. a>
    81. li>
    82. ul>
    83. div>
    84. template>
    85. <script>
    86. export default {
    87. name: 'HelloWorld',
    88. data () {
    89. return {
    90. msg: 'Welcome to Your Vue.js App'
    91. }
    92. }
    93. }
    94. script>
    95. <style scoped>
    96. h1, h2 {
    97. font-weight: normal;
    98. }
    99. ul {
    100. list-style-type: none;
    101. padding: 0;
    102. }
    103. li {
    104. display: inline-block;
    105. margin: 0 10px;
    106. }
    107. a {
    108. color: #42b983;
    109. }
    110. style>

    效果:

    三、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(ElementUI); // 新添加 3
    11. Vue.use(VueAxios,axios);
    12. Vue.config.productionTip = false
    13. /* eslint-disable no-new */
    14. new Vue({
    15. el: '#app',
    16. router,
    17. components: { App },
    18. template: ''
    19. })

     index.js

    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: '/Login',
    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. })

     Login.vue

    1. <template>
    2. <div class="login-wrap">
    3. <el-form :model="ruleForm" ref="ruleForm" 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. <el-form-item>
    27. <el-row>
    28. <el-col :span="12">
    29. <div style="text-align: center;" class="grid-content bg-purple-dark">
    30. <el-link type="success" @click="toReg()">用户注册el-link>
    31. div>
    32. el-col>
    33. <el-col :span="12">
    34. <div style="text-align: center;" class="grid-content bg-purple-dark">
    35. <el-link type="warning" @click="">忘记密码el-link> div>
    36. el-col>
    37. el-row>
    38. el-form-item>
    39. el-form>
    40. div>
    41. template>
    42. <script>
    43. export default {
    44. name: 'Login',
    45. data () {
    46. return {
    47. ruleForm:{}
    48. }
    49. },
    50. methods:{
    51. submitForm(){
    52. // this.axios找到的是/api/http.js文件
    53. //axios.urls = action --> this.axios.urls找到了 /api/action.js文件
    54. // action.js是一个json对象,那么就可以取到请求的值
    55. let url = this.axios.urls.SYSTEM_USER_DOLOGIN;
    56. // alert(url);
    57. // {uname:'zs',pwd:'123'}
    58. this.axios.post(url,this.ruleForm).then(function(resp){//代表成功
    59. console.log(resp);
    60. }).catch(function(){//代表失败
    61. });
    62. },
    63. resetForm(){
    64. },
    65. toReg(){
    66. this.$router.push({path:'/Reg'})
    67. }
    68. }
    69. }
    70. script>
    71. <style scoped>
    72. .login-wrap {
    73. box-sizing: border-box;
    74. width: 100%;
    75. height: 100%;
    76. padding-top: 10%;
    77. background-image: url();
    78. /* background-color: #112346; */
    79. background-repeat: no-repeat;
    80. background-position: center right;
    81. background-size: 100%;
    82. }
    83. .login-container {
    84. border-radius: 10px;
    85. margin: 0px auto;
    86. width: 350px;
    87. padding: 30px 35px 15px 35px;
    88. background: #fff;
    89. border: 1px solid #eaeaea;
    90. text-align: left;
    91. box-shadow: 0 0 20px 2px rgba(0, 0, 0, 0.1);
    92. }
    93. .title {
    94. margin: 0px auto 40px auto;
    95. text-align: center;
    96. color: #505458;
    97. }
    98. style>

     Reg.vue

    1. <template>
    2. <div class="login-wrap">
    3. <el-form :model="ruleForm" ref="ruleForm" 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. <el-form-item>
    27. <el-row>
    28. <el-col :span="12">
    29. <div style="text-align: center;" class="grid-content bg-purple-dark">
    30. <el-link type="success" @click="toLogin">用户登录el-link>
    31. div>
    32. el-col>
    33. <el-col :span="12">
    34. <div style="text-align: center;" class="grid-content bg-purple-dark">
    35. <el-link type="warning" @click="">忘记密码el-link> div>
    36. el-col>
    37. el-row>
    38. el-form-item>
    39. el-form>
    40. div>
    41. template>
    42. <script>
    43. export default {
    44. name: 'Reg',
    45. data () {
    46. return {
    47. ruleForm:{}
    48. }
    49. },
    50. methods:{
    51. submitForm(){
    52. },
    53. resetForm(){
    54. },
    55. toLogin(){
    56. this.$router.push({path:'/Login'})
    57. }
    58. }
    59. }
    60. script>
    61. <style scoped>
    62. .login-wrap {
    63. box-sizing: border-box;
    64. width: 100%;
    65. height: 100%;
    66. padding-top: 10%;
    67. background-image: url();
    68. /* background-color: #112346; */
    69. background-repeat: no-repeat;
    70. background-position: center right;
    71. background-size: 100%;
    72. }
    73. .login-container {
    74. border-radius: 10px;
    75. margin: 0px auto;
    76. width: 350px;
    77. padding: 30px 35px 15px 35px;
    78. background: #fff;
    79. border: 1px solid #eaeaea;
    80. text-align: left;
    81. box-shadow: 0 0 20px 2px rgba(0, 0, 0, 0.1);
    82. }
    83. .title {
    84. margin: 0px auto 40px auto;
    85. text-align: center;
    86. color: #505458;
    87. }
    88. style>

     效果:

    四、this指针污染

    Login.vue中的submitForm方法其中一部分代码改成以下代码

    1. this.axios.post(url, qs.stringify(this.ruleForm)).then((resp) => {
    2. console.log(resp);
    3. if (resp.data.code == 1) {
    4. this.$message({
    5. showClose: true,
    6. message: resp.data.msg,
    7. type: 'success'
    8. });
    9. } else {
    10. this.$message({
    11. showClose: true,
    12. message: resp.data.msg,
    13. type: 'error'
    14. });
    15. }

    五、ajax跨域问题

    引入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 'element-ui/lib/theme-chalk/index.css' // 新添加 2
    5. import App from './App'
    6. import router from './router'
    7. import ElementUI from 'element-ui' // 新添加 1
    8. // import axios from '@/api/http'
    9. import axios from 'axios'
    10. import VueAxios from 'vue-axios'
    11. Vue.use(ElementUI)
    12. Vue.use(VueAxios,axios)
    13. Vue.config.productionTip = false
    14. /* eslint-disable no-new */
    15. new Vue({
    16. el: '#app',
    17. router,
    18. components: { App },
    19. template: ''
    20. })

    显示现象:

    解决方法

    1. package com.zking.vue.util;
    2. import java.io.IOException;
    3. import javax.servlet.Filter;
    4. import javax.servlet.FilterChain;
    5. import javax.servlet.FilterConfig;
    6. import javax.servlet.ServletException;
    7. import javax.servlet.ServletRequest;
    8. import javax.servlet.ServletResponse;
    9. import javax.servlet.http.HttpServletRequest;
    10. import javax.servlet.http.HttpServletResponse;
    11. /**
    12. * 配置tomcat允许跨域访问
    13. *
    14. * @author Administrator
    15. *
    16. */
    17. public class CorsFilter implements Filter {
    18. @Override
    19. public void init(FilterConfig filterConfig) throws ServletException {
    20. }
    21. // @Override
    22. // public void doFilter(ServletRequest servletRequest, ServletResponse
    23. // servletResponse, FilterChain filterChain)
    24. // throws IOException, ServletException {
    25. // HttpServletResponse httpResponse = (HttpServletResponse) servletResponse;
    26. //
    27. // // Access-Control-Allow-Origin就是我们需要设置的域名
    28. // // Access-Control-Allow-Headers跨域允许包含的头。
    29. // // Access-Control-Allow-Methods是允许的请求方式
    30. // httpResponse.addHeader("Access-Control-Allow-Origin", "*");// *,任何域名
    31. // httpResponse.setHeader("Access-Control-Allow-Methods", "POST, GET, PUT,
    32. // DELETE");
    33. // // httpResponse.setHeader("Access-Control-Allow-Headers", "Origin,
    34. // // X-Requested-With, Content-Type, Accept");
    35. //
    36. // // 允许请求头Token
    37. // httpResponse.setHeader("Access-Control-Allow-Headers",
    38. // "Origin,X-Requested-With, Content-Type, Accept, Token");
    39. // HttpServletRequest req = (HttpServletRequest) servletRequest;
    40. // System.out.println("Token=" + req.getHeader("Token"));
    41. // if("OPTIONS".equals(req.getMethod())) {
    42. // return;
    43. // }
    44. //
    45. //
    46. // filterChain.doFilter(servletRequest, servletResponse);
    47. // }
    48. @Override
    49. public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain)
    50. throws IOException, ServletException {
    51. HttpServletResponse resp = (HttpServletResponse) servletResponse;
    52. HttpServletRequest req = (HttpServletRequest) servletRequest;
    53. // Access-Control-Allow-Origin就是我们需要设置的域名
    54. // Access-Control-Allow-Headers跨域允许包含的头。
    55. // Access-Control-Allow-Methods是允许的请求方式
    56. resp.setHeader("Access-Control-Allow-Origin", "*");// *,任何域名
    57. resp.setHeader("Access-Control-Allow-Methods", "POST, GET, PUT, DELETE");
    58. // resp.setHeader("Access-Control-Allow-Headers", "Origin,X-Requested-With,
    59. // Content-Type, Accept");
    60. // 允许客户端,发一个新的请求头jwt
    61. resp.setHeader("Access-Control-Allow-Headers", "Origin,X-Requested-With, Content-Type, Accept, jwt");
    62. // 允许客户端,处理一个新的响应头jwt
    63. resp.setHeader("Access-Control-Expose-Headers", "jwt");
    64. // String sss = resp.getHeader("Access-Control-Expose-Headers");
    65. // System.out.println("sss=" + sss);
    66. // 允许请求头Token
    67. // httpResponse.setHeader("Access-Control-Allow-Headers","Origin,X-Requested-With,
    68. // Content-Type, Accept, Token");
    69. // System.out.println("Token=" + req.getHeader("Token"));
    70. if ("OPTIONS".equals(req.getMethod())) {// axios的ajax会发两次请求,第一次提交方式为:option,直接返回即可
    71. return;
    72. }
    73. filterChain.doFilter(servletRequest, servletResponse);
    74. }
    75. @Override
    76. public void destroy() {
    77. }
    78. }

    六、工具累的作用&post/get区别

    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 'element-ui/lib/theme-chalk/index.css' // 新添加 2
    5. import App from './App'
    6. import router from './router'
    7. import ElementUI from 'element-ui' // 新添加 1
    8. // import axios from '@/api/http'
    9. import axios from 'axios'
    10. import VueAxios from 'vue-axios'
    11. Vue.use(ElementUI)
    12. Vue.use(VueAxios,axios)
    13. Vue.config.productionTip = false
    14. /* eslint-disable no-new */
    15. new Vue({
    16. el: '#app',
    17. router,
    18. components: { App },
    19. template: ''
    20. })

    显示现象:

    解决方法:

    1. let url = 'http://localhost:8080/T216_SSH/vue/userAction_login.action';
    2. this.axios.post(url, qs.stringify(this.ruleForm)).then(function(response) {
    3. console.log(response);
    4. }).catch(function(error) {
    5. console.log(error);
    6. });

  • 相关阅读:
    解决 ARouter 无法生成路由表,Toast提示 找不到目标路由
    科技部首批支持建设十个人工智能示范应用场景,智能家居再获加持
    Stable Diffusion WebUI扩展sd-webui-controlnet之Canny
    docker系列(4) - docker镜像制作
    2439. 最小化数组中的最大值-暴力解法+动态规划法
    新建热门题材跟踪表,捕捉节后主线行情——股票量化分析工具QTYX-V2.7.1
    队列概述以及使用数组模拟实现队列(思路分析) [数据结构][Java]
    MyBatis-Plus找不到Mapper.xml文件的解决方法
    ros2原来本是一个通信协议
    IE浏览器设置兼容性、清除缓存,重置浏览器、Edge浏览器设置兼容性
  • 原文地址:https://blog.csdn.net/m0_62604616/article/details/126801356