欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Vue+Vuex实现自动登录的知识点详解

程序员文章站 2022-05-27 18:49:32
在之前实现的版本中,如果你进行测试,可以看到在浏览器的local storage中,确实里面有了我们加入的authorization,而且如果没有登录的话,直接访问主页会进入登录页面。但其实有好几个问...

在之前实现的版本中,如果你进行测试,可以看到在浏览器的local storage中,确实里面有了我们加入的authorization,而且如果没有登录的话,直接访问主页会进入登录页面。但其实有好几个问题并没有解决:

一、我们所加的authorzation其实并不是从服务器传过来的,而是自己的测试:只要服务器传过来了200的响应状态码,我们就自己加上固定的authorization

二、我们重新进入的时候,判断条件是只要有authorization就可以直接进入了,但其实应该提交给服务器判断这个authorization是否在数据库中,才可以。

基于以上两点,我们对代码进行修改:

首先就是,我们获取的token应该是从服务器获取的,而不是自己给定,因此直接在服务器上接收到信息后修改:

@requestmapping(value = "/login",method = requestmethod.post)
  public respbean login(
      @requestbody userlogin userlogin,
      model model
  ){
    if (userservice.check(userlogin)){
      string token = uuid.randomuuid().tostring();
//      system.out.println(token);
      userservice.autolog(userlogin,token);
      return new respbean("success","登录成功",token);

    }else{
      return new respbean("fail","登录失败");
    }
  }

这里使用uuid直接生成随机的token,为了用respbean传递回去数据,因此传递回去的对象除了状态信息和消息之外,还需要多加一个token:

respbean对象代码为:

  public class respbean {
  private string status;
  private string msg;
  private string token = null;
}

各种方法自己加上就好了。

如果仔细的话,会发现我们传进来的参数好像跟上一次的不一样了,上一次传递了两个用@requestparam修饰的账号密码的string类型的对象,而这一次直接传递了一个userlogin的对象,这是因为我觉得如果要接收表单等信息的话,每一个都使用这样的一个个参数会显得接收参数很多,而且如果要修改接收的数值的话,可能需要很多地方都要修改,复用性太差了。

第二个原因是我们的controller层应该只是最大限度的逻辑表示,而具体怎么添加用户、怎么鉴别用户是否登录等信息,完完全全应该交给下层的service层呀mapper层呀去做,但如果接收的是这样的password、username等数值的话,调用下一层的时候,我们还需要把这些数值直接放入,否则就要在controller层对数据进行操作,这就破坏层次结构了。

所以,为了解决这个问题,我们可以把所有表单中需要用到的数据单独封装成一个对象,这个对象就专门用来接收web的数据以及在各个层之间流转:

java @data public class userlogin { private string username; private string password; }把,
这里的@data注解就是lombok的注解,可以让我们不用再去创建get、set等方法了。这样创建完对象以后,我们的登录操作就可以直接将这样的对象拿来使用了。

但是,如果你是跟着做下来的,就会遇到跟我一样的问题:登录的时候会报错:

resolved [org.springframework.http.converter.httpmessagenotreadableexception: json parse error: unrecognized token 'username': was expecting (json string, number, array, object or token 'null', 'true' or 'false'); nested exception is com.fasterxml.jackson.core.jsonparseexception: unrecognized token 'username': was expecting (json string, number, array, object or token 'null', 'true' or 'false')

大概的意思就是说,我们接受的跟发出的不大一样,对应不上,而这样的原因是:我们当时为了使用get和@requestparam方法,在api.js中,把获取到的json数据格式,变成了json字符串的格式了,所以就不能使用@requestbody这样一个接收json对象的方法来接收了。

因此上一个程序中的api.js改为:

export const postrequest = (url, params) => {
 return axios({
  method: 'post',
  url: `${base}${url}`,
  data: params,

  // transformrequest: [function (data) {
  //  // do whatever you want to transform the data
  //  let ret = ''
  //  for (let it in data) {
  //   ret += encodeuricomponent(it) + '=' + encodeuricomponent(data[it]) + '&'
  //  }
  //  return ret
  // }],
  headers: {
   'content-type': 'application/json;charset=utf-8'
  }
 });
}

详细的可以看一下这个文章@requestbody和@requestparam的区别

而第二点,关于如何实现鉴别token,就是在路由之前的那个方法上,加上传递给服务器以及接收相应信息进行操作:

router.beforeeach((to,from,next)=>{
 if(to.path ==='/login'){
  next();
 }else {
  let token = localstorage.getitem('authorization');

  if(token ===null || token ===''){
   next('/login');
  }else {
   getrequest('/autolog',{
     token:token
   }).then(resp=>{
    if(resp.status == 200){
      var json = resp.data;
      if(json.status=='success'){
       next();
      }else{
       // next('/login');
      }
    }else{
     alert('请求失败', '失败!');
    }
   })
  }
 }
});

服务器的处理也就很简单了,跟上面登录其实是差不多的,就不再列举出来了

以上就是vue+vuex实现自动登录的知识点详解的详细内容,更多关于vue+vuex实现自动登录的资料请关注其它相关文章!