改造DWZ框架(1)

简介: 改造DWZ框架

前言:直接从网上荡下DWZ的dwz4j企业级Java Web快速开发框架(Mybatis + SpringMVC) + jUI整合应用使用的话,里面的一些内容比较冗余,另外里面缺少权限和security,以及对postgre的数据库使用demo,而最近项目中需要开发Java Web的项目,我就花了几天的时间制作和部署了初始化系统,完成了login的登录,同时对用户登录和session过期进行安全验证,同时将原有的mybaits改造成了postgre,另外增加了权限的使用方法,由于原来的DWZ的列表增删改查、分页并不能直接使用,那么后来又新增了一个钢材厚度维护的列表供后续开发使用。



成果展示:


image.png

image.png




上图展示了一部分的关键页面,而下面则从代码架构角度分析这次改造DWZ的关键点以及使用DWZ注意的细节



1.login切入画面


对于刚上手的我,在对login画面进行改造的时候花费了不少时间,因为dwz大多使用了配置和文件套用的模式进行页面显示。那么改造login的时候,我们需要注意什么呢

image.png



上图中选中的两个文件为前端的login改造页面,替换成你需要的界面就好了,而后台的login切入点为下图所示

image.png


而在进行登录验证的地方请注意


 

// 对登录用户进行安全验证
    Authentication authentication = myAuthenticationManager
      .authenticate(new UsernamePasswordAuthenticationToken(username, password));
    SecurityContext securityContext = SecurityContextHolder.getContext();
    securityContext.setAuthentication(authentication);
    HttpSession session = request.getSession(true);
    session.setAttribute("SPRING_SECURITY_CONTEXT", securityContext);
    // 当验证都通过后,把用户信息放在session里
    request.getSession().setAttribute(Constants.AUTHENTICATION_KEY, user);

以上代码中进行登录验证的时候,会关联到下图中的几个文件,如果你需要改用户权限和安全登录的代码时,请注意


image.png


在登录验证通过后,会加载会员的权限设置,见以下代码

package dwz.web.management;
import java.util.Date;
import java.util.List;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.security.core.context.SecurityContextHolder;
import org.springframework.security.core.userdetails.UserDetails;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
import dwz.framework.user.ResourceServiceMgr;
import dwz.framework.user.User;
import dwz.framework.user.UserServiceMgr;
import dwz.persistence.beans.SysResource;
import dwz.web.BaseController;
@Controller("management.indexController")
@RequestMapping("/management")
public class IndexController extends BaseController {
  @Autowired
  private UserServiceMgr userMgr;
  @Autowired
  private ResourceServiceMgr resourcesDao;
  @RequestMapping("")
  public String index(Model model) {
    model.addAttribute("now", new Date());
    UserDetails userDetails = (UserDetails) SecurityContextHolder.getContext().getAuthentication().getPrincipal();
    User contextUser = userMgr.getUserByUsername(userDetails.getUsername());
    model.addAttribute("contextUser", contextUser);
    List<SysResource> resources = resourcesDao.getResourcesByUserName(contextUser.getUsername());
    model.addAttribute("resources", resources);
    return "/management/index";
  }
}

以上代码会加载登录用户的权限资源和用户登录信息,然后跳转到


路径 写道

WEB-INF\jsp\management\index.jsp

该文件中会加载登录用户的权限页面,见下面的代码

<c:forEach items="${resources}" var="keyzero">
            <c:if test="${keyzero.level eq 1}">
              <div class="accordionHeader">
                <h2>${keyzero.remark}</h2>
              </div>
              <div class="accordionContent">
                <ul class="tree treeFolder">
                  <c:forEach items="${resources}" var="key" varStatus="stut">
                    <c:if test="${key.level eq 2}">
                      <li>
                        <a>${key.remark}</a>
                        <ul id="child${stut.index}">
                          <c:forEach items="${resources}" var="k">
                            <c:if test="${k.pid eq key.id}">
                              <li><a href="<c:url value='${k.sn}'/>" target="navTab" rel="plateNav">${k.remark}</a></li>
                            </c:if>
                          </c:forEach>
                        </ul>
                      </li>
                    </c:if>
                  </c:forEach>
                </ul>
              </div>
            </c:if>
          </c:forEach>
相关文章
|
SQL 安全 关系型数据库
|
设计模式 存储 测试技术
实战 | UI 自动化测试框架设计与 PageObject 改造
![](https://ceshiren.com/uploads/default/original/3X/e/f/efd4f6ab53cc4a449657509b655cf5e6499878e5.jpeg) 在 UI 自动化测试过程中,面对复杂的业务场景,经常会遇到这样的挑战: - 简单的录制/回放速度快,但无法适应复杂场景; - 编写自动化测试脚本比较灵活,但工作量大且可维护性差; - 以往的
|
设计模式 存储 测试技术
实战 | UI 自动化测试框架设计与 PageObject 改造
实战 | UI 自动化测试框架设计与 PageObject 改造
|
JavaScript API
走进webpack(1)--环境拆分及模块化
  初级的文章和demo已经基本完成了,代码也已经上传到了我的github上,如果你对webpack的使用并不是十分了解,那么建议你回头看下走近系列,里面包括了当前项目中使用频繁的插件,loader的讲解。
1243 0
|
编解码
DWZ查询页面布局改造(1)
DWZ查询页面布局改造
129 0
DWZ查询页面布局改造(1)
|
编解码
DWZ查询页面布局改造
版权声明:欢迎转载,请注明沉默王二原创。 https://blog.csdn.net/qing_gee/article/details/45717613 DWZ查询页面布局改造,dwz的页面查询条件部分如果使用标签ul、li进行布局的话,在页面分辨率较小时,或者窗口缩小时,就会隐藏部分查询条件,为了防止这种情况出现,就需要改造成table来实现,但是可能不会轻而易举的完成,那么就随我来看看吧。
920 0
|
Web App开发 JavaScript 前端开发
|
9月前
|
持续交付 Android开发 开发者
构建高性能微服务架构:后端开发的终极指南构建高效Android应用:Kotlin与Jetpack的完美结合
【5月更文挑战第28天】 在现代软件开发的浪潮中,微服务架构已经成为了设计灵活、可扩展且易于维护系统的重要模式。本文将深入探讨如何构建一个高性能的微服务架构,涵盖从基础概念理解到实践策略部署的全过程。我们将讨论关键的设计原则、技术选型、性能优化技巧以及安全性考虑,旨在为后端开发者提供一个全面的指南,帮助他们构建出能够适应快速变化的市场需求和技术挑战的系统。 【5月更文挑战第28天】 在移动开发的世界中,效率和性能是衡量一个应用成功与否的关键因素。本文将深入探讨如何通过结合Kotlin语言和Android Jetpack组件,来构建一个既高效又易维护的Android应用。我们将透过实际案例分析
|
监控 前端开发 JavaScript
带你入门前端工程(一):技术选型
带你入门前端工程(一):技术选型
657 0

热门文章

最新文章