guns框架使用日记

2018-09-09  本文已影响0人  Kenny_Yu

如果要使用日期类型

需要在html最下面script中写入

<script>

    laydate.render({

            elem:'#控件id'

    });

</script>

添加数据功能

数据库id要为bigint类型

实体类的id添加下面注释

@TableId(value ="id", type = IdType.ID_WORKER) 就可以自动生成id

删除功能

首先获取选取的行 然后在行[0]获取id  再根据这个id传给后台进行删除 传入时id为String类型  后台需要将他转为Long类型

修改功能

    还是首先获取选取的行 然后在行[0]获取id,然后将这个id传给后台跳转页面的接口,根据这个id可以动态生成页面,生成的页面数据就是选中的数据,然后修改后提交给后台,通过input id="id" value="${item.id}" type="hidden"传入id

前台日历时间和后台数据库时间不一致

修改后台yml配置文件的连接数据库url     serverTimezone=Hongkong

面对不同开发环境可以通过

---来进行分割  这是spring profiles的功能

Wrapper初步理解

    首先controller层查询数据后必须是List<Map<String,Object>>或者Map<String,Object>类型,然后给自定义的一个Wrapper包装

    自定义的Wrapper要继承extends BaseControllerWarpper  然后构造函数中

public UserWarpper(List> list) {

    super(list);

}  让父类去处理

    然后重写warpTheMap的方法,自己进行包装

比如

map.put("sexName", ConstantFactory.me().getSexName((Integer) map.get("sex")));

sexName:经过包装后的Map Key

sex:数据库列的名字,通过这个名字去字典查找相应的值

在IConstaantFactory接口类中写这个获取值的方法

然后在ConstaantFactory类中写实现刚刚的那个方法,在这个方法中调用

return getDictsByName("性别", sex);  意思就是在字典中查找对应的值

第一个参数写类型,第二个参数写的是值 比如 性别:1  然后就能返回相应的中文字段了

创建一个字典映射类

目前好像只用在日志记录中

创建一个类如UserDict 继承 AbstractDictMap

重写他的init方法 在里面写

put(字段名,对用中文名中文)

initBeWrapped方法

用于存放些某些需要字典翻译的字段名

如:

putFieldWrapperMethodName(sex,getSexName)

因为 sex 1对应男 2对应女 这种字段就需写在initBeWrapped中

业务日志功能

在Controller层中添加

@BussinessLog注解(value="业务名称",key="用来唯一标识,当一个不能标识的时候可以填两个",dict="UserDict,class") 字典用于查找某些值对应的中文名称

key的值和UserDict里面的属性值想对应

GUNS中使用SWAGGER

只需要在控制层里面得方法中添加@ApiOperation("添加订单")注解就可以了

@RequestParam 对应得paramType="querry"

@PathVariable 对应得paramType="path"

@RequestBody 对应得paramType="body"

获取登陆用户信息

ShiroUser user = ShiroKit.getUser();


@Permission

不加参数就是按正常权限来看能否访问

这个正常权限是检测你请求的路径有没有你的权限

@Permission(参数)

里面的参数是什么就是什么角色可以访问

就是角色管理里面的别名

如果想自定义权限 需要在Const接口类中添加常量


${tips!}

tips是后端model传入的值 在前台页面如果为空则不显示 

Guns框架使用的表单验证是写在js的  用的是bootstrapValidator.js

第一步

在info.js中

InfoDlg中

:validateFields: {

    account: {

        validators: {

            notEmpty: {

                message:'账户不能为空'

                               }

                              }

                       }

}

添加需要验证的字段

第二步:

/**

* 验证数据是否为空

*/

MyOrderInfoDlg.validate =function () {

$('#MyOrderInfoForm').data("bootstrapValidator").resetForm();

    $('#MyOrderInfoForm').bootstrapValidator('validate');

    return $("#MyOrderInfoForm").data('bootstrapValidator').isValid();

};

MyOrderInfoForm:是需验证表单的id

第三步:

在ajax请求中

if (!this.validate()) {

return;

}

开启验证

第四步:

$(function() {

Feng.initValidator("MyOrderInfoForm", MyOrderInfoDlg.validateFields);

});

初始化验证

https://blog.csdn.net/asd245025733/article/details/78061577?locationNum=7&fps=1

这个博客说明了各种验证的方法.

想使用不同模板

重新创建一个模板文件  重新创建一个TemplateEngine类 修改对应的模板路径

最后在AbstractGeneratorConfig的doGunsGeneration方法中将GunsTemplateEngine改为你自己的模板引擎

动态查询功能

1.在html页面中增加输入框

如:

<div class="col-sm-3">

    <#NameCon id="goodsid" name="订单id" />

