Filter登录拦截
-
继承
Filter接口并实现doFilter()方法public class LoginFilter implements Filter { @Override public void init(FilterConfig filterConfig) throws ServletException { } @Override public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException,ServletException { HttpServletRequest request = (HttpServletRequest) servletRequest; HttpServletResponse response = (HttpServletResponse) servletResponse; HttpSession session = request.getSession(); User user = (User) session.getAttribute("user"); String uri = request.getRequestURI(); System.out.println("uri: " + uri); System.out.println("uri.indexOf: " + uri.indexOf("login.do")); if (user == null && uri.indexOf("login.do") == -1) { response.sendRedirect(request.getContextPath() + "../login.jsp"); } else { filterChain.doFilter(request, response); } } @Override public void destroy() { } } -
在
web.xml中注册并映射Filter<filter> <filter-name>loginFilter</filter-name> <filter-class>com.llanero.Filter.LoginFilter</filter-class> </filter> <filter-mapping> <filter-name>loginFilter</filter-name> <url-pattern>*.do</url-pattern> </filter-mapping>
批量删除
-
在
mapper\UserMapper.xml和com.llanero.dao.UserDao中定义批量删除用户的SQL语句和方法<delete id="deleteAll" parameterType="list"> delete from ssm_user where id in <foreach collection="ids" item="id" open="(" close=")" separator=","> #{id} </foreach> </delete>void deleteAll(@Param("ids") List<Integer> ids); -
在
com.llanero.service.impl.UserServiceImpl中调用com.llanero.dao.UserDao提供的deleteAll方法@Override public void deleteAll(List<Integer> ids) { userDao.deleteAll(ids); } -
在
webapp\pages\user-list.jsp中定义deleteAll()方法并提交postfunction deleteAll() { var checkedNum=$("input[name='ids']:checked").length; alert(checkedNum); if(checkedNum==0){ alert("请至少选择一个进行删除!!!"); return; } if(confirm("确认要删除这些用户吗?")){ var userList=new Array(); $("input[name='ids']:checked").each( function () { userList.push($(this).val()) } ); alert(userList); $.ajax({ type:"post", url: "${pageContext.request.contextPath}/user/deleteAll.do", data:{userList:userList.toString()}, success:function () { alert("删除成功"); location.reload(); }, error:function () { alert("删除失败"); } }); } } -
com.llanero.controller.UserController中的deleteAll方法调用UserService提供的方法响应请求,完成删除@RequestMapping("deleteAll.do") public String deleteAll(String userList) { System.out.println("userList: " + userList); String[] str = userList.split(","); List<Integer> ids = new ArrayList<>(); for (String s : str) { ids.add(Integer.parseInt(s)); } userService.deleteAll(ids); return "redirect:findAll.do"; }
权限管理
-
在MySQL中设计ssm_role表和user_role表


-
定义相应RoleDao、RoleMapper.xml、RoleService、RoleServiceImpl、bean.Role、bean.UserRole等类和文件
RoleMapper.xml相关SQL语句
<select id="findRoleIdByUserId" parameterType="int" resultType="int"> select roleId from user_role where userId=#{userId} </select> <select id="findRoleByUserId" parameterType="int" resultType="role"> select * from ssm_role where id not in (select roleId from user_role where userId=#{id}) </select> <!--先根据userId在user_role表中查找roleId 在ssm_role表中查找role记录,该用户没在--> <insert id="addRole" parameterType="userRole"> insert into user_role (userId,roleId) values (#{userId},#{roleId}) </insert>RoleServiceImpl相关方法
@Service public class RoleServiceImpl implements RoleService { @Autowired private RoleDao roleDao; @Override public List<Integer> findRoleId(int userId) { return roleDao.findRoleIdByUserId(userId); } @Override public List<Role> findRoleByUserId(int id) { return roleDao.findRoleByUserId(id); } @Override public void add(List<Integer> ids, String userId) { for (int roleId : ids) { UserRole userRole = new UserRole(); userRole.setUserId(Integer.parseInt(userId)); userRole.setRoleId(roleId); roleDao.addRole(userRole); } } } -
在
user-list.jsp中添加相应代码,实现添加角色按钮和功能,并添加user-role-add.jsp,实现添加角色界面<% List<Integer> roleIds = (List<Integer>) session.getAttribute("roleIds");%> <% if (roleIds.contains(1)){ %> <a href="/user/toAddRole.do?id=${user.id}">添加角色</a> <% } %> -
在UserController中定义
public ModelAndView toAddRole和public String add方法,实现界面的添加角色请求@RequestMapping("toAddRole.do") public ModelAndView toAddRole(int id) { List<Role> roleList = roleService.findRoleByUserId(id); ModelAndView modelAndView = new ModelAndView(); modelAndView.addObject("roles", roleList); modelAndView.addObject("id", id); modelAndView.setViewName("user-role-add"); return modelAndView; } @RequestMapping("addRole.do") @ResponseBody public String add(String roleList, String userId) { String[] strings = roleList.split(","); List<Integer> ids = new ArrayList<>(); for (String s : strings) { ids.add(Integer.parseInt(s)); } roleService.add(ids, userId); return ""; }
roleList.split(",");
List ids = new ArrayList<>();
for (String s : strings) {
ids.add(Integer.parseInt(s));
}
roleService.add(ids, userId);
return “”;
}
本文介绍了在Java Web开发中如何使用Filter进行登录拦截,实现批量删除用户的功能,以及详细阐述了权限管理的实现过程,包括在MySQL中设计数据库表,定义相关 Dao、Mapper、Service 和 Controller,以及实现添加角色的交互流程。
317

被折叠的 条评论
为什么被折叠?



