gFStu逻辑

来源:互联网 发布:r语言按列读取csv数据 编辑:程序博客网 时间:2024/06/05 11:24

一、概述

1、内置帐号

默认的developer、super帐号可以对业务部门中顶级管理员授权,不能对业务部门中下级的人员授权。

业务部门中顶级管理员可以对下级授权。授权时还需要设置业务部门中顶级管理员的“授权权限”,即该管理员对下级人员可授予哪些权限


下级平行的部门都要分别设立 类似的角色?


角色授权 和 人员授权 功能类似,用户最终权限  为两者的并集

--------------

登录帐户[用户名/密码]<br>
[developer/111111][super/111111]<br>
[xiongchun_a_3/111111][xiongchun_b_3/111111]<br>
提示:使用super帐户登录,可体验Web桌面布局。

2、



三、业务流程

1、使用struts访问jsp页面流程,(url如:zq1/tzxmydgz.do?reqCode=uploadInit

a、 web.xml

配置action,加载action文件。如“config/zq1“

b、struts-config-zq1.xml

配置xxx.do、xxxAction.java、跳转JSP,根据xxxAction.java返回的 跳转标志 跳转到 xml指定的JSP页面。

如path="/tzxmydgz"、<forward name="fileUploadView" path="/tzxmydgz/fileMan.jsp" />

c、 xxxAcion.java

返回跳转标志

action访问JSP的url:(a+b).do,如zq1/tzxmydgz.do

JSP文件的物理路径:(a+c),如zq1/tzxmydgz/fileMan.jsp


url:zq1/tzxmydgz.do?reqCode=uploadInit

zq1:web.inf中的config/zq1

tzxmydgz:struts-config-zq.xml中的path="/tzxmydgz"

uploadInit:FileAction.java中的uploadInit方法


a-------》project\webapp\WEB-INF\web-inf.xml

web-inf中指定加载具体的配置文件:struts-config-zq1.xml

<init-param>   <!-- 配置action,加载action文件 --><param-name>config/zq1</param-name><param-value>/WEB-INF/struts-config-zq1.xml</param-value></init-param>

b-------》project\webapp\WEB-INF\struts-config-zq.xml

配置xxx.do(访问url)、xxxAction.java、跳转JSP之间的关系

<action name="baseActionForm" path="/tzxmydgz" scope="request"parameter="reqCode" type="com.zhengqi.tzxmydgz.web.FileAction"><forward name="fileUploadView" path="/tzxmydgz/fileMan.jsp" /><forward name="exceptionView" path="/tzxmydgz/exception.jsp" /></action>

c-------》project\src\main\java\com\zhengqi\tzxmydgz\web\FileAction.java

action返回跳转标志

public ActionForward uploadInit(ActionMapping mapping, ActionForm form, HttpServletRequest request,HttpServletResponse response) throws Exception {return mapping.findForward("fileUploadView");}

d-------》根据c中的跳转标志和b中的返回页面,project\webapp\zq\tzxmydgz\fileMan.jsp

FileAction.java中的方法名与url中的regCode参数名 一致

------JS中URL不带“文件夹名”


四、sql

1、sql执行流程

-------》FileMan.jsp

-------》FileUpload.js       JS通过调用xxx.do使用FileAction.jav中提供的数据

-------》FileAction.java (-------》web-inf-------》struts-config-zq.xml-------》struts-config-zq.xml,即同上一步中的a、b、c的关系)


src\resources\

-------》config\global.config.xml 导入业务处理对象tzxmydgz.service.xml

-------》config\global.dao.xml 导入tzxmydgz.sqlmap.xml

-------------------------------------------

-------》config.tzxmydgz\tzxmydgz.service.xml 导入com.zhengqi.tzxmydgz.web.service.impl.TzxmydgzServiceImpl实现类

-------》config.tzxmydgz\tzxmydgz.sqlmap.xml 业务系统的SQL映射文件装载,Tzxmydgz.xml

-------------------------------------------

-------》sqlmap\tzxmydgz\Tzxmydgz.xml 手工映射sql语句(tzxmydgz文件夹  要和  Tzxmydgz.xml文件 一样?)

第4行<sqlMap namespace="Bls">,Bls为xxxAction调用sql映射文件的 名称,如g4Reader.queryForObject("Bls.getCodeListForPageCountBL", inDto);

-------------------------------------------

-------》com.zhengqi.tzxmydgz.web.service\TzxmydgService.java

-------》com.zhengqi.tzxmydgz.web.service.impl\TzxmydgzServiceImpl.java

2、

JSP:  fileUpload.js

<G4Studio:import src="/zq/tzxmydgz/js/fileUpload.js" />

JS: tzxmydgz.do?reqCode=queryFileDatas-------》通过web-inf.xml中action的相关定义。。。转发到Action.Java

var store = new Ext.data.Store({proxy : new Ext.data.HttpProxy({url : 'tzxmydgz.do?reqCode=queryFileDatas'}),

Action.Java: Demo.queryFiles

     private TzxmydgzService tzxmydgzService = (TzxmydgzService) getService("<span style="color:#009900;">tzxmydgzService</span>");   //tzxmydgz.service.xml中,<bean id="tzxmydgzService" parent="baseTransactionProxyG4">
 public ActionForward queryFileDatas(。。。 //方法名 与 JS中URL的参数一致
      List list = g4Reader.queryForPage("<span style="color: rgb(0, 153, 0); font-family: Arial, Helvetica, sans-serif;">Tzxmydgz</span>.queryFiles", dto);                       <span style="font-family: Arial, Helvetica, sans-serif;">//Tzxmydgz.xml中<sqlMap namespace="Tzxmydgz"></span>      Integer countInteger = (Integer) g4Reader.queryForObject("Demo.countFiles", dto);

Tzxmydgz.xml:

<sqlMap resource="sqlmap/tzxmydgz/Tzxmydgz.xml" />

Tzxmydgz.xml:

<!-- 查询文件列表信息 --><select id="queryFiles" parameterClass="map" resultClass="dto">   SELECT fileid, title, path,filesize,remark FROM ea_demo_upload WHERE 1=1<dynamic><isNotEmpty prepend="AND" property="title">title like '%$title$%'</isNotEmpty></dynamic>order by fileid desc</select><!-- 统计文件列表 --><select id="countFiles" parameterClass="map" resultClass="java.lang.Integer">   SELECT count(*) FROM ea_demo_upload WHERE 1=1<dynamic><isNotEmpty prepend="AND" property="title">title like '%$title$%'</isNotEmpty></dynamic></select>


3、数据插入

方法:优点是可以一次性的插入需要的数据,即一次性的把数据表字段与表单中字段“绑定”

XXXaction: inDto.put()-------》XXXService.saveXXX()-------》在action类中,将form表单提交的数据统一放入Dto,调用service类的方法保存Dto中的数据

xxxService.java-------》service接口类

xxxServiceImpl.java-------》service实现类,通过g4Dao调用xml文件中的sql

xxx.xml:-------》insert id=“”,sql语句-------》实现类 










十一、去除

1、查看网页源代码中“此页面代码由G4系统集成与应用开发平台模板引擎组件强力驱动生成。。。”

\project\src\main\java\org\gFourStu\core\web\taglib\html\template\HtmlTag.tpl"(2,1):

\project\src\main\java\org\gFourStu\system\admin\web\tag\template\ArmDesktopTag.tpl"(2,1):

2、360浏览器,使用兼容模式不显示、使用急速模式

修改上述文件:

在Head中添加一行代码:<meta name=”renderer” content=”webkit|ie-comp|ie-stand”>

content的取值为webkit,ie-comp,ie-stand之一,区分大小写,分别代表用极速模式,兼容模式,IE模式打开。

2、登录后,主窗口上的 当前菜单

db,eamenu

3、jetty启动时显示:启动成功。。。 | 技术支持 >> www.g4it.org。。。

org.g4studio.core.server.GFourserver.java

4、项目url中的gFOURStu

src\resources\gFOURserver.properties

5、日志中的“G4Studio行业应用二次快速开发平台->开始启动...”

org.g4studio.common.util.SystemInitListener




0 0