Unity&Springboot实现本地登陆验证

 更新时间:2021年07月26日 08:40:25   作者:大可iii  
本文主要介绍了Unity&Springboot服务器/本地登陆验证,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

Springboot使用IDEA编译器

IDEA上实现登录验证

因为这里只能返回网页,但是我们需要返回登陆是否成功的数据所以下面还需要写一个请求方法。
如果登陆失败则将session域中的id删除,这样在unity判断是否登录成功时会直接按请求错误抓取

//登录操作
    @RequestMapping("/login")
    public String login(HttpServletRequest request, @RequestParam("userType") String userType, Map<String, Object> map,HttpSession session) {

        session.setAttribute("id",request.getParameter("id"));
        String id = session.getAttribute("id").toString();
        String password = request.getParameter("password");

        //如果是管理员登录则查询管理员信息表
        if(userType.equals("0")){
            Administrators administrator = administratorsService.login(id, password);
            if(administrator != null){
                System.out.println("登陆成功");
                return "redirect:/ScheduleInfo";
            }else {
                map.put("msg","账号或密码错误");
                //如果登陆失败则将session域中的id删除,这样在unity判断是否登录成功时会直接按请求错误抓取
                session.removeAttribute("id");
                return "login";
            }
        }else {      //如果是普通用户登录则查找普通用户表
            Employees employee = employeesService.login(id, password);
            if(employee != null){
                if (employeesService.findJobById(id).getJob().equals("巡检人员")){
                    System.out.println("登陆成功");
                    return "redirect:/xInfo";
                }else {
                    System.out.println("登陆成功");
                    return "redirect:/wInfo";
                }
            }else {
                map.put("msg","账号或密码错误");
                session.removeAttribute("id");
                return "login";
            }
        }
    }

返回登录是否成功和登陆用户的id信息

这里使用 @ResponseBody注解,使返回的是数据而不是网页

@RequestMapping("/getUserInfo")
    @ResponseBody
    public String getUserInfo(HttpSession session){
        System.out.println("收到unity登录请求");
        //因为登陆失败以后session域中的id会被删除,所以判断为null则登录失败
        if(session.getAttribute("id") != null){
            String id = session.getAttribute("id").toString();
            System.out.println("登陆成功");
            return id ;
        }
        else {
            System.out.println("登陆失败");
            return null;
        }
    }

Unity端的请求

一个简单的登陆注册界面

在这里插入图片描述

在这里插入图片描述

上脚本,看注释

using System.Collections;
using UnityEngine;
using UnityEngine.UI;
using UnityEngine.SceneManagement;
using UnityEngine.Networking;

public class HttpHelper : MonoBehaviour
{
	//发出登录请求
    private string postUrl = "http://47.xx.75.xx:8080/login";//如果是本地运行则将前面的47.96.75.29换成localhost
    //获得登录是否成功的数据,也就是运行上面第二个代码的内瓤
    private string postUrl2 = "http://47.xx.75.xx:8080/getUserInfo";
    public GameObject[] uis;
    public GameObject backLoginObj;
    public Text massage;
    public Text countText;
    public Text passwordText;
    private const string userType = "userType";
    private const string userName = "id";
    private const string password = "password";

    public void loginTest()
    {
    //这个方法和登录按钮绑定,用于触发异步方法Post
        StartCoroutine("Post");
    }

