首页 > 其他分享 >test1

test1

时间:2023-06-18 13:22:10浏览次数:42  
标签:test1 username code axios import password public

技术栈选用

1.前端技术栈 1.Vue.js 2.ElementUI 3.axios

2.后端技术栈 1.Spring Boot 2.Apache Shiro 3.Apache Log4j2 4.Spring Data JPA 5.Spring Data Redis

3.数据库 1.MySQL 2.Redis

登录页面开发

注意我们的项目是前后端分离的

前后端分离的意思是前后端之间通过 RESTful API 传递 JSON 数据进行交流。不同于 JSP 之类,后端是不涉及页面本身的内容的。

在开发的时候,前端用前端的服务器(Nginx),后端用后端的服务器(Tomcat),当我开发前端内容的时候,可以把前端的请求通过前端服务器转发给后端(称为反向代理),这样就能实时观察结果,并且不需要知道后端怎么实现,而只需要知道接口提供的功能,两边的开发人员(两个我)就可以各司其职。

正向代理就是,你要访问一个网站,比如“谷歌”,然后发现访问不到,于是你访问了一个能访问到“谷歌”的代理服务器,让它帮你拿到你想浏览的页面。

反向代理就是,你访问了一个网站,你以为它是“谷歌”,但其实它是“百度”,“百度”知道你其实是想找谷歌,就取回“谷歌”的内容给你看。作为用户的你,是不知道有这个过程的,这么做是为了保护服务器,不暴露服务器的真实地址。

Login.vue 首先我们开发登录页面组件,右键 src\components 文件夹,New -> Vue Component,命名为 Login,如果没有 Vue Component 这个选项,可以选择新建一个 File,命名为 Login.vue 即可。代码如下:

  <template>
 <div>
    用户名:<input type="text" v-model="loginForm.username" placeholder="请输入用户名"/>
     <br><br>
    密码: <input type="password" v-model="loginForm.password" placeholder="请输入密码"/>
     <br><br>
     <button v-on:click="login">登录</button>
 </div>
</template>
<script>
 export default {
   name: 'Login',
   data () {
     return {
       loginForm: {
         username: '',
         password: ''
      },
       responseResult: []
    }
  },
   methods: {
     login () {
       this.$axios
        .post('/login', {
           username: this.loginForm.username,
           password: this.loginForm.password
        })
        .then(successResponse => {
           if (successResponse.data.code === 200) {
             this.$router.replace({path: '/index'})
          }
        })
        .catch(failResponse => {
        })
    }
  }
}
</script>
<template> 标签中随便写了一个登录的界面, methods 中定义了登录按钮的点击方法,即向后端 /login 接口发送数据,获得成功的响应后,页面跳转到 /index。因为之前我们设置了默认的 URL,所以请求实际上发到了 http://localhost:8443/api/login。

前端相关配置

设置反向代理

修改 src\main.js 代码如下:

import Vue from 'vue' import App from './App' import router from './router' // 设置反向代理,前端请求默认发送到 http://localhost:8443/api var axios = require('axios') axios.defaults.baseURL = 'http://localhost:8443/api' // 全局注册,之后可在其他组件中通过 this.$axios 发送数据 Vue.prototype.$axios = axios Vue.config.productionTip = false

/* eslint-disable no-new */ new Vue({ el: '#app', router, components: { App }, template: '<App/>' }) 因为使用了新的模块 axios,所以需要进入到项目文件夹中,执行 npm install --save axios,以安装这个模块。

配置页面路由

修改 src\router\index.js 代码如下

import Vue from 'vue' import Router from 'vue-router' // 导入刚才编写的组件 import AppIndex from '@/components/home/AppIndex' import Login from '@/components/Login'

Vue.use(Router)

