layui案例

该博客详细介绍了如何利用layui构建一个用户权限管理系统。首先,导入必要的依赖,然后在dao层处理数据访问,web层调用dao层将数据传回前端。接着,配置struts_sy.xml文件,接着编写js界面,包括多个js文件如index.js、login.js等。最后,通过编写jsp文件完成界面展示,如user.jsp和login.jsp。
摘要由CSDN通过智能技术生成

1.导入相关依赖

前言:这个案例写了一个用户表,和角色表,根据用户的所拥有权限展示菜单
用户的权限通过该用户所绑定的角色获得
角色绑定权限,用户通过角色间接获得权限 记住按钮和菜单同属于一张表所以要用 type做区分

自定义标签依赖:代码如下

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
  <modelVersion>4.0.0</modelVersion>
  <groupId>com.zrh</groupId>
  <artifactId>Struts</artifactId>
  <packaging>war</packaging>
  <version>0.0.1-SNAPSHOT</version>
  <name>Struts Maven Webapp</name>
  <url>http://maven.apache.org</url>
  <dependencies>
   
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>4.12</version>
      <scope>test</scope>
    </dependency>
    

	<dependency>
	    <groupId>javax.servlet</groupId>
	    <artifactId>javax.servlet-api</artifactId>
	    <version>4.0.1</version>
	    <scope>provided</scope>
	</dependency>
	
     <dependency>
			<groupId>org.apache.struts</groupId>
			<artifactId>struts2-core</artifactId>
			<version>2.5.13</version>
		</dependency>
   	
   	<dependency>
			<groupId>mysql</groupId>
			<artifactId>mysql-connector-java</artifactId>
			<version>5.1.44</version>
		</dependency>
   	
     <dependency>
			<groupId>jstl</groupId>
			<artifactId>jstl</artifactId>
			<version>1.2</version>
		</dependency>
		
    
			<dependency> 
			   <groupId>javax.servlet.jsp</groupId> 
			   <artifactId>jsp-api</artifactId> 
			   <version>2.1</version> 
			   <scope>provided</scope>
			</dependency>
			
			<dependency>
			<groupId>taglibs</groupId>
			<artifactId>standard</artifactId>
			<version>1.1.2</version>
		</dependency>
		
		
		<!--我们需要自定义标签库一定要引用这个jar包  -->
		<dependency>
			<groupId>org.apache.tomcat</groupId>
			<artifactId>tomcat-jsp-api</artifactId>
			<version>8.0.47</version>
		</dependency>
			
		
		<dependency>
		    <groupId>com.fasterxml.jackson.core</groupId>
		    <artifactId>jackson-databind</artifactId>
		    <version>2.4.4</version>
		</dependency>
		
		<dependency>
			<groupId>cn.hutool</groupId>
			<artifactId>hutool-all</artifactId>
			<version>4.5.16</version>
		</dependency>
		
		<dependency>
			<groupId>com.alibaba</groupId>
			<artifactId>fastjson</artifactId>
			<version>1.2.47</version>
		</dependency>
			
  </dependencies>
  <build>
    <finalName>Struts</finalName>
    <plugins>
    	<plugin>
				<groupId>org.apache.maven.plugins</groupId>
				<artifactId>maven-compiler-plugin</artifactId>
				<version>3.7.0</version>
				<configuration>
					<source>1.8</source>
					<target>1.8</target>
					<encoding>UTF-8</encoding>
				</configuration>
			</plugin>
    </plugins>
  </build>
</project>

2.dao层去访问数据

userDao.java

package com.zrh.crud.dao;

import java.sql.SQLException;
import java.util.List;
import java.util.Map;

import com.zrh.crud.entity.User;
import com.zrh.crud.util.JsonBaseDao;
import com.zrh.crud.util.JsonUtils;
import com.zrh.crud.util.PageBean;
import com.zrh.util.StringUtils;