    [System.Obsolete]
    IEnumerator Post()
    {
    //发送登录表单,每个人不一样,根据自己需要的表单参数来,一般就是账号密码,这里的userType就是管理员和员工的分类,0是管理员,1是员工。
        WWWForm form = new WWWForm();
        form.AddField(userType, "0");
        form.AddField(userName, countText.text);
        form.AddField(password, passwordText.text);
		
		//这里发出了登录请求
		//利用UnityWebRequest通过请求路径这个和postman的操作类似,将表单发送出去
        UnityWebRequest request = UnityWebRequest.Post(postUrl, form);
        yield return request.SendWebRequest();
        if (request.isHttpError || request.isNetworkError)
        {
            Debug.LogError(request.error);
        }
		
		//这里获取了登录是否成功的数据
        UnityWebRequest request2 = UnityWebRequest.Get(postUrl2);
        yield return request2.SendWebRequest();
        //如果登陆失败的Session域中的id是空的,所以会报错,也就是判断登陆是否成功的依据。
        if (request2.isHttpError || request2.isNetworkError)
        {
            massage.text = "登陆失败,账号或密码错误";
        }
        else
        {
        //反之如果登录成功则获得返回的数据,这里就是用户的id
            string receiveContent = request2.downloadHandler.text;
		//这是个普通的ui操作,我的构想是如果登录成功则将这些ui隐藏只显示massage和一个返回键
            foreach (GameObject ui in uis)
            {
                ui.SetActive(false);
            }
            massage.gameObject.SetActive(true);
            backLoginObj.SetActive(true);
			
			//如果返回的数据和用户输入时的账号一样时则判断登陆成功
            if (receiveContent == countText.text)
            {
                massage.text = "登陆成功,欢迎管理员" + receiveContent;
            }
            else//反之登陆失败
            {
                massage.text = "登陆失败,账号或密码错误";
            }
        }
        StopCoroutine("Post");
    }
    public void backLogin()
    {
        SceneManager.LoadScene("SampleScene");
    }
}

最后的运行结果

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

到此这篇关于Unity&Springboot服务器/本地登陆验证的文章就介绍到这了,更多相关Unity&Springboot服务器/本地登陆验证内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Spring boot AOP通过XML配置文件声明的方法

    Spring boot AOP通过XML配置文件声明的方法

    这篇文章主要介绍了Spring boot AOP通过XML配置文件声明,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-06-06
  • 关于Java中XML Namespace 命名空间问题

    关于Java中XML Namespace 命名空间问题

    这篇文章主要介绍了Java中XML Namespace 命名空间,XML命名空间是由国际化资源标识符 (IRI) 标识的 XML 元素和属性集合,该集合通常称作 XML“词汇”,对XML Namespace 命名空间相关知识感兴趣的朋友一起看看吧
    2021-08-08
  •  Spring 中 Bean 的生命周期详解

     Spring 中 Bean 的生命周期详解

    这篇文章主要介绍了Spring中Bean的生命周期详解,Java中的公共类称之为Bean或Java Bean,而Spring中的Bean指的是将对象的生命周期
    2022-09-09
  • SpringBoot使用@Async注解可能会遇到的8大坑点汇总

    SpringBoot使用@Async注解可能会遇到的8大坑点汇总

    SpringBoot中,@Async注解可以实现异步线程调用,用法简单,体验舒适,但是你一定碰到过异步调用不生效的情况,今天,我就列出90%的人都可能会遇到的8大坑点,需要的朋友可以参考下
    2023-09-09
  • JAVA三种异常处理机制的具体使用

    JAVA三种异常处理机制的具体使用

    异常是程序在编译或执行的过程中可能出现的问题,本文主要介绍了JAVA三种异常处理机制的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2024-06-06
  • Spring Data JPA实现动态条件与范围查询实例代码

    Spring Data JPA实现动态条件与范围查询实例代码

    本篇文章主要介绍了Spring Data JPA实现动态条件与范围查询实例代码,非常具有实用价值,需要的朋友可以参考下
    2017-06-06
  • 浅析非对称加密在接口参数中的实现

    浅析非对称加密在接口参数中的实现

    接口层做数据加密应该算是老生常谈的一件事了,业界用的比较多的,不外乎是对称加密,非对称加密以及两者的结合。本文就来聊聊非对称加密在接口参数中的实现,希望对大家有所帮助
    2023-02-02
  • 解析分别用递归与循环的方式求斐波那契数列的实现方法

    解析分别用递归与循环的方式求斐波那契数列的实现方法

    本篇文章是对分别用递归与循环的方式求斐波那契数列的方法进行了详细的分析介绍,需要的朋友参考下
    2013-06-06
  • IDEA部署jeesite3完美运行教程详解

    IDEA部署jeesite3完美运行教程详解

    这篇文章主要介绍了IDEA部署jeesite3完美运行教程,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-09-09
  • tio-boot框架整合ehcache实现过程示例

    tio-boot框架整合ehcache实现过程示例

    这篇文章主要为大家介绍了tio-boot框架整合ehcache实现过程示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-12-12

最新评论