export default new Router({ routes: [ // 下面都是固定的写法 { path: '/login', name: 'Login', component: Login }, { path: '/index', name: 'AppIndex', component: AppIndex } ] })

跨域支持

为了让后端能够访问到前端的资源,需要配置跨域支持。

在 config\index.js 中,找到 proxyTable 位置,修改为以下内容

proxyTable: {
'/api': {
  target: 'http://localhost:8443',
  changeOrigin: true,
  pathRewrite: {
    '^/api': ''
  }
}
}

后端开发

User 类 在 Login.vue 中,前端发送数据的代码段为

.post('/login', { username: this.loginForm.username, password: this.loginForm.password }) 后端如何接收这个 JS 对象呢?我们很自然地想到在需要创建一个形式上一致的 Java 类。

打开我们的后端项目 wj,首先在 src\main\java\com\evan\wj 文件夹(就是你自己的 web 项目的包)下,新建一个 pojo 包(package),然后新建 User类,代码如下

package com.evan.wj.pojo;

public class User {
   int id;
   String username;
   String password;
public int getId() {
   return id;
}

public void setId(int id) {
   this.id = id;
}

public String getUsername() {
   return username;
}

public void setUsername(String username) {
   this.username = username;
}

public String getPassword() {
   return password;
}

public void setPassword(String password) {
   this.password = password;
}
}    

Result 类 Result 类是为了构造 response,主要是响应码。新建 result 包,创建 Result 类,代码如下

package com.evan.wj.result;
public class Result {
   //响应码
   private int code;
public Result(int code) {
   this.code = code;
}

public int getCode() {
   return code;
}

public void setCode(int code) {
   this.code = code;
}
}

实际上由于响应码是固定的,code 属性应该是一个枚举值,这里作了一些简化。

LoginController Controller 是对响应进行处理的部分。这里我们设定账号是 admin,密码是 123456,分别与接收到的 User 类的 username 和 password 进行比较,根据结果返回不同的 Result,即不同的响应码。前端如果接收到成功的响应码(200),则跳转到 /index 页面。

在 wj 下新建 controller 包,新建 LoginController 类,代码如下

 

package com.evan.wj.controller;

import com.evan.wj.result.Result;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.*;
import org.springframework.web.util.HtmlUtils;

import com.evan.wj.pojo.User;

import java.util.Objects;

@Controller
public class LoginController {
@CrossOrigin
@PostMapping(value = "api/login")
@ResponseBody
public Result login(@RequestBody User requestUser) {
// 对 html 标签进行转义,防止 XSS 攻击
  String username = requestUser.getUsername();
  username = HtmlUtils.htmlEscape(username);

  if (!Objects.equals("admin", username) || !Objects.equals("123456", requestUser.getPassword())) {
      String message = "账号密码错误";
      System.out.println("test");
      return new Result(400);
  } else {
      return new Result(200);
  }
}
}

这里只是为了演示前后端的交互过程,真正的登录验证要考虑更多因素。另外对项目结构做了一些简化,实际上在 controller 里写这么多逻辑是不合理的,要封装到 service 里面去。

最后,在 src\main\resources 文件夹下找到 application.properties 文件配置端口,即加上 server.port=8443(初始应该是空白的,后期还要配置数据库等)

标签:test1,username,code,axios,import,password,public
From: https://www.cnblogs.com/jiangrui-/p/17489014.html

相关文章

  • test1
    Markdown示例文件这是一个加粗的文本。这是一个斜体的文本。这是一个~~删除线~~的文本。标题H1标题H2标题H3标题H4标题H5标题H6这是一个引用。这是一个内联代码文本。print("这是一个代码块")列表项1列表项2列表项3有序列表项1有序列表项2有......
  • py + python test1 score
    sC:\Lindows\lab\pytest\venv\Scripts\python.exeC:/Lindows/lab/pytest/hello.py-score=[80,70,90]#定义变量scoremin_grade=None#定义变量min_g......
  • spring boot——请求与参数校验——response重定向——response.sendRedirect("/test1
               代码:packageorg.example.controller;importorg.springframework.web.bind.annotation.RequestMapping;importorg.springframe......
  • Airtest10053您的主机中的软件中止了一个已建立的连接,10054远程主机强迫关闭了一个现
    小站注:以下两个错误出现的频率相当高,官方本篇推文讲的很清楚了。 初始化顺序错误时会出现: ConnectionAbortedError: [WinError10053] 您的主机中的软件中止了一个......
  • test11
    <!DOCTYPEhtml><htmllang="zh"><head><metacharset="UTF-8"/><metahttp-equiv="X-UA-Compatible"content="IE=edge"/><metaname="viewport"co......
  • test1
    安装hexo安装hexo之前需要安装Nodejs组件,这个在我的另一篇文章:Hexo是我们博客的框架,我们需要在我们的电脑里创建一个文件夹,可以命名为Blog,Hexo框架与你发布的博客网页以......
  • git checkout命令详解 git checkout feature/test123
    gitcheckout命令详解gitcheckoutfeature/test123//切换到feature/test123分支保证当前分支没有修改提交,否则回提示error:Yourlocalchangestothefollowing......
  • 趁热打铁!一起来看下Airtest1.2.7新增的那些断言API
    1.前言先前我们放出了1.2.7版本的Airtest,其中,一个很重要的功能是,我们新增了非常丰富的断言API,今天我们就来详细看一下新版Airtest都有给我们提供哪些断言语句。2.旧......
  • test1
    任务一#include<stdio.h>intmain(){ printf("O\n"); printf("<H>\n"); printf("II\n"); printf("O\n"); printf("<H>\n"); printf("II\n"); return0;}  ......
  • MicroSoft interview 2022 test1
    MicroSoftinterview2022test1Programingone点击查看代码defsolution(S,B):#writeyourcodeinPython(Python3.6)fixed=0holes=[]l......