public class userDao extends JsonBaseDao {
	
	
	/**
	 *登录
	 * 
	 * @param paramMap
	 * @return
	 * @throws Exception
	 */
	public User login(Map<String, String[]> paramMap) throws Exception {
//		String administrator_id = JsonUtils.getParamVal(paramMap, "administrator_id");
		String sql = "select * from administrator where administrator_name = ? and  pwd = ? and statu = 1";
		List<Map<String, Object>> list = super.executeQuery(sql, new String[] {"administrator_name", "pwd"}, paramMap,null);
		if (list != null && list.size() > 0) {
			Map<String, Object> map = list.get(0);
			bindingStr(map.get("administrator_id").toString(), map);
			return new User(map);
		}
		return null;
	}
	
	
	/**
	 * 角色数据绑定
	 * 
	 * @return
	 */
	private void bindingStr(String administrator_id, Map<String, Object> map) throws Exception {
		String sql = "select a.part_id, a.part_name from part a, administrator_and_part b where a.part_id = b.part_id and b.administrator_id = "
				+ administrator_id;
		List<Map<String, Object>> list = super.executeQuery(sql, null);
		String part_names = "";
		String part_ids = "";
		for (Map<String, Object> m : list) {
			part_names += "," + m.get("part_name");
			part_ids += "," + m.get("part_id");
		}
		if (part_names.length() > 0) {
			part_ids = part_ids.substring(1);
			part_names = part_names.substring(1);
		}

		map.put("part_names", part_names);
		map.put("part_ids", part_ids);
	}


	
	/**
	 *查询 
	 * 
	 * @param paramMap
	 * @param pageBean
	 * @return
	 * @throws Exception
	 */
	public List<Map<String, Object>> list(Map<String, String[]> paMap, PageBean pageBean) throws Exception {
		String sql = "select * from administrator where true ";
		
		String administrator_name = JsonUtils.getParamVal(paMap, "administrator_name");
		if (StringUtils.isNotBlank(administrator_name)) {
			sql += " and administrator_name like '%" + administrator_name + "%' ";
		}
		String administrator_id = JsonUtils.getParamVal(paMap, "administrator_id");
		if (StringUtils.isNotBlank(administrator_id)) {
			sql += " and administrator_id = " + administrator_id;
		}
		//带角色查询
		String part_ids = JsonUtils.getParamVal(paMap, "part_ids");
		if (StringUtils.isNotBlank(part_ids)) {
			sql += " and administrator_id in (" + 
					"	select administrator_id from administrator_and_part where part_id in ("+part_ids+") " + 
					")";
		}
		
		List<Map<String, Object>> listt = super.executeQuery(sql, pageBean);

		//用户的角色对应数据绑定(角色名和id)
		for (Map<String, Object> map : listt) {
			bindingStr(map.get("administrator_id").toString(), map);
		}
		return listt;
	}

//增加
	public int add(Map<String, String[]> paMap) throws Exception {
		String sql = "insert into administrator (administrator_name, pwd, statu)values (?, ?, 1)";
		int n = super.executeUpdate(sql, new String[] { "administrator_name", "pwd" }, paMap);
		//获取当前插入id
		int maxId = executeByInteger("select max(administrator_id) from administrator ");
		// 角色数据插入
		String[] part_ids = JsonUtils.getParamVal(paMap, "part_ids").split(",");
		bindingPart(maxId + "", part_ids);
		return n;
	}
	
	
	/**
	 * 
	 * @param administrator_id
	 * @param part_ids
	 */
	public void bindingPart(String administrator_id, String[] part_ids) {
		String sql = "delete from administrator_and_part where administrator_id = " + administrator_id;
		super.executeUpdate(sql);
		for (String part_id : part_ids) {
			super.executeUpdate("insert into administrator_and_part values(" + administrator_id + "," + part_id + ")");
		}
	}




	
	
	
	/**
	 * 修改
	 * @param clz
	 * @return
	 * @throws NoSuchFieldException
	 * @throws SecurityException
	 * @throws IllegalArgumentException
	 * @throws IllegalAccessException
	 * @throws SQLException
	 */
	public int edit(Map<String, String[]> paMap) throws NoSuchFieldException, SecurityException, IllegalArgumentException, IllegalAccessException, SQLException {
		String sql = "update  administrator set administrator_name=?,pwd=? where administrator_id=?";
		int n = super.executeUpdate(sql, new String[] { "administrator_name", "pwd", "administrator_id" }, paMap);
		String[] part_ids = JsonUtils.getParamVal(paMap, "part_ids").split(",");
		bindingPart(JsonUtils.getParamVal(paMap, "administrator_id"), part_ids);
		return n;
	}
	
	
	
	
	
	
	/**
	 * 删除
	 * @param clz
	 * @return
	 * @throws NoSuchFieldException
	 * @throws SecurityException
	 * @throws IllegalArgumentException
	 * @throws IllegalAccessException
	 * @throws SQLException
	 */
	public int del(Map<String, String[]> paMap) throws NoSuchFieldException, SecurityException, IllegalArgumentException, IllegalAccessException, SQLException {
		String sql = "delete from administrator where administrator_id=?";
		return super.executeUpdate(sql, new String[] {"administrator_id"}, paMap);
	}
	
	