</div>

2.在js文件下的search方法中获取输入框对应的值

如:

queryData['goodsid'] =$("#goodsid").val();

3.在后台方面,在控制层参数上添加@RequestParam(required =false) String goodsid获取对应的值

4.新建一个实体Wrapper对象

如:

EntityWrapper myOrderEntityWrapper=new EntityWrapper<>();

5.判断每个查询条件是否为空,若不为空则:

myOrderEntityWrapper.like("id",goodsid);

6.最后返回查询数据

return secondService.selectList(myOrderEntityWrapper);

数据范围

myOrderEntityWrapper.in("deptid",ShiroKit.getDeptDataScope());

思路:前台不传入deptid,后台获取当前用户的deptid

test.setDeptid(ShiroKit.getUser().deptId);就可以了

事务

事务的四个特性

原子性(Atomicity):事务是一个原子操作,由一系列动作组成。事务的原子性确保动作要么全部完成,要么完全不起作用。

一致性(Consistency):一旦事务完成(不管成功还是失败),系统必须确保它所建模的业务处于一致的状态,而不会是部分完成部分失败。在现实中的数据不应该被破坏。

隔离性(Isolation):可能有许多事务会同时处理相同的数据,因此每个事务都应该与其他事务隔离开来,防止数据损坏。

持久性(Durability):一旦事务完成,无论发生什么系统错误,它的结果都不应该受到影响,这样就能从任何系统崩溃中恢复过来。通常情况下,事务的结果被写到持久化存储器中。

隔离性

如果不考虑隔离性产生的三种后果:

1.脏读:在一个事务中,读取了另一个未提交事务中的数据.

2.不可重复读:一个事务范围内多次查询,返回了不同数据值(由于在查询间隔被另一个事务修改了)

3.幻读:一个事务批量修改表中的所有数据,这时另一个事务往表里新增了一条记录,导致第一个事务发现修改完之后落了一条,就跟产生幻觉一样.

Mysql提供的四种隔离级别

isolation=Isolation.DEFAULT

Serializable (串行化):可避免脏读、不可重复读、幻读的发生。

Repeatable read (可重复读):可避免脏读、不可重复读的发生(默认的隔离级别) 。(默认)

Read committed (读已提交):可避免脏读的发生。

Read uncommitted (读未提交):最低级别,任何情况都无法保证。

然级别越高,执行效率就越低。

传播行为

propagation=Propagation.REQUIRED

当事务方法被另一个事务方法调用时,须指定事务应该如何传播。

事务的传播行为:

PROPAGATION_REQUIRED--表示当前方法必须运行在事务中。如果当前事务存在,方法将会在该事务中运行。否则,会启动一个新的事务(默认)

PROPAGATION_SUPPORTS--表示当前方法不需要事务,但是如果存在当前事务的话,那么该方法会在这个事务中运行,如果当前没有事务,就以非事务方式执行。

PROPAGATION_MANDATORY--表示该方法必须在事务中运行,如果当前事务不存在,则会抛出一个异常。

PROPAGATION_REQUIRES_NEW--表示当前方法必须运行在它自己的事务中。一个新的事务将被启动。如果存在当前事务,在该方法执行期间,当前事务会被挂起。

PROPAGATION_NOT_SUPPORTED--表示该方法不应该运行在事务中。如果存在当前事务,在该方法运行期间,当前事务将被挂起。

PROPAGATION_NEVER--表示当前方法不应该运行在事务上下文中。如果当前正有一个事务在运行,则会抛出异常

PROPAGATION_NESTED--一个事务内部嵌套事务的执行不会影响外部事务,但外部事务的执行要影响内部

REST框架使用流程

    先访问auth接口获得随机字符串和token

    客户端通过这个随机字符串当作盐先将要发送的数据转化为json,在进行base64加密,在进行md5加密获得对象和签名.

    客户端再访问hello接口,在body当中传入刚刚生成的object和sign  要以raw和json的形式发送,在请求头上

添加Authorization:Bearer+刚刚从auth获取的token值

例如:Bearer eyJhbGciOiJIUzUxMiJ9.eyJyYW5kb21LZXkiOiIzbmhhZ20iLCJzdWIiOiJhZG1pbiIsImV4cCI6MTUzNzg3NzM3OCwiaWF0IjoxNTM3MjcyNTc4fQ.slc5CDGe1Py6Ieo86fpQHlEIQhX8Um3la4z6OnJxVDQHCd_QATMbwvG_ORqJpx3UEFX10g7EJpzdKEC3Y9cI4g

和Content-Type:application/json

就验证成功了

上一篇下一篇

猜你喜欢

热点阅读