1:这个例子用spirngboot整合mybatis,jdbc等技术开发的

2:步骤

2.1:新建一个工程

主要的两个步骤已经贴图了,第二张图是直接在pom.xml文件中加入依赖

2.2:新建完项目,就创建一个数据表

  1.  
    CREATE TABLE `tuser` (
  2.  
    `id` int(11) NOT NULL AUTO_INCREMENT,
  3.  
    `loginname` varchar(20) DEFAULT NULL,
  4.  
    `password` varchar(20) DEFAULT NULL,
  5.  
    PRIMARY KEY (`id`)
  6.  
    ) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8

创建一个名为tuser的数据表

2.3:把项目所需的包和文件夹补充完整

2.4整合jdbc,在application.yml中加入jdbc的支持

spring:
datasource:
url: jdbc:mysql://127.0.0.1:3306/springboot?useUnicode=true&characterEncoding=utf-8
driver-class-name: com.mysql.jdbc.Driver
username: root
password: 123456

2.5整合springmvc的前端控制器,在application.yml中加入

spring:
mvc:
view:
prefix: /WEB-INF/jsp/
suffix: .jsp

2.6整合mybatis,添加mapper.xml的目录

mybatis:
mapper-locations: classpath:mapper/*.xml

2.7整个yml文件如下

spring:
datasource:
url: jdbc:mysql://127.0.0.1:3306/springboot?useUnicode=true&characterEncoding=utf-8
driver-class-name: com.mysql.jdbc.Driver
username: root
password: 123456
mvc:
view:
prefix: /WEB-INF/jsp/
suffix: .jsp
mybatis:
mapper-locations: classpath:mapper/*.xml

2.8实体类的编写,也就是model

和数据表对应的User类

  1.  
    public class User {
  2.  
     
  3.  
    private int id;
  4.  
    private String loginname;
  5.  
    private String password;
 //省略构造方法和get/set方法
}

返回数据给页面的封装类ResultEntity

  1.  
    public class ResultEntity {
  2.  
     
  3.  
    private int code;
  4.  
    private String message;
  5.  
    //省略构造方法和get/set方法
  6.  
     
  7.  
    }

2.9 控制层的编写,controller

  1.  
    @Controller
  2.  
    @SessionAttributes("user")
  3.  
    public class LoginController {
  4.  
     
  5.  
    @Autowired
  6.  
    private LoginService loginService;
  7.  
     
  8.  
    @RequestMapping("/index")
  9.  
    public String index() {
  10.  
    return "login";
  11.  
    }
  12.  
     
  13.  
    @RequestMapping("/success")
  14.  
    public String success() {
  15.  
    return "success";
  16.  
    }
  17.  
     
  18.  
    @RequestMapping("/login")
  19.  
    @ResponseBody
  20.  
    public ResultEntity login(User user, Model model) {
  21.  
    ResultEntity resultEntity = loginService.login(user);
  22.  
    if (resultEntity.getCode() == 200)
  23.  
    model.addAttribute("user", user);//将user存放到session
  24.  
    return resultEntity;
  25.  
    }
  26.  
     
  27.  
    }

2.10Service实现层的编写

  1.  
    @Service
  2.  
    class LoginServiceImpl implements LoginService {
  3.  
     
  4.  
    @Autowired
  5.  
    private UserMapper userMapper;
  6.  
     
  7.  
    private ResultEntity resultEntity;
  8.  
     
  9.  
    @Override
  10.  
    public ResultEntity login(User user) {
  11.  
    User login = userMapper.login(user);
  12.  
    if (login != null) {
  13.  
    resultEntity = new ResultEntity(200, "登陆成功");
  14.  
    } else {
  15.  
    resultEntity = new ResultEntity(201, "用户名或密码错误");
  16.  
    }
  17.  
    return resultEntity;
  18.  
    }
  19.  
    }

接口层就忽略啦  我懒。。就一个 ResultEntity login(User user);

2.11 mapper.xml

  1.  
    <?xml version="1.0" encoding="UTF-8"?>
  2.  
    <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
  3.  
    <mapper namespace="net.stxy.boot.dome.mapper.UserMapper">
  4.  
     
  5.  
    <select id="login" parameterType="net.stxy.boot.dome.model.User" resultType="net.stxy.boot.dome.model.User">
  6.  
    select * from tuser where loginname = #{loginname} and password = #{password}
  7.  
    </select>
  8.  
     
  9.  
    </mapper>

mapper接口也不写了。。。QAQ..

2.12 到页面了,采用jsp开发,所以要在pom.xml中添加对jsp的支持

  1.  
    <!--springboot tomcat jsp 支持开启-->
  2.  
    <dependency>
  3.  
    <groupId>org.apache.tomcat.embed</groupId>
  4.  
    <artifactId>tomcat-embed-jasper</artifactId>
  5.  
    </dependency>
  6.  
    <dependency>
  7.  
    <groupId>javax.servlet</groupId>
  8.  
    <artifactId>jstl</artifactId>
  9.  
    <scope>compile</scope>
  10.  
    </dependency>

因为在yml中指定了前端控制器,所以直接在WEB-INF的jsp下读取jsp页面,静态资源文件就可以在路径前面添加,例如jquery文件放在static/js/jquery.min.js,读取直接读js/jquery.min.js即可,因为默认静态资源路径为/static/

2.13 登陆页面用ajax提交表单,判断返回的code是否==200,等于200则跳转登陆成功页面,否则,提示失败.

ajax代码:

  1.  
    //提交表单
  2.  
    $.ajax({
  3.  
    url: "/login",
  4.  
    type: "post",
  5.  
    dataType: "json",
  6.  
    data: {
  7.  
    loginname: account,
  8.  
    password: password
  9.  
    },
  10.  
    success: function (result) {
  11.  
    console.log(result);
  12.  
    if (result.code == 200) {
  13.  
    window.location.href = "success";
  14.  
    } else {
  15.  
    alert(result.message);
  16.  
    }
  17.  
    }
  18.  
    })

3.效果

3.1地址栏输入 localhost:8080/index,出现登陆页面

3.2登陆失败

3.3登陆成功

这是一个非常简单的springboot登陆例子,新手一枚,勿喷i....QAQ...

[源码下载]

SpringBoot的简单登陆开发例子的更多相关文章

  1. 使用Multiplayer Networking做一个简单的多人游戏例子-1/3(Unity3D开发之二十五)

    猴子原创,欢迎转载.转载请注明: 转载自Cocos2Der-CSDN,谢谢! 原文地址: http://blog.csdn.net/cocos2der/article/details/51006463 ...

  2. 使用Multiplayer Networking做一个简单的多人游戏例子-3/3(Unity3D开发之二十七)

    使用Multiplayer Networking做一个简单的多人游戏例子-1/3 使用Multiplayer Networking做一个简单的多人游戏例子-2/3 使用Multiplayer Netw ...

  3. 使用Multiplayer Networking做一个简单的多人游戏例子-2/3(Unity3D开发之二十六)

    猴子原创,欢迎转载.转载请注明: 转载自Cocos2Der-CSDN,谢谢! 原文地址: http://blog.csdn.net/cocos2der/article/details/51007512 ...

  4. 基于SpringBoot+AntDesign的快速开发平台,JeecgBoot 2.0.2 版本发布

    Jeecg-Boot 是一款基于SpringBoot+代码生成器的快速开发平台! 采用前后端分离架构:SpringBoot,Ant-Design-Vue,Mybatis,Shiro,JWT. 强大的代 ...

  5. 在线Online表单来了!JeecgBoot 2.1 版本发布——基于SpringBoot+AntDesign的快速开发平台

    项目介绍 Jeecg-Boot 是一款基于SpringBoot+代码生成器的快速开发平台! 采用前后端分离架构:SpringBoot,Ant-Design-Vue,Mybatis,Shiro,JWT. ...

  6. springboot核心技术(三)-----web开发

    web开发 1.简介 使用SpringBoot: 1).创建SpringBoot应用,选中我们需要的模块: 2).SpringBoot已经默认将这些场景配置好了,只需要在配置文件中指定少量配置就可以运 ...

  7. 菜鸟学习Hibernate——简单的一个例子

    一.Hibernate开发. 上篇博客已经为大家介绍了持久层框架的发展流程,持久层框架的种类. 为了能够使用Hibernate快速上手,我们先讲解一个简单的Hibernate应用实例hibernate ...

  8. 用SpringBoot搭建简单电商项目 01

    前几节呢,我们已经简单介绍了SpringBoot框架的使用,从这一节开始,我们尝试着使用SpringBoot框架来一步一步搭建一个简单电商项目.当然了,这不是真正的电商项目,你可以看成是一个CRUD案 ...

  9. springboot 实战之一站式开发体验

    都说springboot是新形势的主流框架工具,然而我的工作中并没有真正用到springboot: 都说springboot里面并没有什么新技术,不过是组合了现有的组件而已,但是自己却说不出来: 都说 ...

随机推荐

  1. wx-charts 微信小程序图表 -- radarChart C# .net .ashx 测试

    radarChart:原始代码 new wxCharts({ canvasId: 'radarCanvas', type: 'radar', categories: ['1', '2', '3', ' ...

  2. AWS专线服务总结和疑问

    1.AWS专线服务的入口, 从介绍页上可以看到,有如下功能: (1)专线可以连接AWS云主机和传统的数据中心或者分支机构. (2)专线可以连接AWS云主机和托管区的主机. 连接要素: (1)需要使用V ...

  3. Elasticsearch Elasticsearch入门指导

    Elasticsearch入门指导 By:授客 QQ:1033553122 1. 开启elasticsearch服务器 1 2. 基本概念 2 <1> 集群(Cluster) 2 < ...

  4. Physical Plausible Shading

    问所有人一个简单的问题,为什么我们做片子,CG生产的效果,就是不如论文中样图结果.难道是论文中用了某些神奇的黑科技?或者是依赖PS伪造的图?你当然不可能怀疑Cornell.Stanford这些一流机构 ...

  5. js获取选中日期的当周的周一和周日

    js获取选中日期的当周的周一和周日 第一种方法(推荐): function getWeekStr(str) { // 将字符串转为标准时间格式 str2 = Date.parse(str); let ...

  6. 【Spring源码解读】bean标签中的属性(一)你可能还不够了解的 scope 属性

    scope 属性说明 在spring中,在xml中定义bean时,scope属性是用来声明bean的作用域的.对于这个属性,你也许已经很熟悉了,singleton和prototype信手捏来,甚至还能 ...

  7. Django 配置MySQL数据库

    在settings.py中配置 DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', # 数据库引擎 'NAME': 'my ...

  8. Spring Data Redis 让 NoSQL 快如闪电 (1)

    [编者按]本文作者为 Xinyu Liu,详细介绍了 Redis 的特性,并辅之以丰富的用例.在本文的第一部分,将重点概述 Redis 的方方面面.文章系国内 ITOM 管理平台 OneAPM 编译呈 ...

  9. 对display主要属性的探究,以及vertical-aligin

    display 首先要简单说明一下display的主要3个主要属性,分别为block,inline-block,inline,这里只提及主要,关于其他的inherit,none等可以自行了解 inli ...

  10. LeetCode题解之Find Bottom Left Tree Value

    1.题目描述 2.问题分析 使用层序遍历思想 3.代码 int findBottomLeftValue(TreeNode* root) { if (root == NULL) ; queue<T ...