	/**
	 * 修改状态
	 * 
	 * @param paramMap
	 * @return
	 * @throws Exception
	 */
	public int eidtStatu(Map<String, String[]> paramMap) throws Exception {
		String sql = "update administrator set statu = ? where administrator_id = ?";
		return super.executeUpdate(sql, new String[] { "statu", "administrator_id" }, paramMap);
	}
	
}

typeDao.java这个是角色

package com.zrh.crud.dao;

import java.sql.SQLException;
import java.util.List;
import java.util.Map;

import com.zrh.crud.util.JsonBaseDao;
import com.zrh.crud.util.JsonUtils;
import com.zrh.crud.util.PageBean;
import com.zrh.util.StringUtils;

public class typeDao extends JsonBaseDao{
	/**
	 * 查询分页方法,查询单挑数据公用的方法
	 * @param clz
	 * @param pagebean
	 * @return
	 * @throws InstantiationException
	 * @throws IllegalAccessException
	 * @throws SQLException
	 */
	public List<Map<String, Object>> list(Map<String, String[]> paMap,PageBean pageBean) throws InstantiationException, IllegalAccessException, SQLException{
		String sql ="select * from part where true";
		String part_name = JsonUtils.getParamVal(paMap, "part_name");
		String part_id = JsonUtils.getParamVal(paMap, "part_id");
		if(StringUtils.isNotBlank(part_id)) {
			sql += " and part_id = "+part_id+"";
		}
		if(StringUtils.isNotBlank(part_name)) {
			sql += " and part_name like '%"+part_name+"%'";
		}
		return super.executeQuery(sql , pageBean);
	}
	
	/**
	 * 增加
	 * @param clz
	 * @return
	 * @throws NoSuchFieldException
	 * @throws SecurityException
	 * @throws IllegalArgumentException
	 * @throws IllegalAccessException
	 * @throws SQLException
	 */
	public int add(Map<String, String[]> paMap) throws NoSuchFieldException, SecurityException, IllegalArgumentException, IllegalAccessException, SQLException {
		String sql="insert into part (part_name,remarks,statu) values(?,?,1)";
		return super.executeUpdate(sql, new String[] {"part_name","remarks"}, paMap);
	}
	
	/**
	 * 修改
	 * @param clz
	 * @return
	 * @throws NoSuchFieldException
	 * @throws SecurityException
	 * @throws IllegalArgumentException
	 * @throws IllegalAccessException
	 * @throws SQLException
	 */
	public int edit(Map<String, String[]> paMap) throws NoSuchFieldException, SecurityException, IllegalArgumentException, IllegalAccessException, SQLException {
		String sql = "update  part set part_name=?,remarks=? where part_id=?";
		return super.executeUpdate(sql, new String[] {"part_name","remarks","part_id"}, paMap);
	}

	
	
