JEECG新建用户不用系统用户表的实现
首先新增组织机构 和 角色:
-- 新增 组织机构
INSERT INTO `t_s_depart` VALUES ('dept001', '你所在的机构', '你所在的机构的描述', null, 'A04', '1', '', '', '', null);
-- 新增 角色
INSERT INTO `t_s_role` VALUES ('role001', 'tz_admin', '台账管理员', null, null, null, '管理员', '2017-10-25 11:01:16', 'admin');
INSERT INTO `t_s_role` VALUES ('role002', 'tz_branch', '支行管理员', null, null, null, '管理员', '2017-10-25 11:01:33', 'admin');
INSERT INTO `t_s_role` VALUES ('role003', 'tz_am', '客户经理', null, null, null, '管理员', '2017-10-25 11:01:45', 'admin');
然后在代码中实现:
package com.zifeiy;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;
import org.jeecgframework.core.util.PasswordUtil;
import org.jeecgframework.core.util.oConvertUtils;
/*
* 用于传输额外的信息到 系统用户表中
*/
public class AdditionalAddToDbHelper {
private static String driver = "com.mysql.jdbc.Driver";
private static String url = "jdbc:mysql://localhost:3306/jeecg?useUnicode=true&characterEncoding=UTF-8&zeroDateTimeBehavior=convertToNull";
private static String userName = "root";
private static String password = "password";
// private static Connection conn = null;
// private static Statement stmt = null;
public static boolean addMoreUserInfo(String fullname, String username, String passwd, String rightString) throws ClassNotFoundException, SQLException {
int right = 3;
try {
right = Integer.parseInt(rightString.trim());
} catch (Exception e) {
right = 3;
}
Class.forName(driver);
Connection conn = DriverManager.getConnection(url, userName, password);
System.out.println("connect database successful!begin to add or update");
Statement stmt = conn.createStatement();
String[] roleNameList = new String[]{"台账管理员", "支行管理员", "客户经理"};
String[] roleIdList = new String[]{"role001", "role002", "role003"};
// String[] roleList = new String[]{"tz_admin", "tz_branch", "tz_am"};
String dept = "dept001";
passwd = oConvertUtils.getString(passwd);
String encryptedPasswd = PasswordUtil.encrypt(username, passwd, PasswordUtil.getStaticSalt());
String delete_sql1 = "DELETE FROM `t_s_role_user` WHERE ID='" + username + "'";
String delete_sql2 = "DELETE FROM `t_s_user` WHERE ID='" + username + "'";
String delete_sql3 = "DELETE FROM `t_s_base_user` WHERE ID='" + username + "'";
String delete_sql4 = "DELETE FROM `t_s_user_org` WHERE ID='" + username + "'";
String insert_sql3 = "INSERT INTO `t_s_role_user` VALUES ('" + username + "', '"
+ roleIdList[right-1] + "', '" + username + "');";
String insert_sql2 = "INSERT INTO `t_s_user` VALUES ('" + username
+ "', '', '', '', null, '管理员', '2017-10-25 11:08:52', 'admin', '管理员', '2017-10-25 11:08:20', 'admin', null, null, '1');";
String insert_sql1 = "INSERT INTO `t_s_base_user` VALUES ('" + username
+ "', null, null, '" + encryptedPasswd
+ "', '" + username
+ "', null, '1', '" + roleNameList[right-1] +"', '"
+ username + "', null, '0');";
String insert_sql4 = "INSERT INTO `t_s_user_org` VALUES ('" + username + "', '" + username + "', '" + dept + "');";
String[] sqlList = new String[]{delete_sql1, delete_sql2, delete_sql3, delete_sql4,
insert_sql1, insert_sql2, insert_sql3, insert_sql4};
for (int i = 0; i < 8; i ++) {
String sql = sqlList[i];
System.out.println("sql: " + sql);
stmt.addBatch(sql);
}
stmt.executeBatch();
stmt.close();
if (conn != null)
conn.close();
return false;
}
public static boolean doMoreUserDelete(String username) throws ClassNotFoundException, SQLException {
Class.forName(driver);
Connection conn = DriverManager.getConnection(url, userName, password);
System.out.println("connect database successful!begin to delete");
Statement stmt = conn.createStatement();
String delete_sql1 = "DELETE FROM `t_s_role_user` WHERE ID='" + username + "'";
String delete_sql2 = "DELETE FROM `t_s_user` WHERE ID='" + username + "'";
String delete_sql3 = "DELETE FROM `t_s_base_user` WHERE ID='" + username + "'";
String delete_sql4 = "DELETE FROM `t_s_user_org` WHERE ID='" + username + "'";
String[] sqlList = new String[]{delete_sql1, delete_sql2, delete_sql3, delete_sql4};
for (int i = 0; i < 4; i ++) {
String sql = sqlList[i];
System.out.println("sql: " + sql);
stmt.addBatch(sql);
}
stmt.executeBatch();
stmt.close();
if (conn != null)
conn.close();
return false;
}
public static void main(String[] args) throws ClassNotFoundException, SQLException {
}
}
JEECG新建用户不用系统用户表的实现的更多相关文章
- linux用户权限 -> 系统用户管理
用户基本概述: Linux用户属于多用户操作系统,在windows中,可以创建多个用户,但不允许同一时间多个用户进行系统登陆,但是Linux可以同时支持多个用户同时登陆操作系统,登陆后互相之间并不影响 ...
- 在linux 列出 超级用户 普通用户和 系统用户
#!/bin/bash echo Please select which list you want to print echo "1. admin (enter 1)" echo ...
- 第2章 细说Linux系统用户/组管理(1)
2.1 用户和组的基本概念 用户和组是操作系统中一种身份认证资源. 每个用户都有用户名.用户的唯一编号uid(user id).所属组及其默认的shell,可能还有密码.家目录.附属组.注释信息等. ...
- Oracle用户和模式,表空间
oracle 用户与表空间关系 oracle用户与表空间关系用户=商家表=商品表空间=仓库1. 1个商家能有很多商品,1个商品只能属于一个商家2. 1个商品可以放到仓库A,也可以放到仓库B,但不能同时 ...
- useradd---创建的新的系统用户
useradd命令 useradd命令用于Linux中创建的新的系统用户.useradd可用来建立用户帐号.帐号建好之后,再用passwd设定帐号的密码.而可用userdel删除帐号.使用user ...
- 高手查看Linux系统用户命令-测评
一.Linux查看用户命令-测评 查看linux所有的用户 cat /etc/passwd 查看普通用户.系统用户(1-499) root:x:0:0:root:/root:/bin/bash < ...
- (四)Linux之用户管理(用户和用户组)
Linux之用户管理(用户和用户组) 目录 Linux之用户管理(用户和用户组) 一.概述 二.用户和组的关系 三.关于UID和GID(用户ID和组ID) 四.用户和组的数据 /etc/passwd内 ...
- CentOS 6.8 ftp服务安装配置 基于本地用户和虚拟用户
CentOS 6.8 ftp服务安装配置 基于本地用户和虚拟用户 一.安装ftp服务 1.检查是否已经安装 # rpm -qa | grep ftp ftp-0.17-54.el6.x86_64 vs ...
- Linux用户和权限——用户和用户组管理
Linux用户和权限——用户和用户组管理 摘要:本文主要介绍了Linux系统中的用户和用户组管理. 用户和用户组 含义 在使用Linux系统时,虽然输入的是自己的用户名和密码,但其实Linux并不认识 ...
随机推荐
- go语言开发IDE
软件下载及绿化方法 GoLand-2018.3 链接:https://pan.baidu.com/s/15AKPDIJIN86vxfriHBjE-g 提取码:060h 选择路径的时候,去掉路径名的版本 ...
- 理解*arg 、**kwargs
这两个是python中的可变参数.*args表示任何多个无名参数,它是一个tuple(元祖):**kwargs表示关键字参数,它是一个dict(字典).并且同时使用*args和**kwargs时,必须 ...
- Nutch2.1+mysql+solr3.6.1+中文网站抓取
1.mysql 数据库配置 linux mysql安装步骤省略. 在首先进入/etc/my.cnf (mysql为5.1的话就不用修改my.cnf,会导致mysql不能启动)在[mysqld] 下添加 ...
- 使用JSP/Servlet技术开发新闻发布系统---Servlet基础
Servlet简介 什么是Servlet 其实就是一个类,主要负责处理用户的请求和做到数据的相应以及页面的跳转,基于Java技术的Web组件 Servlet API Servlet接口 Servlet ...
- 关于 sublime 的插件 AdvancedNewFile 新建文件/文件夹 插件
新建文件的插件: 快捷键:Ctrl + N 路径:当前目录下进行创建:js/index.js 表示在当前js目录下面创建index.js box 表示直接在当前目录下面创建一个bo ...
- boost::swap
boost::swap是对标准库里的std::swap的增强和泛化,为交换两个变量的值提供便捷的方法. 为了使用需包含头文件: #include <boost/swap.hpp> 原理 c ...
- KindEditor3.x-自动上传Word图片功能.
Chrome+IE默认支持粘贴剪切板中的图片,但是我要发布的文章存在word里面,图片多达数十张,我总不能一张一张复制吧?Chrome高版本提供了可以将单张图片转换在BASE64字符串的功能.但是无法 ...
- zabbix的日志监控
前提条件是该日志文件对于启动zabbix agent进程的用户开启了可读权限,而且该日志的路径对该用户开方x权限,让能取到这个日志文件 第一个参数可以不用引号,前提是zabbix用户可以进入文件路径, ...
- xfce 快捷键 命令整理
本文链接:https://blog.csdn.net/cFarmerReally/article/details/53375956 转载自:https://my.oschina.net/u/56535 ...
- Luogu5540 最小乘积生成树
Luogu5540 最小乘积生成树 题目链接:洛谷 题目描述:对于一个\(n\)个点\(m\)条边的无向连通图,每条边有两个边权\(a_i,b_i\),求使\((\sum a_i)\times (\s ...