	/**
	 * 移除
	 * 
	 * @param paramMap
	 * @return
	 * @throws Exception
	 */
	public int del(Map<String, String[]> paMap) throws Exception {
		super.executeUpdate("delete from administrator_and_part where part_id =" + JsonUtils.getParamVal(paMap, "part_id"));
		super.executeUpdate("delete from part_and_permission where part_id = " + JsonUtils.getParamVal(paMap, "part_id"));
		return super.executeUpdate("delete from part where part_id = ?", new String[] { "part_id" }, paMap);
	}
	
	
	
	/**
	 *获取角色下拉 只有可用的返回
	 * @return
	 * @throws Exception
	 */
	public List<Map<String, Object>> select() throws Exception {
		String sql = "select part_id, part_name  from part where statu = 2";
		return super.executeQuery(sql, null);
		}
	
	
	
	/**
	 * 角色名是否存在
	 * 
	 * @return
	 */
	public boolean isName(Map<String, String[]> paMap) throws Exception {
		List<Map<String, Object>> list = null;
		if(StringUtils.isNotBlank(JsonUtils.getParamVal(paMap, "part_id"))) {
			String sql = "select part_id from part where part_id != ? and part_name = ?";
			 list = super.executeQuery(sql, new String[] { "part_id", "part_name" }, paMap, null);		
		}else {
			String sql = "select part_id from part where part_name = ?";
			 list = super.executeQuery(sql, new String[] {"part_name" }, paMap, null);		
		}	
		return list != null && list.size() > 0;
	}
	
	/**
	 * 修改状态
	 * 
	 * @param paramMap
	 * @return
	 * @throws Exception
	 */
	public int eidtStatu(Map<String, String[]> paMap) throws Exception {
		String sql = "update part set statu = ? where part_id = ?";
		return super.executeUpdate(sql, new String[] { "statu", "part_id" }, paMap);
	}
	
	
	}

MenuDao.java

package com.zrh.crud.dao;

import java.sql.SQLException;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Set;

import com.zrh.crud.entity.TreeNode;
import com.zrh.crud.util.JsonBaseDao;
import com.zrh.crud.util.JsonUtil
  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
layui treetable 是一款基于 layui 框架的树形表格插件。它可以帮助开发者快速地构建树状表格,并实现树的展开、折叠、查找、排序等功能。 使用 layui treetable 插件的案例可以有很多种,下面以一个商品分类管理的案例来说明。 首先,我们需要创建一个表格,用来展示商品分类的树状结构。通过 layui 的 table 模块和 treetable 插件,我们可以很方便地实现这一功能。在页面加载时,调用 treetable.render() 方法,将数据渲染成树状表格,并将其显示在页面上。 接着,我们可以添加一些操作按钮,例如新增分类、编辑分类、删除分类等。当用户点击这些按钮时,通过调用 treetable 方法,可以实现对分类树的增删改操作。例如,当用户点击新增分类按钮时,会弹出一个对话框,用户可以在对话框中填写分类的名称、父类别等信息,然后将这些信息通过 ajax 提交到后台进行保存。保存成功后,通过调用 treetable 的 addNode() 方法,在表格中新增对应的节点。 另外,我们可以为表格添加一些附加功能,例如展开全部、折叠全部、搜索分类等。通过调用 treetable 的相关方法,我们可以实现这些功能。例如,当用户输入关键词进行搜索时,我们可以调用 treetable 的 search() 方法,根据关键词在树状表格中查找匹配的节点,并将这些节点高亮显示。 总的来说,layui treetable 插件是一个非常实用的工具,可以帮助开发者快速地构建树状表格,并实现相关的操作和功能。无论是商品分类管理、组织结构管理还是其他需要以树状结构展示的数据,都可以通过 layui treetable 实现。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值